Golang应用打包docker镜像并运行

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

编写程序代码

main.gogit

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

这里须要注意的是docker里面的host不能配置127.0.0.1或者192.168.0.1不然宿主机器将没法访问端口。因此这里服务启动时要绑定在0.0.0.0上。github

编写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 .

构建完成查看镜像列表golang

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

参考文章

相关文章
相关标签/搜索