Docker-harbor私有倉庫部署與管理方式
1、什么是Harbor
Harbor 是 VMware 公司開源的企業(yè)級 Docker Registry 項(xiàng)目,其目標(biāo)是幫助用戶迅速搭建一個(gè)企業(yè)級的 Docker Registry 服務(wù)。
Harbor以 Docker 公司開源的 Registry 為基礎(chǔ),提供了圖形管理 UI 、基于角色的訪問控制(Role Based AccessControl) 、AD/LDAP 集成、以及審計(jì)日志(Auditlogging) 等企業(yè)用戶需求的功能,同時(shí)還原生支持中文。
Harbor 的每個(gè)組件都是以 Docker 容器的形式構(gòu)建的,使用 docker-compose 來對它進(jìn)行部署。用于部署 Harbor 的 docker-compose 模板位于 harbor/docker-compose.yml。
2、Harbor的特性
- 基于角色控制:用戶和倉庫都是基于項(xiàng)目進(jìn)行組織的,而用戶在項(xiàng)目中可以擁有不同的權(quán)限。
- 基于鏡像的復(fù)制策略:鏡像可以在多個(gè)Harbor實(shí)例之間進(jìn)行復(fù)制(同步)。
- 支持 LDAP/AD:Harbor 可以集成企業(yè)內(nèi)部已有的 AD/LDAP(類似數(shù)據(jù)庫的一張表),用于對已經(jīng)存在的用戶認(rèn)證和管理。
- 鏡像刪除和垃圾回收:鏡像可以被刪除,也可以回收鏡像占用的空間。
- 圖形化用戶界面:用戶可以通過瀏覽器來瀏覽,搜索鏡像倉庫以及對項(xiàng)目進(jìn)行管理。
- 審計(jì)管理:所有針對鏡像倉庫的操作都可以被記錄追溯,用于審計(jì)管理。
- 支持 RESTful API:RESTful API 提供給管理員對于 Harbor 更多的操控, 使得與其它管理軟件集成變得更容易。
- Harbor和docker registry的關(guān)系:Harbor實(shí)質(zhì)上是對docker registry做了封裝,擴(kuò)展了自己的業(yè)務(wù)模板。
3、Harbor的構(gòu)成
Harbor 在架構(gòu)上主要有 Proxy、Registry、Core services、Database(Harbor-db)、Log collector(Harbor-log)、Job services 六個(gè)組件。
- Proxy: 是一個(gè) nginx 的前端代理,Harbor 的 Registry、UI、Token 服務(wù)等組件,都處在 nginx 反向代理后邊。 該代理將來自瀏覽器、docker clients 的請求轉(zhuǎn)發(fā)到后端不同的服務(wù)上。
- Registry: 負(fù)責(zé)儲(chǔ)存 Docker 鏡像,并處理 Docker push/pull 命令。由于要對用戶進(jìn)行訪問控制,即不同用戶對 Docker 鏡像 有不同的讀寫權(quán)限,Registry 會(huì)指向一個(gè) Token 服務(wù),強(qiáng)制用戶的每次 Docker pull/push 請求都要攜帶一個(gè)合法的 Token, Registry 會(huì)通過公鑰對 Token 進(jìn)行解密驗(yàn)證。
- Core services: Harbor的核心功能,主要提供以下3個(gè)服務(wù):
1、UI(harbor-ui): 提供圖形化界面,幫助用戶管理 Registry 上的鏡像(image), 并對用戶進(jìn)行授權(quán)。
2、WebHook:為了及時(shí)獲取Registry 上image 狀態(tài)變化的情況,在Registry 上配置 Webhook,把狀態(tài)變化傳遞給 UI 模塊。
3、Token 服務(wù):負(fù)責(zé)根據(jù)用戶權(quán)限給每個(gè) Docker push/pull 命令簽發(fā) Token。Docker 客戶端向 Registry 服務(wù)發(fā)起的請求, 如果不包含 Token,會(huì)被重定向到 Token 服務(wù),獲得 Token 后再重新向 Registry 進(jìn)行請求。
- Database(harbor-db):為core services提供數(shù)據(jù)庫服務(wù),負(fù)責(zé)儲(chǔ)存用戶權(quán)限、審計(jì)日志、Docker 鏡像分組信息等數(shù)據(jù)。
- Job services: 主要用于鏡像復(fù)制,本地鏡像可以被同步到遠(yuǎn)程 Harbor 實(shí)例上。
- Log collector(harbor-log): 負(fù)責(zé)收集其他
組件的日志到一個(gè)地方。
Harbor 的每個(gè)組件都是以 Docker 容器的形式構(gòu)建的,因此,使用 Docker Compose 來對它進(jìn)行部署。
總共分為7個(gè)容器運(yùn)行,通過在docker-compose.yml所在目錄中執(zhí)行 docker-compose ps 命令來查看, 名稱分別為:nginx、harbor-jobservice、harbor-ui、harbor-db、harbor-adminserver、registry、harbor-log。
其中 harbor-adminserver 主要是作為一個(gè)后端的配置數(shù)據(jù)管理,并沒有太多的其他功能。harbor-ui 所要操作的所有數(shù)據(jù)都通過 harbor-adminserver 這樣一個(gè)數(shù)據(jù)配置管理中心來完成。
4、Harbor 部署
(1)部署 Docker-Compose 服務(wù)
Docker-Compose一般在下載docker時(shí)已經(jīng)安裝,將他復(fù)制到/usr/local/bin/目錄即可使用 find / -name docker-compose cp /usr/libexec/docker/cli-plugins/docker-compose /usr/local/bin/ docker-compose -v #查看版本

(2)部署 Harbor 服務(wù)
cd /opt 上傳harbor壓縮包 tar xf harbor-offline-installer-v1.10.18.tgz #解壓 mv harbor /usr/local/ cd /usr/local cd harbor/ vim harbor.yml --5行--修改,設(shè)置為Harbor服務(wù)器的IP地址或者域名 hostname:20.0.0.10 --27行--指定管理員的初始密碼,默認(rèn)的用戶名/密碼是admin/Harbor12345 harbor_admin_password = Harbor12345 12-18行全部注釋
關(guān)于 Harbor.cfg 配置文件中有兩類參數(shù):所需參數(shù)和可選參數(shù)
1、所需參數(shù):這些參數(shù)需要在配置文件 Harbor.cfg 中設(shè)置。如果用戶更新它們并運(yùn)行 install.sh 腳本重新安裝 Harbor, 參數(shù)將生效。具體參數(shù)如下:
- hostname:用于訪問用戶界面和 register 服務(wù)。它應(yīng)該是目標(biāo)機(jī)器的 IP 地址或完全限定的域名(FQDN),例如 192.168.80.10 或 hub.kgc.cn。不要使用 localhost 或 127.0.0.1 為主機(jī)名。
- ui_url_protocol:(http 或 https,默認(rèn)為 http)用于訪問 UI 和令牌/通知服務(wù)的協(xié)議。如果公證處于啟用狀態(tài),則此參數(shù)必須為 https。
- max_job_workers:鏡像復(fù)制作業(yè)線程。
- db_password:用于db_auth 的MySQL數(shù)據(jù)庫root 用戶的密碼。
- customize_crt:該屬性可設(shè)置為打開或關(guān)閉,默認(rèn)打開。打開此屬性時(shí),準(zhǔn)備腳本創(chuàng)建私鑰和根證書,用于生成/驗(yàn)證注冊表令牌。當(dāng)由外部來源提供密鑰和根證書時(shí),將此屬性設(shè)置為 off。
- ssl_cert:SSL 證書的路徑,僅當(dāng)協(xié)議設(shè)置為 https 時(shí)才應(yīng)用。
- secretkey_path:用于在復(fù)制策略中加密或解密遠(yuǎn)程 register 密碼的密鑰路徑。
2、可選參數(shù):這些參數(shù)對于更新是可選的,即用戶可以將其保留為默認(rèn)值,并在啟動(dòng) Harbor 后在 Web UI 上進(jìn)行更新。如果進(jìn)入 Harbor.cfg,只會(huì)在第一次啟動(dòng) Harbor 時(shí)生效,隨后對這些參數(shù)的更新,Harbor.cfg 將被忽略。
注意:如果選擇通過 UI 設(shè)置這些參數(shù),請確保在啟動(dòng) Harbor 后立即執(zhí)行此操作。具體來說,必須在注冊或在 Harbor 中創(chuàng)建任何新用戶之前設(shè)置所需的 auth_mode。當(dāng)系統(tǒng)中有用戶時(shí)(除了默認(rèn)的 admin 用戶), auth_mode 不能被修改。 具體參數(shù)如下:
- Email:Harbor 需要該參數(shù)才能向用戶發(fā)送“密碼重置”電子郵件,并且只有在需要該功能時(shí)才啟用。請注意,在默認(rèn)情況下 SSL 連接時(shí)沒有啟用。如果 SMTP 服務(wù)器需要 SSL,但不支持 STARTTLS,那么應(yīng)該通過設(shè)置啟用 SSL email_ssl = TRUE。
- harbor_admin_password:管理員的初始密碼,只在 Harbor 第一次啟動(dòng)時(shí)生效。之后, 此設(shè)置將被忽略,并且應(yīng)在 UI 中設(shè)置管理員的密碼。請注意,默認(rèn)的用戶名/密碼是admin/Harbor12345。
- auth_mode:使用的認(rèn)證類型,默認(rèn)情況下,它是 db_auth,即憑據(jù)存儲(chǔ)在數(shù)據(jù)庫中。對于LDAP身份驗(yàn)證,請將其設(shè)置為 ldap_auth。
- self_registration:啟用/禁用用戶注冊功能。禁用時(shí),新用戶只能由 Admin 用戶創(chuàng)建,只有管理員用戶可以在 Harbor 中創(chuàng)建新用戶。注意:當(dāng) auth_mode 設(shè)置為 ldap_auth 時(shí),自注冊功能將始終處于禁用狀態(tài),并且該標(biāo)志被忽略。
- Token_expiration:由令牌服務(wù)創(chuàng)建的令牌的到期時(shí)間(分鐘),默認(rèn)為 30 分鐘。
- project_creation_restriction:用于控制哪些用戶有權(quán)創(chuàng)建項(xiàng)目的標(biāo)志。默認(rèn)情況下,每個(gè)人都可以創(chuàng)建一個(gè)項(xiàng)目。 如果將其值設(shè)置為“adminonly”,那么只有 admin 可以創(chuàng)建項(xiàng)目。
- verify_remote_cert:打開或關(guān)閉,默認(rèn)打開。此標(biāo)志決定了當(dāng)Harbor與遠(yuǎn)程 register 實(shí)例通信時(shí)是否驗(yàn)證 SSL/TLS 證書。 將此屬性設(shè)置為 off 將繞過 SSL/TLS 驗(yàn)證,這在遠(yuǎn)程實(shí)例具有自簽名或不可信證書時(shí)經(jīng)常使用。
另外,默認(rèn)情況下,Harbor 將鏡像存儲(chǔ)在本地文件系統(tǒng)上。在生產(chǎn)環(huán)境中,可以考慮 使用其他存儲(chǔ)后端而不是本地文件系統(tǒng),如 S3、Openstack Swif、Ceph 等對象存儲(chǔ)。但需要更新 common/templates/registry/config.yml 文件。
Harbor的默認(rèn)鏡像存儲(chǔ)路徑在 /data/registry 目錄下,映射到docker容器里面的 /storage 目錄下。
這個(gè)參數(shù)是在 docker-compose.yml 中指定的,在 docker-compose up -d 運(yùn)行之前修改。
如果希望將 Docker 鏡像存儲(chǔ)到其他的磁盤路徑,可以修改這個(gè)參數(shù)。



(3)啟動(dòng) Harbor
cd /usr/local/harbor/ ./install.sh



(4)創(chuàng)建一個(gè)新項(xiàng)目
(1)瀏覽器訪問:http://20.0.0.10 登錄 Harbor WEB UI 界面,默認(rèn)的管理員用戶名和密碼是 admin/Harbor12345
(2)輸入用戶名和密碼登錄界面后可以創(chuàng)建一個(gè)新項(xiàng)目。點(diǎn)擊“新建項(xiàng)目”按鈕創(chuàng)建兩個(gè)項(xiàng)目
(3)填寫項(xiàng)目名稱為“xy101”、“zx”,點(diǎn)擊“確定”按鈕,一個(gè)公開,一個(gè)私有,創(chuàng)建新項(xiàng)目訪問級別公開:項(xiàng)目中的鏡像所有人都能下載,未登錄倉庫的用戶都能下載




訪問級別私有:必須先登錄用戶,而且必須是項(xiàng)目的成員才能下載


(5)創(chuàng)建用戶
點(diǎn)擊“用戶管理”,點(diǎn)擊“創(chuàng)建用戶”;創(chuàng)建兩個(gè)用戶



將成員分別加入到項(xiàng)目中;如下圖所示
點(diǎn)擊項(xiàng)目,選擇scj項(xiàng)目,點(diǎn)擊成員,點(diǎn)擊+用戶,姓名zx,角色項(xiàng)目管理員,創(chuàng)建




zx101項(xiàng)目中也將這兩個(gè)用戶添加

(6)本地上傳鏡像
vim /etc/docker/daemon.json "insecure-registries": ["http://20.0.0.10"] systemctl reload docker docker info



docker login -u admin -p Harbor12345 http://20.0.0.10 #以admin用戶登錄倉庫;admin為管理員 docker tag centos:7 20.0.0.10/zx101/centos:zx #為鏡像添加標(biāo)簽 docker push 20.0.0.10/zx101/centos:zx #推送鏡像到倉庫 docker tag nginx:latest 20.0.0.10/zx101/nginx:zx docker push 20.0.0.10/zx101/nginx:zx





(7)從Harbor下載鏡像
添加一臺(tái)docker服務(wù)器20.0.0.20
修改其配置,,對接私有倉庫
vim /etc/docker/daemon.json
{
"insecure-registries": ["http://20.0.0.10"]
}
systemctl reload docker.service
docker pull 20.0.0.10/zx101/nginx:zx


如何從私有倉庫下載鏡像?
scj項(xiàng)目為私有倉庫,內(nèi)包含一個(gè)nginx鏡像


在20.0.0.20服務(wù)器登錄zx用戶 docker login -u zx -p Abc123456 http://20.0.0.10 docker pull 20.0.0.10/scj/nginx:scj #想下載私有倉庫的鏡像,必須先登錄項(xiàng)目中存在的用戶再進(jìn)行下載,若登錄項(xiàng)目中存在的用戶是無法下載的 退出用戶:docker logout http://20.0.0.10

為成員設(shè)置標(biāo)簽時(shí),維護(hù)人員具有下載刪除上傳權(quán)限,訪客只有下載權(quán)限
docker pull 時(shí),公開項(xiàng)目的鏡像可以被任意用戶拉取,私有項(xiàng)目的鏡像需要先用項(xiàng)目成員登錄倉庫才能拉取
docker push 時(shí) 需要先用具有上傳權(quán)限的項(xiàng)目成員登錄倉庫才能推送鏡像
5、鏡像同步
在20.0.0.20安裝部署Harbor
快速安裝
20.0.0.10
cd /opt scp harbor-offline-installer-v1.10.18.tgz 20.0.0.20:/opt cd /usr/local/bin/ scp docker-compose 20.0.0.20:`pwd`

20.0.0.20
docker-compose -v #查看docker-compose是否安裝 cd /opt tar xf harbor-offline-installer-v1.10.18.tgz mv harbor /usr/local/ cd /usr/local/harbor/ vim harbor.yml

修改兩臺(tái)服務(wù)器指定倉庫地址
20.0.0.20
vim /etc/docker/daemon.json
{
"insecure-registries": ["http://20.0.0.10","http://20.0.0.20"]
}
systemctl reload docker
docker info
./install.sh



20.0.0.10
vim /etc/docker/daemon.json
{
"insecure-registries": ["http://20.0.0.10","http://20.0.0.20"]
}
systemctl reload docker
docker info


登錄兩臺(tái)服務(wù)器的harbor


(1)定時(shí)拉取
20.0.0.10服務(wù)器是存在鏡像,20.0.0.20是空倉庫
20.0.0.10創(chuàng)建倉庫:點(diǎn)擊倉庫管理,點(diǎn)擊新建目標(biāo)



20.0.0.20創(chuàng)建倉庫:點(diǎn)擊倉庫管理,點(diǎn)擊新建目標(biāo)



20.0.0.20harbor(定時(shí)拉取)
點(diǎn)擊復(fù)制管理,點(diǎn)擊新建規(guī)則


等待一分鐘即可

(2)主動(dòng)推送
刪除20.0.0.20中添加的zx01規(guī)則,測試主動(dòng)推送
20.0.0.10harbor
點(diǎn)擊復(fù)制管理,點(diǎn)擊新建規(guī)則


20.0.0.10服務(wù)器中上傳鏡像進(jìn)行測試




6、管理harbor
查看harbor下容器狀態(tài)
20.0.0.10
cd /usr/local/harbor #必須在docker-compose.yml存在的目錄下執(zhí)行命令 docker-compose ps

若發(fā)現(xiàn)其中有的容器狀態(tài)不支持,顯示down,如何解決?
1、首先使用docker-compose restart重啟看是否能夠解決
2、若任然有組件不正常,先使用docker-compose down停止所有容器并刪除;再使用docker-compose up -d重新創(chuàng)建啟動(dòng)容器
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
yum下載rpm以及相關(guān)依賴的方式離線安裝docker
今天小編就為大家分享一篇關(guān)于yum下載rpm以及相關(guān)依賴的方式離線安裝docker,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12
MongoDB從入門到實(shí)戰(zhàn)之Docker快速安裝MongoDB的詳細(xì)過程
這篇文章主要介紹了MongoDB從入門到實(shí)戰(zhàn)之Docker快速安裝MongoDB的詳細(xì)過程,本文給大家分享詳細(xì)實(shí)戰(zhàn)教程,幫助大家快速把MongoDB環(huán)境搭建起來,感興趣的朋友一起看看吧2025-05-05
pod污點(diǎn)taint?與容忍度tolerations詳解
這篇文章主要為大家介紹了pod污點(diǎn)taint與容忍度tolerations示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
使用docker離線部署dify之docker鏡像問題及部署過程
這篇文章主要給大家介紹了關(guān)于使用docker離線部署dify之docker鏡像問題及部署過程,通過配置多個(gè)鏡像源解決了,此外還介紹了如何將Dify鏡像轉(zhuǎn)移到離線環(huán)境并啟動(dòng)服務(wù),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-04-04

