Docker 系列四(自定義倉庫).

来源:https://www.cnblogs.com/jmcui/archive/2018/07/25/9362633.html
-Advertisement-
Play Games

一、Docker hub 交互 Docker hub 是 Docker 官方維護的一個公共倉庫,大部分需求都可以通過在 Docker hub 中直接下載鏡像來完成。接下來,來看一下怎麼與 Docker hub 進行交互,包括登陸登出以及將本地鏡像推送到 Docker hub 等... 註冊:http ...


一、Docker hub 交互

    Docker hub 是 Docker 官方維護的一個公共倉庫,大部分需求都可以通過在 Docker hub 中直接下載鏡像來完成。接下來,來看一下怎麼與 Docker hub 進行交互,包括登陸登出以及將本地鏡像推送到 Docker hub 等...

註冊https://hub.docker.com/ 註冊的時候需要FQ~~

登陸:docker login 

登出:docker logout

搜索鏡像

docker search [name] --filter=stars=30
                     --filter=stars=N (參數可以指定僅顯示收藏數量為 N 以上的鏡像)

拉取鏡像:docker pull [選項] [Docker Registry 地址[:埠號]/]倉庫名[:標簽]

推送鏡像

#1、打鏡像標簽(username 表示Docker賬號用戶名)
docker tag REPOSITORY[:tag] username/REPOSITORY[:tag]
docker tag myenv:1.0 jmcui/myenv:1.0

#2、推送到Docker hub
docker push username/REPOSITORY[:tag]
docker push jmcui/myenv:1.0

二、創建 Docker 私庫(基於HTTP)

    在企業中把內部的一些工具包放入 Nexus 中是比較常見的做法,最新版本 Nexus3.x 全面支持 Docker 的私有鏡像。所以使用 Nexus3.x 一個軟體來管理 Docker , Maven , Yum , PyPI 等是一個明智的選擇。

1、使用 Docker 安裝 Nexus

docker run -d --name nexus3 --restart=always -p 8081:8081 -p 8082:8082 -p 8083:8083 --mount src=nexus-data,target=/nexus-data sonatype/nexus3
## 8081:nexus3網頁端
## 8082:docker(hosted)私有倉庫,可以pull和push
## 8083:docker(proxy)代理遠程倉庫,只能pull 

2、登陸

    訪問 http:// ip地址:8081 預設賬號:admin,預設密碼:admin123

 3、創建私有倉庫

    頁面上方的齒輪按鈕 —> Repository —> Repositories —> Create repository —> 選擇 docker (hosted)

      還可以創建一個 docker (proxy) 類型的倉庫鏈接到 DockerHub 上。再創建一個 docker (group) 類型的倉庫把剛纔的 hosted 與 proxy 添加在一起。主機在訪問的時候預設下載私有倉庫中的鏡像,如果沒有將鏈接到 DockerHub 中下載並緩存到 Nexus 中。

4、配置支持 HTTP

    Docker 預設不允許非 HTTPS 方式推送鏡像。我們可以通過 Docker 的配置選項來取消這個限制,(Ubuntu 16.04+, Debian 8+, centos 7)在 /etc/docker/daemon.json 中寫入如下內容:

{
  "registry-mirrors": [
    "https://registry.docker-cn.com"
  ],
  "insecure-registries": [
    "xx.xx.xx.xx:8082"
  ]
}

     重啟 Docker :

$ sudo systemctl daemon-reload
$ sudo systemctl restart docker

5、驗證效果

#1、登陸
docker login xx.xx.xx.xx:8082
#2、私庫標簽
docker tag myenv:1.0  xx.xx.xx.xx:8082/myenv
#3、推送鏡像到私有倉庫
docker push xx.xx.xx.xx:8082/myenv
#4、查看私有倉庫鏡像,驗證是否推送成功
curl xx.xx.xx.xx:8082/v2/_catalog
#5、拉取私有倉庫鏡像
docker pull xx.xx.xx.xx:8082/myenv

三、私有倉庫高級配置(HTTPS 認證)

    下麵,我們將要搭建的私有倉庫地址為 docker.domain.com,使用 openssl 自行簽發 docker.domain.com 的站點 SSL 證書,並用 Docker Compose 搭建一個擁有許可權認證、TLS 的私有倉庫。

    由於是在 Centos 7 下玩的 Docker ,首先要解決 Docker Compose 安裝的問題。

1、安裝 python-pip

#1、檢查linux有沒有安裝python-pip包
 pip -V
#2、執行安裝 epel-release 包
 yum -y install epel-release
#3、執行安裝 python-pip 包
 yum install python-pip
#4、對安裝好的pip進行升級
 pip install --upgrade pip
#5、再次驗證pip是否安裝成功
 pip -V
#6、安裝Docker-Compose(失敗的話可重覆多次)
 pip --default-timeout=300 install -U docker-compose --ignore-installed requests
#7、檢查docker-compose 安裝
 docker-compose -version

 2、HTTPS 認證

    因為對 HTTPS 的那些證書認證什麼的,著實沒有什麼大的概念,就不在這裡大誇其辭了。國內各大雲服務商均提供了免費的站點證書,常見的做法是:申請個功能變數名稱,綁定伺服器IP,然後下載雲服務提供的證書,添加認證即可。

    這裡的做法是使用 openssl 自行簽發 docker.domain.com 的站點 SSL 證書,也是看著步驟,一步步傻瓜式操作下來的,就不獻醜了。具體步驟可以參考:https://yeasy.gitbooks.io/docker_practice/content/repository/registry_auth.html

    至於坑,那還是有的,比如上面的 Docker Compose 安裝就折騰了好久。另外需要註意的是,最後生成的文件都要放在 /etc/docker 相關目錄下,目錄結構如下:

 

參考資料:《Docker — 從入門到實踐》


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在IIS上部署web api 完成後,瀏覽時出現了“The compiler failed with error code -2146232576.”的錯誤(有時會出現這個情況)。主要是 我們在.Net Framework 下創建Web API的時候,選擇預設的模板後,VS在創建項目時會添加一些組件 ...
  • 實際開發中有很多項目需要引用第三方的dll或者資源文件,且文件比較多,在運行時這些文件需要被拷貝到BIN目錄。 使用VS自帶的"複製到輸出目錄",似然方便,但是比較不零活,經過多次摸索,終於有了一個很好的解決辦法。 將csproj中copy指令的用法如下: 1、記事本打開啟動項目的 csproj文件 ...
  • 線程概述 線程是一個獨立處理的執行路徑。每個線程都運行在一個操作系統進程中,這個進程是程式執行的獨立環境。在單線程中進程的獨立環境內只有一個線程運行,所以該線程具有獨立使用進程資源的權利。在多線程程式中,在進程中有多個線程運行,所以它們共用同一個執行環境。 基礎線程(thread) 使用Thread ...
  • 基於 Red Hat Enterprise Linux 7.5 或者 CentOS 7.4 基本概念 Linux最核心的一個概念就是:Linux裡面任何東西都可以被視為一個文件,包括系統本身(說到底Linux啟動不就是調用那些開機文件再連帶啟動其他的文件麽~~~) User:文件擁有者 Group: ...
  • 什麼是shell? shell是一個命令解釋器,它在操作系統的最外層,負責直接與用戶對話,把用戶的輸入解釋給操作系統,並處理各種各樣的操作系統的輸出結果,輸出到屏幕返回給用戶。這種對話方式可以是交互的方式(從鍵盤輸入命令,可以立即得到shell的回應),或非交互(執行腳本程式)的方式。下圖的黃色部分... ...
  • Linux幫助文檔 1、--help 一般是Linux命令自帶的幫助信息 如:ls --help 2、man man是linux提供的一個手冊,包含了絕大多數的命令、函數使用說明 該手冊分成許多章節(section),使用man時可以指定不同的章節來瀏覽。 例:man ls; man 2 print ...
  • linux的設計之處就是為了多用戶同時執行不同的任務,但是硬體資源是有限的,不能讓一個用戶無限制的上傳文件,如果不加以限制,那麼磁碟最終將會被充滿,對此我們應該使用uquota來加以限制。 1.quota分類 1.1 軟限制:當達到限制時,提示用戶,但任然允許用戶在限定的額度內使用磁碟 1.2 硬限 ...
  • nc     nc命名netcat,直譯為 網路貓 。在CentOS 7查看幫助的解釋如下所示: 翻譯過來就是可以連接和重定向Sockets。通過查詢其他資料,可以看到nc命令功能確實非常多,它可以打開TCP連接,發送UDP包,監聽TCP/UDP埠,進行埠掃描等等。 基本語法 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...