docker 鏡像倉庫 Harbor 部署 以及 跨數據複製

docker 鏡像倉庫 Harbor 部署 跨數據複製mysql

Harbor 是 Vmwar 公司開源的 企業級的 Docker Registry 管理項目nginx

它主要 提供 Dcoker Registry 管理UI,可基於角色訪問控制, AD/LDAP 集成,日誌審覈等功能,徹底的支持中文。git

Harbor 的全部組件都在 Dcoker 中部署,因此 Harbor 可以使用 Docker Compose 快速部署。github


注: 因爲 Harbor 是基於 Docker Registry V2 版本,因此 docker 版本必須 > = 1.10.0 docker-compose >= 1.6.0 golang


開源項目地址:https://github.com/vmware/harborsql


1、 使用docker compose 快速部署:mongodb

首先用 git 下載 源碼。docker

git clone https://github.com/vmware/harbor數據庫

下載完之後 進入 harbor/Deploy 目錄ubuntu

初始化配置, 配置文件爲harbor.cfg

 

## Configuration file of Harbor
# hostname 設置訪問地址,支持IP,域名,主機名,禁止設置127.0.0.1
hostname = reg.mydomain.com

# 訪問協議,可設置 http,https
ui_url_protocol = http

# 郵件通知, 配置郵件通知。
email_server = smtp.mydomain.com
email_server_port = 25
email_username = sample_admin@mydomain.com
email_password = abc
email_from = admin <sample_admin@mydomain.com>
email_ssl = false

# harbor WEB UI登錄使用的密碼
harbor_admin_password = Harbor12345

# 認證方式,這裏支持多種認證方式,默認是 db_auth ,既mysql數據庫存儲認證。
# 這裏還支持 ldap 以及 本地文件存儲方式。
auth_mode = db_auth

# ldap 服務器訪問地址。
ldap_url = ldaps://ldap.mydomain.com
ldap_basedn = uid=%s,ou=people,dc=mydomain,dc=com

# mysql root 帳戶的 密碼
db_password = root123
self_registration = on
use_compressed_js = on
max_job_workers = 3 
verify_remote_cert = on
customize_crt = on

# 一些顯示的設置.
crt_country = CN
crt_state = State
crt_location = CN
crt_organization = organization
crt_organizationalunit = organizational unit
crt_commonname = example.com
crt_email = example@example.com

 


修改成配置文件之後 運行./prepare腳本更新配置, 出現以下信息表示 更新完畢.

 

Generated configuration file: ./config/ui/env
Generated configuration file: ./config/ui/app.conf
Generated configuration file: ./config/registry/config.yml
Generated configuration file: ./config/db/env
Generated configuration file: ./config/jobservice/env
Clearing the configuration file: ./config/ui/private_key.pem
Clearing the configuration file: ./config/registry/root.crt
Generated configuration file: ./config/ui/private_key.pem
Generated configuration file: ./config/registry/root.crt
The configuration files are ready, please use docker-compose to start the service.

 

執行完畢會生成一個 docker-compose.yml  文件

 

配置 docker-compose.yml 文件中的 掛載目錄,啓動方式等選項。 

 

使用 pip install docker-compose 安裝 docker-compose

執行 docker-compose up -d 構建docker 容器

docker hub 下載鏡像實在是慢, Harbor 提供了一個 配置本地鏡像的配置: cd harbor/contrib/prebuild-install

運行 update_compose.sh 配置本地的鏡像倉庫

咱們也能夠配置 --registry-mirror= 來加速下載 使用 daocloud 提供的 mirror http://b438f72b.m.daocloud.io

 

 

[root@localhost Deploy]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
deploy_jobservice   latest              be822b50163d        43 minutes ago      804.6 MB
deploy_mysql        latest              5015ce56c9d5        49 minutes ago      328.8 MB
deploy_ui           latest              8596c12dbeba        About an hour ago   808.1 MB
deploy_log          latest              6a74c6f52a2b        About an hour ago   187.9 MB
mysql               5.6                 5e0f1b09e25e        2 days ago          328.8 MB
ubuntu              14.04               0ccb13bf1954        12 days ago         187.9 MB
golang              1.6.2               8ecba0e9bd48        5 weeks ago         753.5 MB
nginx               1.9                 c8c29d842c09        10 weeks ago        182.7 MB
registry            2.4.0               8b162eee2794        3 months ago        171.1 MB

 

 

[root@localhost Deploy]# docker ps -a
CONTAINER ID        IMAGE                    COMMAND                  CREATED             STATUS              PORTS                                      NAMES
9704f42b05d5        deploy_jobservice        "/go/bin/harbor_jobse"   4 minutes ago       Up 4 minutes                                                   deploy_jobservice_1
0f8ff9b099d2        library/nginx:1.9        "nginx -g 'daemon off"   4 minutes ago       Up 4 minutes        0.0.0.0:80->80/tcp, 0.0.0.0:443->443/tcp   deploy_proxy_1
6b0159939874        deploy_ui                "/go/bin/harbor_ui"      4 minutes ago       Up 4 minutes        80/tcp                                     deploy_ui_1
6f2298da0f67        deploy_mysql             "docker-entrypoint.sh"   4 minutes ago       Up 4 minutes        3306/tcp                                   deploy_mysql_1
2dbca506e1ea        library/registry:2.4.0   "/bin/registry serve "   4 minutes ago       Up 4 minutes        5000/tcp, 0.0.0.0:5001->5001/tcp           deploy_registry_1
fc5b1a201c72        deploy_log               "/bin/sh -c 'cron && "   4 minutes ago       Up 4 minutes        0.0.0.0:1514->514/tcp                      deploy_log_1

 


完成之後,使用 http://userIP/ 訪問 Harbor

使用 賬號 admin, 密碼爲 配置文件中 harbor_admin_password = Harbor12345 的密碼 登錄


至此, Harbor 已經搭建完成,具體在 WEB UI 下面操做也是很是的簡單,只有幾個選項。


docker 須要上傳 push 鏡像,須要在 docker 中配置 --insecure-registry userIP 或者在nginx 中配置 https

配置完畢之後,重啓 docker

使用 docker login userIP 登錄 Harbor

[root@swarm-manager ~]#docker login 10.6.0.192
Username (admin): admin
Password: 
Login Succeeded

 

查看 本地 images

[root@swarm-manager ~]#docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
mongodb             latest              8af05a33e512        3 weeks ago         958.4 MB
sath89/oracle-12c   latest              7effebcd18ee        11 weeks ago        5.692 GB
centos              latest              778a53015523        4 months ago        196.7 MB

 

tag 修改 image 的名字. 格式爲: userip/項目名/image名字:版本號

 

[root@swarm-manager ~]#docker tag mongodb 10.6.0.192/jicki/mongodb:1.0


[root@swarm-manager ~]#docker images
REPOSITORY                 TAG                 IMAGE ID            CREATED             SIZE
10.6.0.192/jicki/mongodb   1.0                 8af05a33e512        3 weeks ago         958.4 MB
mongodb                    latest              8af05a33e512        3 weeks ago         958.4 MB
sath89/oracle-12c          latest              7effebcd18ee        11 weeks ago        5.692 GB
centos                     latest              778a53015523        4 months ago        196.7 MB

 


push 鏡像到 Harbor

 

[root@swarm-manager ~]#docker push 10.6.0.192/jicki/mongodb:1.0
The push refers to a repository [10.6.0.192/jicki/mongodb]
c1e4cd91bcd4: Pushed 
d9a948970255: Pushed 
dd9b001e77ee: Pushed 
625440e212f2: Pushed 
75fa23acbccb: Pushed 
fd269370dcf4: Pushed 
44e3199c59b3: Pushed 
db3474cfcfbc: Pushed 
5f70bf18a086: Pushed 
6a6c96337be1: Pushed 
1.0: digest: sha256:c7d2e619d86089ffef373819a99df1390c4f2df4aeec9c1f7945c55d63edc670 size: 2824

 

 

登錄 WEB UI , 選擇項目, 項目名稱 jicki , 進入 既可查看剛纔上傳的 image

 


至此, Harbor 都已經部署完成。

 


2、 配置Docker 鏡像複製。

 

 

 

 

 

配置 2個 Harbor

IP 1 = 10.6.0.192

IP 2 = 10.6.0.196


在 10.6.0.192 上面咱們已經push 了一個 鏡像,因此咱們將這臺看成 主節點,10.6.0.196 爲從複製節點。

進入 WEB UI 選擇 項目, 選擇項目爲 jicki , 而後選擇 複製 選項。

 

 

點擊 新增策略

 

 

 

建立完畢之後,咱們能夠看 複製策略 已經有一欄。

複製任務裏面 也已經有一個任務。

 


稍等一會,能夠看到 複製任務裏面 那個任務已經提示 完成。


登錄 10.6.0.196 的 WEB UI

 

咱們能夠看到, 鏡像已經複製過來。並且連 日誌操做 也會複製過來。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

harbor 升級

 

1、

cd harbor/Deploy/

執行 docker-compose down

刪除原有的容器

 

2、

備份整個目錄

mv harbor/ /tm/harbor

 

3、

從新 下載新的源碼

git clone https://github.com/vmware/harbor

 

4、
若是harbor 是遷移到其餘服務器,請先執行數據備份

cd harbor/migration/

修改 migration.cfg 文件裏面的 數據庫 賬號密碼

docker build -t migrate-tool .

 

5、
運行一個臨時數據庫容器,注意:/data/database 爲你設置的掛載數據庫的目錄 /path/to/backup 數據備份的目錄

數據庫備份:
docker run -ti --rm -v /data/database:/var/lib/mysql -v /path/to/backup:/harbor-migration/backup migrate-tool backup

 

6、
數據庫還原:
docker run -ti --rm -v /data/database:/var/lib/mysql migrate-tool up head

 

7、
對比一下配置文件:

cd harbor/Deploy/

diff harbor.cfg /tmp/harbor/Deploy/harbor.cfg

diff docker-compose.yaml /tmp/harbor/Deploy/docker-compose.yaml

若是修改了端口 必須更新 cd harbor/Deploy/config/nginx/nginx.conf 裏面的端口

 

8、
執行 ./prepare 生成新的配置文件

cd /harbor/Deploy/

./prepare

 

9、
最後build 新的鏡像,啓動容器

cd /harbor/Deploy/

docker-compose up --build -d

 

10、登錄 WEB UI 檢查是否OK

相關文章
相關標籤/搜索