Docker 化你的開源項目

引言

在我開源的 藍眼云盤 (https://github.com/eyebluecn/tank) 中有 網(wǎng)友建議 道使用docker并且push到DockerHub上,這樣子就可以一行代碼直接安裝藍眼云盤了。這個提議非常好,因此本篇文章就記錄下藍眼云盤docker化的整個詳細(xì)過程。在閱讀這篇文章之前,讀者需要具有Docker基礎(chǔ),我推薦閱讀 《Docker — 從入門到實踐》 。

目標(biāo)

  • 熟悉docker和docker-compose的基本操作
  • 熟悉將 golang 工程部署到docker的整個流程
  • 能夠在docker中快速啟動藍眼云盤,訪問 http://server-ip:6010 可以看到首頁內(nèi)容

環(huán)境

1. 宿主機環(huán)境

$ cat /etc/redhat-release
CentOS Linux release 7.4.1708 (Core)

宿主機不要求和我完全一致,其他版本的Linux也行,甚至Mac Os, Windows ,只要能安裝docker都行。

2. docker

$ docker version

Client:
 Version:       18.01.0-ce
 API version:   1.35
 Go version:    go1.9.2
 Git commit:    03596f5
 Built: Wed Jan 10 20:07:19 2018
 OS/Arch:       linux/amd64
 Experimental:  false
 Orchestrator:  swarm

Server:
 Engine:
  Version:      18.01.0-ce
  API version:  1.35 (minimum version 1.12)
  Go version:   go1.9.2
  Git commit:   03596f5
  Built:        Wed Jan 10 20:10:58 2018
  OS/Arch:      linux/amd64
  Experimental: false

docker 盡量使用最新版本

構(gòu)建Docker鏡像

1. 準(zhǔn)備源代碼

clone 項目 Github后端tank地址 到本地。

# 可以根據(jù)自己的實際情況,決定項目放置的位置
$ mkdir -p /data/group/golang/
$ cd /data/group/golang/

# clone 藍眼云盤項目
$ git clone https://github.com/eyebluecn/tank.git
$ cd tank

2. 制作Dockerfile文件

我們需要從源代碼開始編譯整個項目,Dockerfile文件描述整個構(gòu)建的過程。
在tank根目錄下創(chuàng)建文件Dockerfile。
在clone下來的藍眼云盤項目中,Dockerfile已經(jīng)存在了,你可以直接閱讀Dockerfile中的內(nèi)容,或者刪除這個文件重新創(chuàng)建,以作學(xué)習(xí)練習(xí)使用。

Dockerfile的內(nèi)容如下:

# 使用1.9的golang作為母鏡像
FROM golang:1.9

# 維護者信息,也就是作者的姓名和郵箱
MAINTAINER eyeblue "eyebluecn@126.com"

# 指定工作目錄就是 tank。工作目錄指的就是以后 每層構(gòu)建的當(dāng)前目錄 。
WORKDIR $GOPATH/src/tank

# 將tank項目下的所有文件移動到golang鏡像中去
COPY . $GOPATH/src/tank

# 這里為了維持docker無狀態(tài)性,準(zhǔn)備數(shù)據(jù)卷作為日志目錄和上傳文件目錄
VOLUME /data/log
VOLUME /data/matter
# 通過環(huán)境變量的方式,為應(yīng)用指定日志目錄和上傳文件目錄。
ENV TANK_LOG_PATH=/data/log TANK_MATTER_PATH=/data/matter


# golang.org庫國內(nèi)無法下載,這里從我準(zhǔn)備的github中clone
# github.com的庫可以直接通過`go get`命令下載
# `go install tank`是對項目進行打包
# `cp`是將項目需要的html等文件移動到可執(zhí)行文件的目錄下。
RUN git clone https://github.com/eyebluecn/golang.org.git $GOPATH/src/golang.org \
    && go get github.com/disintegration/imaging \
    && go get github.com/json-iterator/go \
    && go get github.com/go-sql-driver/mysql \
    && go get github.com/jinzhu/gorm \
    && go get github.com/nu7hatch/gouuid \
    && go install tank \
    && cp -r $GOPATH/src/tank/build/* $GOPATH/bin

# 聲明運行時容器提供服務(wù)端口,這只是一個聲明。默認(rèn)是6010端口
EXPOSE 6010

# tank作為執(zhí)行文件 啟動這個容器就會去執(zhí)行 `/go/bin/tank`
ENTRYPOINT ["/go/bin/tank"]

3. 開始構(gòu)建docker鏡像

首先保證當(dāng)前目錄是Dockerfile所在的目錄,然后執(zhí)行以下指令即可開始構(gòu)建:

$ docker build -t eyeblue/tank:1.0.2 .

其中eyeblue 是我的 Docker Hub ID,tank是鏡像名,1.0.2是我當(dāng)前構(gòu)建的鏡像版本。
注意最后的小點.不要遺漏了。

如果構(gòu)建成功,會看到以下提示

Successfully built 3cc1bf6757af
Successfully tagged eyeblue/tank:1.0.2

4. 推送到遠程

只有當(dāng)我們把自己構(gòu)建的鏡像push到Docker Hub后,別人才能很方便的下載,一行命令執(zhí)行我們的應(yīng)用。如果你對Docker Hub注冊,或者命令行登錄不熟悉,請參考這篇文章:《Docker Hub》

推送到遠程的指令如下:

$ docker push eyeblue/tank:1.0.2

如果命令執(zhí)行成功,你將看到以下提示

The push refers to repository [docker.io/eyeblue/tank]
62f3bd4ed81c: Pushed
b417ac3c9fc9: Pushed
2a7192ac3426: Pushed
b7600cc31df2: Mounted from library/golang
690bf254e66f: Mounted from library/golang
23c5addd579d: Mounted from library/golang
af1e37edd79f: Mounted from library/golang
b31411566900: Mounted from library/golang
06f4de5fefea: Mounted from library/golang
851f3e348c69: Mounted from library/golang
e27a10675c56: Mounted from library/golang
1.0.2: digest: sha256:7ba3c6b95ab5fef022342543fbb7cff5bf8b61c2ae2795900c83ba616da32375 size: 2635

運行項目

1. docker-compose 安裝

我們的藍眼云盤項目在運行的時候依賴mysql數(shù)據(jù)庫,在docker中運行一個鏡像依賴另一個鏡像的時候就要使用到docker-compose。首先進入docker-compose下載頁 。找到一個穩(wěn)定版本的安裝腳本,在命令行中執(zhí)行便可。

$ curl -L https://github.com/docker/compose/releases/download/1.18.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

$ chmod +x /usr/local/bin/docker-compose

2. 編寫docker-compose.yml

docker-compose.yml描述了鏡像啟動的數(shù)據(jù)卷,環(huán)境變量,啟動方式,依賴項等。運行藍眼云盤的docker-compose.yuml如下:

#docker-compose版本,這里的3不要動
version: "3"
services:

   # 數(shù)據(jù)庫的鏡像信息
   # 使用mysql:5.7的鏡像
   db:
     image: mysql:5.7
     volumes:
       # 數(shù)據(jù)庫文件存放在宿主機的`~/data/mysql`位置,如果宿主機目錄不存在,則會自動創(chuàng)建
       - ~/data/mysql:/var/lib/mysql
     # 如果啟動失敗,則總是會重啟。因為鏡像有依賴的情況,不停重啟可以保證依賴項啟動成功后自己再運行
     restart: always
     environment:
       # 指定root密碼為`tank123`,并且創(chuàng)建一個新數(shù)據(jù)庫`tank`,同時用戶名和密碼為`tank` `tank123`
       MYSQL_ROOT_PASSWORD: tank123
       MYSQL_DATABASE: tank
       MYSQL_USER: tank
       MYSQL_PASSWORD: tank123

   # 藍眼云盤的鏡像信息
   # 依賴 mysql:5.7 的鏡像
   tank:
     image: eyeblue/tank:1.0.2
     depends_on:
       - db
     ports:
       # 端口映射關(guān)系,宿主機端口:鏡像端口
       - "6010:6010"
     # 如果啟動失敗,則總是會重啟。因為鏡像有依賴的情況,不停重啟可以保證依賴項啟動成功后自己再運行
     restart: always
     environment:
       # mysql的端口
       TANK_MYSQL_PORT: 3306
       # Mysql的主機,和services的第一個節(jié)點一致。
       TANK_MYSQL_HOST: db
       # 數(shù)據(jù)庫
       TANK_MYSQL_SCHEMA: tank
       # 數(shù)據(jù)庫的用戶名
       TANK_MYSQL_USERNAME: tank
       # 數(shù)據(jù)庫的密碼
       TANK_MYSQL_PASSWORD: tank123
       # 超級管理員的昵稱。只能是英文或數(shù)字
       TANK_ADMIN_USERNAME: admin
       # 超級管理員郵箱,作為登錄賬號
       TANK_ADMIN_EMAIL: admin@tank.eyeblue.cn
       # 超級管理員密碼,作為登錄密碼
       TANK_ADMIN_PASSWORD: 123456
     volumes:
       # 日志文件存放在宿主機的`~/data/tank/log`位置,如果宿主機目錄不存在,則會自動創(chuàng)建
       - ~/data/tank/log:/data/log
       # 上傳文件存放在宿主機的`~/data/tank/matter`位置,如果宿主機目錄不存在,則會自動創(chuàng)建
       - ~/data/tank/matter:/data/matter

3. 運行項目

首先保證當(dāng)前目錄是docker-compose.yml所在的目錄,然后執(zhí)行以下指令即可運行藍眼云盤:

$ docker-compose up -d

4. 驗證

由于數(shù)據(jù)庫啟動需要一定的時間,因此大約20s后,打開瀏覽器訪問http://127.0.0.1:6010,如果看到以下界面則表示運行成功。

[圖片上傳失敗...(image-a9a12-1517293121825)]

5. 停止項目

方法一:使用以下命令來停止藍眼云盤

$ docker-compose stop

方法二:當(dāng)然你也可以用停止容器的方式來停止藍眼云盤

$ docker container ls

CONTAINER ID        IMAGE                COMMAND                  CREATED             STATUS              PORTS                    NAMES
f5f64735fc53        eyeblue/tank:1.0.2   "/go/bin/tank"           20 minutes ago      Up 13 seconds       0.0.0.0:6010->6010/tcp   tank_tank_1
3a859cad3e7e        mysql:5.7            "docker-entrypoint.s…"   20 minutes ago      Up 14 seconds       3306/tcp                 tank_db_1

$ docker container stop f5
$ docker container stop 3a

參考文章

我開源了一個私人云盤——藍眼云盤

Docker — 從入門到實踐

Docker實戰(zhàn) - 將golang工程部署到docker

原文發(fā)布于藍眼博客 https://blog.eyeblue.cn/home/article/510f9316-9ca1-40fe-b1b3-5285505a527d

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Docker — 云時代的程序分發(fā)方式 要說最近一年云計算業(yè)界有什么大事件?Google Compute Engi...
    ahohoho閱讀 15,828評論 15 147
  • 0. 前言 docker是什么?docker是用GO語言開發(fā)的應(yīng)用容器引擎,基于容器化,沙箱機制的應(yīng)用部署技術(shù)???..
    sessionboy閱讀 4,000評論 2 49
  • 一 、什么是 Docker Docker 最初是 dotCloud 公司創(chuàng)始人 Solomon Hykes 在法國...
    Blazzer閱讀 3,239評論 0 13
  • 是結(jié)束,也是開始...... 西藏之行結(jié)束的那天下午,我獨自一人在拉薩火車站坐上了回京的火車。 天漸漸黑了下來。窗...
    君君1001閱讀 1,023評論 21 31
  • 你說三亞又降溫了 我這里不 因為一直都冷 我戴上帽子和手套 冷從縫隙里鉆 在我身上取暖 有人說為啥冬天人就喜歡賴床...
    覺知之光閱讀 112評論 1 2

友情鏈接更多精彩內(nèi)容