dev-resources.site
for different kinds of informations.
Build your first service in golang
Overview
Go delivers speed, security, and developer-friendly tools for Web Applications
Go is designed to enable developers to rapidly develop scalable and secure web applications. Go ships with an easy to use, secure and performant web server and includes its own web templating library. Go has excellent support for all of the latest technologies from HTTP/2, to databases like MySQL, MongoDB and ElasticSearch, to the latest encryption standards including TLS 1.3. Go web applications run natively on Google App Engine and Google Cloud Run (for easy scaling) or on any environment, cloud, or operating system thanks to Go’s extreme portability.
Go for Web Development
What is a web service (REST API)
Setup environment
installing Golang
go to the official documentation and follow the steps to install golang on your machine.
installing a code editor
You can use one of the available IDEs like Goland from JetBrains.
But I personally prefer using Visual Studio Code editor because it's lightweight compared to IDEs and it combines the simplicity of a source code editor with powerful developer tooling, like IntelliSense code completion and debugging.
Go in VSCode: Must-have extensions
Let's Go
- Start by creating a
main.go
file in your project root folder.
In this file we are going to define the main package and the main function (entry point of any golang program)
package main
func main() {
}
Packages in go
Functions in go
- Now we are going to create our project module (introduction to golang modules) run the flowing command in the cmd (inside you project directory):
go mod init devfest.com/gopher
A new file will be added in your project directory named go.mod
in wich you will find the module name golang version
in my case:
module devfest.com/gopher
go 1.17
Let's set up our server
- We start by creating a new package(folder) named
server
. In this package we create a new filehttp.go
, in this file we will implement the server setup and start functions and we will handle our first request.
We add the package name and define an empty struct called HttpService
(structs in go)
package server
type HttpService struct{
}
- Than we implement the server Start function:
- We define the function signature
func Start() {}
- We print message to the console to indicate that the server is starting and mention the port the server is going to run on
func Start() {
fmt.Printf("Starting server at port %s\n", ":8080")
}
We used the fmt package so we can use the Printf function thus we need to import it.
import "fmt"
We can see above that the function Start begins with a capital letter (as well as the Printf func from the fmt package) wich is unusual for someone comming from a different programming language especially an OOP language, in fact methods in Go are exported by capitalizing its first letter.
Exported names
- We then use the function ListenAndServe function from the net/http package which starts a golang server on a provided port
func Start() {
fmt.Printf("Starting server at port %s\n", ":8080")
err := http.ListenAndServe(fmt.Sprintf(":%s", "8080"), nil)
if err != nil {
log.Println(err)
}
}
We can see the new :=
annotation it's a short variable declaration operator in go .
The function ListenAndServe returns an error so we handle it by checking if it's not nil (null) we log it.
- we add a receiver to the start function to assign it to the HttpService struct: (Method receivers/ Pointers)
func (svc *HttpService) Start() {
fmt.Printf("Starting server at port %s\n", ":8080")
err := http.ListenAndServe(fmt.Sprintf(":%s", "8080"), nil)
if err != nil {
log.Println(err)
}
}
- now let's implement the Setup function:
func (svc *HttpService) Setup() {
http.HandleFunc("/ping", ping)
}
The Setup function is exported and assigned to the HttpService. As we can see we called the function HundleFunc from the net/http
package that registers a handler function for the given pattern (in our case /ping).
- We need to implement the ping function to handle the request on /ping:
func ping(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Pong!")
}
ping starts with a lowercase letter so it's not exported thus it can only be called from the server package
, it takes two params: r of type *http.Request (in which we can find all the request information) and w of type http.ResponseWriter (which will be used to return the response to the request sender). In the ping function we used the Fprintf of the fmt package to return a message using the ResponseWriter.
don't forget to import the fmt package
http.go
would look like this in the end:
package server
import (
"fmt"
"log"
"net/http"
)
type HttpService struct {
}
func (svc *HttpService) Setup() {
http.HandleFunc("/ping", ping)
}
func ping(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Pong!")
}
func (svc *HttpService) Start() {
fmt.Printf("Starting server at port %s\n", ":8080")
err := http.ListenAndServe(fmt.Sprintf(":%s", "8080"), nil)
if err != nil {
log.Println(err)
}
}
Let's go back to
main.go
to create an instance of our server, configure it and run it.We start by importing the server package so we can get our server type and functions.
import "devfest.com/gopher/server"
As we can see here we started the import by specifying the module name that we created in the beginning devfest.com/gopher
then the package name to tell the compiler that we are going to import the server package from this module.
- Now we create a new variable of type
HttpService
of our server package, and we call the setup function to set up our server and the start function to start it.
func main() {
var server server.HttpService
server.Setup()
server.Start()
}
As we have assigned Setup and Start functions to HttpService
struct we were able to call them by adding .
after the variable after the variable name of type server.HttpService
.
The main func would look like this in the end:
package main
import "devfest.com/gopher/server"
func main() {
var server server.HttpService
server.Setup()
server.Start()
}
Let's test our server
- Now that we have implemented our first golang server it's time to test it.
run the flowing command in the cmd (inside you project directory): two ways of running a go program
go run main.go
- After running this command we can see a message indicating that the server is starting at port 8080, then the cmd is freezing, which means that our server has started running and it's waiting for us to send a request for it to handle it.
- We can now test our Server by heading to the browser and typing this url
http://localhost:8080/ping
and hit enter, the browser will issue a request to our server as it's running on the your device (localhost) at port 8080, than our server will redirect our request to the ping function, as we are sending the request on "/ping", and return the "Pong!" message that will be displayed on your browser tab.
Congratulations 🎉 you have just finished implementing your first golang server and you have learned a little about the language itself.
Conclusion
I hope this was helpful to guide you through building your first golang server and starting to discover the language by building something fun from scratch.
You can head over to the official Go documentation to explore more about the language.
You can start with this tutorial that will help you discover the basics of the language.
And you can also see go used in different examples.
Featured ones: