您好,登錄后才能下訂單哦!
小編這次要給大家分享的是Docker鏡像怎么部署go項目,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
依賴知識
當然,一點也不會也可以按照這個步驟部署完成,不過可能中間如果出點小問題,會不知道怎么解決,當然你也可以留言。
我是在mac環境上開發測試的,如果你是在windows上可能有一點出入,但應該不會有啥大問題。
一、依賴環境
二、編寫一個GoLang web程序
我這里就寫一個最簡單的hello world程序吧,監聽端口是80端口。
新建一個main.go
文件,內容如下:
package main import ( "fmt" "log" "net/http" ) func sayHello(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "hello world") } func main() { http.HandleFunc("/", sayHello)//注冊URI路徑與相應的處理函數 log.Println("【默認項目】服務啟動成功 監聽端口 80") er := http.ListenAndServe("0.0.0.0:80", nil) if er != nil { log.Fatal("ListenAndServe: ", er) } }
三、編譯成linux下的程序包
我是在mac上開發的,需要用到go的交叉編譯,如果對交叉編譯不熟悉的,可以查下文檔,或者直接復制我下面的命令進行編譯。
我們是要跑在Docker
里面,基礎 golang
這個鏡像跑的,所以需要把他編譯成兼容 i386
處理器的程序。
sudo env GOOS=linux GOARCH=386 go build main.go
這個編譯完成后,本地會多出一個 main
程序,暫時不用管它備用就行。
四、使用 Dockerfile 定制我們go程序的鏡像
新建一個文件夾,里面新建一個Dockerfile
文件,再在里面新建app
,script
兩個文件。把上一步的main
程序放到app
文件夾里面,在script
里面新建一個build.sh
腳本文件,文件內容先不管,等下會說。
具體的文件結構是這樣。
. ├── Dockerfile ├── app │ └── main └── script └── build.sh
下面就是編寫Dockerfile
文件內容了,內容我先上代碼:
FROM golang MAINTAINER 謙益 WORKDIR /go/src/ COPY . . EXPOSE 80 CMD ["/bin/bash", "/go/src/script/build.sh"]
這里解釋下:
FROM
是集成自哪個鏡像,我們是go程序官方提供了一個golang
這樣的鏡像,我們可以直接使用。
MAINTAINER
是維護這名字。
WORKDIR
工作目錄。
COPY
這是一個復制命令,把本地的所有文件復制到工作目錄下。
EXPOSE
這是對方開發的端口,我默認是開放80端口,這里可根據實際情況修改
CMD
執行一個帶參數的命令,我這樣寫,是為了讓鏡像啟動時去執行script/build.sh
的腳本,這個腳本里面是寫的啟動go程序的命令。
這里我把內容粘貼出來:
#!/usr/bin/env bash cd /go/src/app/ && ./main
就這兩行。
五、編譯我們自己的鏡像
這屬于Docker
的知識了,我把命令粘貼出來。
docker build -t go-web .
golang
這個鏡像的話,他會自己先去官方鏡像庫拉取這個鏡像再編譯,我們靜靜的等他就行go-web
這個參數是你最后編譯后的鏡像名字,可以隨意修改,也可以加上版本號比如: go-web:v1
。看到上面這個輸出,就說明編譯成功了,在你的本地鏡像里面就有了一個名為go-web
的鏡像。可以使用 docker images
進行查詢:
六、編寫 docker-compose.yml 文件
到這里屬于我們的最后一步了,如果用我們剛編譯的go-web
來運行我們的go程序:
version: '2' networks: basic: services: world: container_name: world image: go-web ports: - "8099:80" volumes: - ./app/go/world:/go/src/app:rw networks: - basic
到這里我們的編排文件已經寫好了,現在只需要用docker-compose
來啟動我們的編排文件就好,啟動命令如下:
docker-compose -f docker-compose.yml up -d world
如果輸出下面的提示,說明啟動成功了。
Creating world ... done
啟動成功后你可以再用
docker ps
來查看下是否啟動成功了。
現在訪問http://127.0.0.1:8099
就能訪問我們的go程序了。
看完這篇關于Docker鏡像怎么部署go項目的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。