使用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")
}
這里需要注意的是docker里面的host不能配置127.0.0.1
或者192.168.0.1
否則宿主機器將無法訪問端口。所以這里服務啟動時要綁定在0.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"}