(bssh) ➜ ~ echo $SHELL
/bin/zsh
(bssh) ➜ ~ ps -p $$
PID TTY TIME CMD
58746 ttys000 0:00.94 /bin/zsh
(bssh) ➜ ~
GoLang_System_Essentials_Notes_Chapter_1
Why Go
Apart from easy to read code and simple learning curve which encourages everyone to quickly adopt the existing code system, Go has a very strong concurrency model.
Concurrency defines throughput of your system. When a task is waitnig for I/O resources, if you can code like other task can leverage the idle CPU, then throughput of your entire program will be increased.
Go uses channels for communicating between threads and go follows CSP when it comes to implementation of threads and thread communication.
There is an excellent paper written on same. https://www.cs.cmu.edu/~crary/819-f09/Hoare78.pdf
And another prinicple, share memory not by locks but by communicating. We can write a lot about go concurrency, but lets see in practicals.
Go in-built tools
go build main.go
to generate go binary
go test
to run tests
go run main/hello.go
to run your program but no binary generation
go vet filename.go
to check errors in your code.
go fmt file.go
to format your go code.
Cross platform development
two main env variables, GOOS
and GOARCH
GOOS
for OS Target
GOARCH
for CPU arch, amd64, darwin etc
Linux build command
GOOS=linux GOARCH=amd64 go build
For Mac
GOOS=darwin GOARCH=amd64 go run
We can also add build tags for specific platform
// go:build windows
package main
import "fmt"
func main() {
fmt.Println("This is Windows!")
}
// go:build linux
package main
import "fmt"
func main() {
fmt.Println("This is Linux!")
}
GOOS=windows go build -o app.exe
GOOS=linux go build -o app
Linux: Firefox in Debian+I3m taking a lot of time to load
Recently, Firefox in my Linux setup( Debian + i3wm) taking a lot of time to reload. Upon searching I came to know that its caused by xdg-desktop-portal package. From Arch docs I understand that its for opening the application in a sandbox environment for better safety and then I thought no security needed for Firefox if its not there for Chrome.
So I remove it.
sudo apt-get remove xdg-desktop-portal
Hope it helps.
How to fix Microsoft Blue Death Of Screen(BDOS) issue ?
Notes - Kevlin Henney - The Case For Technical Excellence
Ref: https://www.youtube.com/watch?v=LLEXAdO3X1o
Agile: able to move quickly and easily, quick movement
- Prioritising business goals over technical excellence
The over-engineered Agile approach is gonna spoil both Business Goals and Technical Excellence.
Agile - And if your application architecture sucks - code quality drops
Agility is an observation, can I move the code quickly and easily?
The software where you are working on, is it agile?
Feature work vs. technical Work: people create this, this is a false dichotomy
Feature work is technical work. People don't think like this.
Features are made of software which is technical work.
You need to figure out business value, which varies from context to context.
Business value and also varies by time, when thinking in the perspective of business value, you should think on business value over a day, over a week, a month, an year, a decade
Challenge Somebody on business value.
prioritise by business value -> prioritize the backlog
No Product Owner / No Business owner knows the business value. The only way you know the business value is by building it, shipping it and observing the value generation over time and then comparing it with our initial assessment.
Prioritize by business value estimate(d). Semantics means meanings. Actuals not an estimate. There is vagueness in the lang we speak i.e we dont know the stuff.
"Architecture represents the significant design decisions that shape a system, where significant is measured by cost of change" by Grady Booch
Where do you spend time and money. Less
What effect does ignoring quality have in the long term ?
- It has no effect? : Well its impossible answer, someone gave this answer ? interesting
- It reduces the cost? probably in the term, then mark it for later review
- It increases the cost ? then pickup immediately and reduce the cost
Technical debt is an effect, what is the cause of this ?
We distracted by wrong thing, what is the cause by debt ?
Technical Neglect:
tech debt - legacy code
Practical Example: A boat on the water, people are throwing the water outside instead of fixing the whole from where water coming to the boat. This is technical debt.
As an evolving program is continually changed, its complexity, reflecting deteriorating structure, increases unless work is done to maintain or reduce it. By Meir M Legman
Legacy born in 1989 in software world.
maintenance -> deteriorating the code -> by adding a new feature -> then you should maintain the structure of the program
Time Is Money -> We are lending money and converting that into money
Arguments is war
Arguments are buildings
Love is journey
Happy is up, sad is down
To be considered good, a metaphor has to offer a number of points of useful correspondence with what is being described.
Another quality is good metaphor is that it should not have too many obvious points of conflict
The Third quality of a metaphor that makes it effective is familiarity to its audience
Martin Flower: Technical debt is a wonderful metaphor developed by Ward Cunningham, in this metaphor, doing things the quick and dirty way sets us up with a technical debt, which is similar to a financial debt.
Shipping first time code is like going into debt, A little debt speeds development so long as it is paid back promptly with a rewrite.
Create a thing - get the feedback - respond - add a feature -> deliver - > get the feedback
A structured debit is good, its not bad like a house loan.
Bad Science : You cant convert technical debt into financial debt, its unmanaged technical debt.
Technical debt is not the cost of repaying the debt: it is the cost of owning the debt. These are not the same.
In summary in my words
- Technical debt is not something that we think is technical debt
- technical debt cant be converted into money
- you should convert the value lost due to technical debt as its technical debt
- you should always follow the structure of your architecture to avoid more technical debt
- If you are working on something always ask, is it adding any value?
- A value by fixing a debt in terms of loss might approach by not fixing it.
- if your developers are spending a lot of time of understanding the past code instead of adding new features then you are not adding much value.
- Here the point is, why your developers are spending time to understand the code, why cant the developers who have idea on the code can't fix it while the new developers can work on features
Git: How to set set default branch as master?
root@arch-host ~ ✖ git config --add --global user.name "<username"
git config --add --global user.email "email@yahoo.com"
root@arch-host ~ ➜ git config --global --unset rerere.enabled
git config --global init.defaultBranch master
root@arch-host ~ ➜ cat ~/.gitconfig
[user]
name = rxxxx
email = xxxxxx@yahoo.com
[init]
defaultBranch = master
root@arch-host ~ ➜