4 minutes
First Golang Meetup
Saturday 21-July-2018, was the first meetup of Gurgaon Golang meetup and also my first Golang meetup. Organised at Grofers Headquater, Gurgaon for all the gophers in Delhi-NCR.
Everybody was already half way through the Q/A session when I reached (I was late). Kasisnu was giving a demo of an exercise from the Go book (TCP server that periodically writes the time). You can read the source code of the Exercise from here.
The very first Talk was given by Alkesh Shrivastava on Goroutines which I failed to attend. You can refer this doc for reference. Since it was the very first meetup, introductions are a good way to start. One by one, everyone including the hosts and attendees, everyone gave a brief introduction about themself. During introductions, Melvin talked about his experience with Golang in industry. Kasisnu shared his experience with Golang. Kasisnu shared some useful information about the meetup, like the slack channel of Gurgaon-Golang-Meetup(you can join from here) where the discussions will take place.
It was networking break, Grofers provided us with pizzas and cold-drinks and to keep the fun going.There was also a quiz with prize for the winner. The attendees were asked to solve the problems of this repository and the people with PRs would be given prize, isn’t it interesting? Experienced The Best networking while sharing pizza and discussing the solutions of the problem.
After the break, when everyone was done with there snacks it was lightning sessions’ turn.Lightening session given by Yash Mehrotra who introduced us to Grofers’ go-codon which generates Go server code from a combination of REST and Workflow DSLs. The concept was fairly new to me but people were excited to know about it.All we have to do is place swagger specification for all our upstream APIs in the folder spec/clients in config.yml format and then these will be converted to client libraries. For more detailed explaination refer this wiki
For a surprize, we had another round of pizzas for everyone (because of our humble host Kasisnu). While everyone was excited about it Madhukar Mishra began with his talk on Go’s concurrency model. Stating with first and foremost misunderstanding, Concurrency is not Parallelism refer this talk for clear insite. Go follows communicating sequential processes(CSP) model of concurrency which requires:
- concurrently executing entities
- communicating by sending “messages” to each other
A very basic and easy example to understand this model is by looking at *NIX pipes. To help in understanding the go concurrency let’s go through some examples.The go statement runs the function as usual, but doesn’t make the caller wait. It launches a goroutine.func main() { boring("boring!") } func boring(msg string) { //a very boring function that runs forever like a boring party guest for i := 0; ; i++ { fmt.Println(msg, i) time.Sleep(time.Duration(rand.Intn(1e3)) * time.Millisecond) //random sleep interval } }
func main() { go boring("boring!") fmt.Println("I'm listening.") time.Sleep(2 * time.Second) fmt.Println("You're boring; I'm leaving.") }
What is a goroutine? It’s an independently executing function, launched by a go statement. It has its own call stack, which grows and shrinks as required. It’s very cheap. It’s practical to have thousands, even hundreds of thousands of goroutines. It’s not a thread. There might be only one thread in a program with thousands of goroutines.Instead, goroutines are multiplexed dynamically onto threads as needed to keep all the goroutines running. The above boring example cheated.the main function couldn’t see the output from the other goroutine. It was just printed to the screen, where we pretended we saw a conversation. Now comes channels, a channel in Go provides a connection between two goroutines, allowing them to communicate. For example :
func main() {
c := make(chan string)
go boring("boring!", c)
for i := 0; i < 5; i++ {
fmt.Printf("You say: %q\n", <-c) // Receive expression is just a value.
}
fmt.Println("You're boring; I'm leaving.")
}
func boring(msg string, c chan string) {
for i := 0; ; i++ {
c <- fmt.Sprintf("%s %d", msg, i) // Expression to be sent can be any suitable value.
time.Sleep(time.Duration(rand.Intn(1e3)) * time.Millisecond)
}
}