使用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
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"]
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"}