go-build-template

A Makefile/Dockerfile example for Go projects.

Github stars Tracking Chart

Go app template build environment

Build Status

This is a skeleton project for a Go application, which captures the best build
techniques I have learned to date. It uses a Makefile to drive the build (the
universal API to software projects) and a Dockerfile to build a docker image.

This has only been tested on Linux, and depends on Docker to build.

Customizing it

To use this, simply copy these files and make the following changes:

Makefile:

  • change BIN to your binary name
  • rename cmd/myapp to cmd/$BIN
  • change REGISTRY to the Docker registry you want to use
  • maybe change SRC_DIRS if you use some other layout
  • choose a strategy for VERSION values - git tags or manual

Dockerfile.in:

  • maybe change or remove the USER if you need

Go Modules

This assumes the use of go modules (which will be the default for all Go builds
as of Go 1.13) and vendoring (which reasonable minds might disagree about).
You will need to run go mod vendor to create a vendor directory when you
have dependencies.

Building

Run make or make build to compile your app. This will use a Docker image
to build your app, with the current directory volume-mounted into place. This
will store incremental state for the fastest possible build. Run make all-build to build for all architectures.

Run make container to build the container image. It will calculate the image
tag based on the most recent git tag, and whether the repo is "dirty" since
that tag (see make version). Run make all-container to build containers
for all supported architectures.

Run make push to push the container image to REGISTRY. Run make all-push
to push the container images for all architectures.

Run make clean to clean up.

Main metrics

Overview
Name With Ownerthockin/go-build-template
Primary LanguageMakefile
Program languageMakefile (Language Count: 3)
Platform
License:Apache License 2.0
所有者活动
Created At2016-09-21 03:16:57
Pushed At2025-04-30 22:20:44
Last Commit At2025-04-30 15:20:37
Release Count0
用户参与
Stargazers Count3.3k
Watchers Count53
Fork Count435
Commits Count153
Has Issues Enabled
Issues Count55
Issue Open Count6
Pull Requests Count57
Pull Requests Open Count1
Pull Requests Close Count20
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private