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

參考文章

相關文章
相關標籤/搜索