Skip to content

A template for a simple Go-Docker service with hot reloading.

License

Notifications You must be signed in to change notification settings

MichalMoravik/go-docker

Repository files navigation

Go-Docker Template

A template for a simple Go-Docker service with hot reloading.

Usage Locally

  1. Use, pull, or fork this template.
  2. Navigate to the folder.
  3. Change the name to your project's name in the go.mod file.
  4. Run docker-compose up.

If the port 8081 is already occupied on your machine, go to the docker-compose.yml file and choose a different port.

  1. Send requests to http://127.0.0.1:8081/yo.

Deployment

  • When deploying the code, build the server from Dockerfile.serverd.
  • Dockerfile.serverd.dev and docker-compose.yml should not be used when running the deployed server
  • The deployed server will run on 8080 (as mentioned in Dockerfile.serverd).

I suggest deploying the code to Cloud Run using Cloud Build (CI) built from your GitHub branch. This is the most straightforward way I've worked with.

Hot Reloading Explained

To maximize the potential of Docker, you should always develop and run the service inside a container. But when you create a container locally, the code is copied to the container just once.

The code is not, by default, updated when you make code changes on your host machine.

In order to refresh the code inside the container after it is changed, we have to mount the code using volumes (see volumes section in docker-compose.yml file). This is only 50% of the work though.

Once the code inside the container changes, you have refresh the server. This is what the Air library does for you.

Now you can run the server locally and each time you change the code from your code editor, the container will refresh and the server will reflect the changes.

Removing the volumes section from the docker-compose.yml file will malfunction hot reloading.

About

A template for a simple Go-Docker service with hot reloading.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages