久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      基于Docker鏡像部署go項(xiàng)目(實(shí)例詳解)

      本篇文章給大家?guī)砹嘶赿ocker鏡像部署go項(xiàng)目的相關(guān)知識,其中包括編寫GoLang web程序、編譯linux下的程序包的相關(guān)問題,希望對大家有幫助。

      基于Docker鏡像部署go項(xiàng)目(實(shí)例詳解)

      依賴知識

      • Go交叉編譯基礎(chǔ)
      • Docker基礎(chǔ)
      • Dockerfile自定義鏡像基礎(chǔ)
      • docker-compose編排文件編寫基礎(chǔ)

      當(dāng)然,一點(diǎn)也不會也可以按照這個(gè)步驟部署完成,不過可能中間如果出點(diǎn)小問題,會不知道怎么解決,當(dāng)然你也可以留言。

      我是在mac環(huán)境上開發(fā)測試的,如果你是在windows上可能有一點(diǎn)出入,但應(yīng)該不會有啥大問題。

      一、依賴環(huán)境

      • Docker

      二、編寫一個(gè)GoLang web程序

      我這里就寫一個(gè)最簡單的hello world程序吧,監(jiān)聽端口是80端口。
      新建一個(gè)main.go文件,內(nèi)容如下:

      package mainimport (     "fmt"     "log"     "net/http")func sayHello(w http.ResponseWriter, r *http.Request) {     fmt.Fprintf(w, "hello world")}func main() {     http.HandleFunc("/", sayHello)//注冊URI路徑與相應(yīng)的處理函數(shù)     log.Println("【默認(rèn)項(xiàng)目】服務(wù)啟動成功 監(jiān)聽端口 80")     er := http.ListenAndServe("0.0.0.0:80", nil)     if er != nil {         log.Fatal("ListenAndServe: ", er)     }}

      三、編譯成linux下的程序包

      我是在mac上開發(fā)的,需要用到go的交叉編譯,如果對交叉編譯不熟悉的,可以查下文檔,或者直接復(fù)制我下面的命令進(jìn)行編譯。
      我們是要跑在Docker里面,基礎(chǔ) golang這個(gè)鏡像跑的,所以需要把他編譯成兼容 i386 處理器的程序。

      sudo env GOOS=linux GOARCH=386 go build main.go

      這個(gè)編譯完成后,本地會多出一個(gè) main 程序,暫時(shí)不用管它備用就行。

      四、使用 Dockerfile 定制我們go程序的鏡像

      新建一個(gè)文件夾,里面新建一個(gè)Dockerfile文件,再在里面新建appscript兩個(gè)文件。把上一步的main程序放到app文件夾里面,在script里面新建一個(gè)build.sh腳本文件,文件內(nèi)容先不管,等下會說。
      具體的文件結(jié)構(gòu)是這樣。

      . ├── Dockerfile ├── app │   └── main └── script     └── build.sh

      下面就是編寫Dockerfile文件內(nèi)容了,內(nèi)容我先上代碼:

      FROM golang MAINTAINER  青羽 WORKDIR /go/src/COPY . .EXPOSE 80CMD ["/bin/bash", "/go/src/script/build.sh"]

      這里解釋下:

      • FROM 是集成自哪個(gè)鏡像,我們是go程序官方提供了一個(gè)golang這樣的鏡像,我們可以直接使用。
      • MAINTAINER 是維護(hù)這名字。
      • WORKDIR 工作目錄。
      • COPY 這是一個(gè)復(fù)制命令,把本地的所有文件復(fù)制到工作目錄下。
      • EXPOSE 這是對方開發(fā)的端口,我默認(rèn)是開放80端口,這里可根據(jù)實(shí)際情況修改
      • CMD 執(zhí)行一個(gè)帶參數(shù)的命令,我這樣寫,是為了讓鏡像啟動時(shí)去執(zhí)行script/build.sh的腳本,這個(gè)腳本里面是寫的啟動go程序的命令。
        這里我把內(nèi)容粘貼出來:
      #!/usr/bin/env bash cd /go/src/app/ && ./main

      就這兩行。

      五、編譯我們自己的鏡像

      這屬于Docker的知識了,我把命令粘貼出來。

      docker build -t go-web .
      • 這個(gè)命令執(zhí)行,如果本地沒有 golang 這個(gè)鏡像的話,他會自己先去官方鏡像庫拉取這個(gè)鏡像再編譯,我們靜靜的等他就行。
      • go-web這個(gè)參數(shù)是你最后編譯后的鏡像名字,可以隨意修改,也可以加上版本號比如: go-web:v1。

      基于Docker鏡像部署go項(xiàng)目(實(shí)例詳解)

      看到上面這個(gè)輸出,就說明編譯成功了,在你的本地鏡像里面就有了一個(gè)名為go-web的鏡像??梢允褂?docker images 進(jìn)行查詢:

      基于Docker鏡像部署go項(xiàng)目(實(shí)例詳解)

      六、編寫 docker-compose.yml 文件

      到這里屬于我們的最后一步了,如果用我們剛編譯的go-web來運(yùn)行我們的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

      到這里我們的編排文件已經(jīng)寫好了,現(xiàn)在只需要用docker-compose來啟動我們的編排文件就好,啟動命令如下:

      docker-compose -f docker-compose.yml up -d world

      如果輸出下面的提示,說明啟動成功了。

      Creating world ... done

      啟動成功后你可以再用

      docker ps

      來查看下是否啟動成功了。

      現(xiàn)在訪問http://127.0.0.1:8099 就能訪問我們的go程序了。

      推薦學(xué)習(xí):《docker視頻教程》

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號