Deploying Golang supposed to be very simple & straight forward, compare with other language like Java, PHP etc, but i found a lot of article on the internet make looks very complicated & not straight to the point. So i write this note to give you some insight about how Golang deploy on top of Ubuntu Server with Nginx as Reverse Proxy + SSL HTTPS certificate.
Deployment Step ✨
Clone Project to Server 🌿
First step is pretty simple, just SSH your linux server with root access & move to /var/www directory. Clone your go project, like this:
git clone https://github.com/Faeshal/crowdfunding
As always dont forget to create & setup .env file, if you have it.
Installing Golang on Server 🍀
This is optional step, you can deploy without installing Golang on the server as long as you already build your Golang code, because remember what the server will run is native Golang binaries NOT raw Golang code (.go extension). But the recommended way is still installing Golang on the server so we can setup auto build CI/CD later.
go to your server again & move to directory /usr/local to download the file by typing:
wget https://go.dev/dl/go1.19.linux-amd64.tar.gz
🚧 watch out the version!. If you wanna install spesific Golang version be careful on that.
you can make sure the file was downloaded by typing “ls” & to extract the file just type:
tar -C /usr/local -xvf go1.19.linux-amd64.tar.gz
As you can see go folder will appear & if you want, you can delete go tar.gz that you download before.
Setup GO PATH, so when you type “go” on server terminal, linux will recognize your command.
nano ~/.bashrc
do not care about other texts. Just focus on the last line. You need to add the path on the last line, save it & exit.
export PATH=$PATH:/usr/local/go/bin
refresh it by typing:
source ~/.bashrc
done, you can check by typing “go version”. Linux will recognize the command.
after that move to your Golang project for build your GO app by typing “go build -o app-name” for example i will name it “funding-server”.
go build -o funding-server
to run the program, very simple just type:
./funding-server
Creating Linux Systemd Service 🥬
Systemd is a service manager for Linux operating systems. We need it for managing our Golang app that we already build, so when our server is restart or crash and the server is up again, our Golang app will run automatically. The step is pretty easy:
move to directory /etc/systemd/system & create service file based on your Golang app name.
🚧 if you change the config, dont forget to reload: “systemctl daemon-reload”
until this step, basically you can access your Golang app by typing server-ip:port, because i set 7070 for my app, so the result is:
🔥 but this is NOT a good & secure way. We need to hide the port & put Golang behind a Reverse Proxy. That’s why we need NGINX to do that.
Setup Nginx as Reverse Proxy 🌵
A reverse proxy is an application that typically sits between firewall & backend service. Nginx is one of the best reverse proxy in town. It will directing requests to the appropriate backend. Reverse proxies are typically implemented to increase security, performance, and reliability 🥇
Btw, i already have domain from Domainesia & for this app i will pointing to subdomain go.faeshal.com. Dont forget to add “A record” on your domain provider dashboard & fill it with your server IP.
install Nginx
apt-get install Nginx
move to /etc/nginx/sites-available directory. Copy default Nginx config & create a new one, just in case
Open config file with nano. 🚨 Remember because we use proxy pass, you must comment “listen port 80”. Enter valid root path based on project directory, server name based on your domain & proxy pass based on your app port. Dont forget to save the config.
nano go.faeshal.com
restart & check Nginx configuration, if you fail on this step don’t continue. Just check your Nginx configuration again, maybe there is a typo.
service Nginx restart nginx -t
done, now Golang is run behind Nginx, but we need one last thing. Setup SSL so we can have Https connection.
Setup SSL HTTPS 🔰
HTTPS is the secure version of HTTP, which is the primary protocol used to send data & it’s encrypted in order to increase security of data transfer.
we gonna using certbot, a package that handle all ssl stuf, very simple to install just type:
done, we got https connection. Very simple isn’t it ?
Hope this basic Golang deployment useful, many things that you can improved, such as adding firewall or adding caching mechanism. Anyway stay safe & stay secure, peace out 🖐️