Build your first service in golang

_alaedeen_

Alaeddine Eloueryemmi

Posted on December 9, 2021

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() {

}
Enter fullscreen mode Exit fullscreen mode

Packages in go
Functions in go

go mod init devfest.com/gopher
Enter fullscreen mode Exit fullscreen mode

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

Enter fullscreen mode Exit fullscreen mode

Let's set up our server

  • We start by creating a new package(folder) named server. In this package we create a new file http.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{

}
Enter fullscreen mode Exit fullscreen mode
  • Than we implement the server Start function:
  • We define the function signature
func  Start() {}
Enter fullscreen mode Exit fullscreen mode
  1. 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")
}
Enter fullscreen mode Exit fullscreen mode

We used the fmt package so we can use the Printf function thus we need to import it.

import "fmt"
Enter fullscreen mode Exit fullscreen mode

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

  1. 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)
    }
}
Enter fullscreen mode Exit fullscreen mode

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.

  1. 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)
    }
}
Enter fullscreen mode Exit fullscreen mode
  • now let's implement the Setup function:
func (svc *HttpService) Setup() {
    http.HandleFunc("/ping", ping)
}
Enter fullscreen mode Exit fullscreen mode

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!")
}
Enter fullscreen mode Exit fullscreen mode

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)
    }
}

Enter fullscreen mode Exit fullscreen mode
  • 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"
Enter fullscreen mode Exit fullscreen mode

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()
}

Enter fullscreen mode Exit fullscreen mode

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()
}

Enter fullscreen mode Exit fullscreen mode

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
Enter fullscreen mode Exit fullscreen mode
  • 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.

cmd

  • 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.

request from the browser

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.

💖 💪 🙅 🚩
_alaedeen_
Alaeddine Eloueryemmi

Posted on December 9, 2021

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related