使用gin框架起一个最基础的web服务来说明整个流程。

编写程序代码

main.go

package main

import "github.com/gin-gonic/gin"

func main() {
	r := gin.Default()
	r.GET("/ping", func(c *gin.Context) {
		c.JSON(200, gin.H{
			"message": "pong",
		})
	})
	r.Run("0.0.0.0:8080") // listen and serve on 0.0.0.0:8080 (for windows "localhost:8080")
}
127.0.0.1192.168.0.10.0.0.0

编写Dockerfile文件

FROM golang:alpine
MAINTAINER JiangHongJie "jhj767658181@gmail.com"
# docker中的工作目录
WORKDIR $GOPATH/src/gin_docker
# 将当前目录同步到docker工作目录下,也可以只配置需要的目录和文件(配置目录、编译后的程序等)
ADD . ./
# 由于所周知的原因,某些包会出现下载超时。这里在docker里也使用go module的代理服务
ENV GO111MODULE=on
ENV GOPROXY="https://goproxy.io"
# 指定编译完成后的文件名,可以不设置使用默认的,最后一步要执行该文件名
RUN go build -o gin_docker .
EXPOSE 8080
# 这里跟编译完的文件名一致
ENTRYPOINT  ["./gin_docker"]

构建docker镜像

sudo docker build -t gin_docker .

构建完成查看镜像列表

vagrant@homestead:~/go_project/gin_docker$ docker image ls
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
gin_docker          latest              ed64de3e98e9        2 hours ago         469MB
logforce            latest              3cfe19164260        3 hours ago         511MB
<none>              <none>              d20ebc82d1e6        6 hours ago         810MB
<none>              <none>              c19c1e8968e1        6 hours ago         828MB
golang              alpine              30df784d6206        2 weeks ago         370MB

启动容器

vagrant@homestead:~/go_project/gin_docker$ docker run --name gin_docker -p 8080:8080 -d gin_docker
ae97da70bc94a4c9a235f44a7d12030b283a2fabd56fc2be1a70ffef3a805c71
vagrant@homestead:~/go_project/gin_docker$ docker container ls
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS                    NAMES
ae97da70bc94        gin_docker          "./gin_docker"      24 seconds ago      Up 22 seconds       0.0.0.0:8080->8080/tcp   gin_docker

访问服务

vagrant@homestead:~/go_project/gin_docker$ curl 127.0.0.1:8080/ping
{"message":"pong"}

参考文章