日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

win10安装dockerx docker的常见命令 可以子腾讯云上做做练习

發(fā)布時(shí)間:2023/12/3 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 win10安装dockerx docker的常见命令 可以子腾讯云上做做练习 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

參考資料

https://www.jianshu.com/p/e8427d12b3e0

?

?

?

?

百度搜索? docker hub? 可以查找? 你需要的鏡像

https://hub.docker.com/?utm_source=getting_started_guide&utm_medium=embedded_Windows&utm_campaign=find_whalesay

https://blog.csdn.net/zzq060143/article/details/91050272

?

1.docker的安裝

環(huán)境準(zhǔn)備

Docker for Windows是一個(gè)Docker Community Edition(CE)應(yīng)用程序。Docker for Windows安裝包包含了在Windows系統(tǒng)上運(yùn)行Docker所需的一切。如果你不想裝虛擬機(jī),想直接在你的Windows操作系統(tǒng)中安裝與學(xué)習(xí)使用docker,那么你首先得查看你的系統(tǒng)是否滿足Docker for Windows的安裝與使用要求。

  • Docker for Windows的當(dāng)前版本運(yùn)行在64位Windows 10 Pro,專業(yè)版、企業(yè)版和教育版(1607年紀(jì)念更新,版本14393或更高版本)上。Ps:家庭版是不行的,如果你是家庭版,那么一是升級(jí)到專業(yè)版,破解專業(yè)版推薦個(gè)地址:http://blog.csdn.net/SONGCHUNHONG/article/details/78006389?,二是安裝Docker Toolbox,自行網(wǎng)上百度http://blog.csdn.net/tina_ttl/article/details/51372604

  • 如果你滿足Docker for Windows的環(huán)境條件了,那么首先檢查電腦的虛擬化開啟了沒有:進(jìn)入任務(wù)管理器(ctrl+alt+delete),點(diǎn)擊性能->cpu ,查看虛擬化是否已啟用,如果虛擬化是已禁用,那么你需要重啟電腦進(jìn)入bios開啟虛擬化(我們的發(fā)的筆記本cpu都是支持虛擬化的,重啟時(shí)進(jìn)入bios按esc -> 再按f12 -> 去開啟虛擬化)

  • 開啟虛擬化重啟后,進(jìn)入任務(wù)管理器看虛擬化是否已啟用。

  • 然后再是進(jìn)入電腦的控制面板->程序->啟用或關(guān)閉Windows功能->把Hyper-v勾上,啟用后電腦會(huì)重啟,后面就可以下載并安裝Docker for Windows了。

  • 重啟電腦

  • 打開docker的官網(wǎng),點(diǎn)擊右上角的get started,進(jìn)入到docker的下載頁面

  • ?

    https://hub.docker.com/editions/community/docker-ce-desktop-windows/? ? 默認(rèn)為英文翻譯為中文

    下載下來900多兆吧

    接下來就是安裝? ? ?沒什么問題? ?需要注冊(cè)一下的
  • 下載完成后,就會(huì)進(jìn)入安裝流程,第一步會(huì)提示你是否創(chuàng)建桌面圖標(biāo),默認(rèn)是勾選的,點(diǎn)擊ok按鈕繼續(xù)。然后程序就開始解壓文件,開始安裝。

  • 安裝完成后,會(huì)提示你關(guān)閉安裝程序并注銷賬號(hào)。這里的注銷賬號(hào)指的是注銷當(dāng)前登陸的windows使用戶賬號(hào)。點(diǎn)擊開始菜單,再點(diǎn)擊出現(xiàn)的個(gè)人頭像圖標(biāo),選擇注銷。

  • 注銷后,重新登陸,就會(huì)彈出docker的啟動(dòng)程序,如果系統(tǒng)沒有啟動(dòng)hyper-v的話,會(huì)提示你啟動(dòng),點(diǎn)擊ok啟動(dòng)。這個(gè)時(shí)候系統(tǒng)可能會(huì)重啟安裝hyper-v。等它重啟完畢后,在桌面的右下角就能看到docker的圖標(biāo),說明docker開始運(yùn)行了。

  • 然后我們?cè)陂_始菜單上點(diǎn)右鍵,選擇powershell。

  • 打開powershell后,輸入命令:

    docker --version

    如果安裝正常的話,會(huì)顯示出docker的版本信息,如下面第一張圖中所示。然后執(zhí)行docker的測試程序:

    docker run hello-world

    如果安裝沒有出錯(cuò)的話,會(huì)出現(xiàn)第二張圖中的:

    hello from docker

    的內(nèi)容。

  • ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    下面的參見csdn博客

    https://blog.csdn.net/zzq060143/article/details/91050272

    ?

    WIN10中DOCKER的安裝與使用

    ?

    • WIN10中DOCKER的安裝與使用
      • 1.docker的安裝
        • 環(huán)境準(zhǔn)備
        • 下載安裝
      • 2.docker的入門
        • 開始使用
      • 3.docker的常用配置
        • 在PowerShell中設(shè)置 tab鍵自動(dòng)補(bǔ)全(其實(shí)用的都是cmd.exe)
        • Settings
      • 4.用Dockerfile定義一個(gè)鏡像
        • 新建目錄文件
        • 構(gòu)建鏡像
        • 停止容器運(yùn)行
      • 5.聯(lián)系Docker Hub的常用操作
        • 登錄到Docker Hub
        • push鏡像
      • 6.服務(wù)
        • 創(chuàng)建一個(gè)docker-compose.yml文件
        • 運(yùn)行新的負(fù)載均衡應(yīng)用程序
        • 更改應(yīng)用程序
        • 關(guān)閉應(yīng)用程序和群
      • 7.集群
        • 了解集群
        • 創(chuàng)建一個(gè)集群
        • 初始化群并添加節(jié)點(diǎn)
        • 在集群上部署應(yīng)用程序
      • 8.參考文檔

    ?

    這是之前寫的一個(gè)word文檔
    Author: liguo.wang
    Creation Date: 2017/12/12
    Last Updated: 2017/12/15
    Document Ref:
    Version: DRAFT 1A

    1.docker的安裝

    環(huán)境準(zhǔn)備

    Docker for Windows是一個(gè)Docker Community Edition(CE)應(yīng)用程序。Docker for Windows安裝包包含了在Windows系統(tǒng)上運(yùn)行Docker所需的一切。如果你不想裝虛擬機(jī),想直接在你的Windows操作系統(tǒng)中安裝與學(xué)習(xí)使用docker,那么你首先得查看你的系統(tǒng)是否滿足Docker for Windows的安裝與使用要求。

  • Docker for Windows的當(dāng)前版本運(yùn)行在64位Windows 10 Pro,專業(yè)版、企業(yè)版和教育版(1607年紀(jì)念更新,版本14393或更高版本)上。Ps:家庭版是不行的,如果你是家庭版,那么一是升級(jí)到專業(yè)版,破解專業(yè)版推薦個(gè)地址:http://blog.csdn.net/SONGCHUNHONG/article/details/78006389?,二是安裝Docker Toolbox,自行網(wǎng)上百度http://blog.csdn.net/tina_ttl/article/details/51372604

  • 如果你滿足Docker for Windows的環(huán)境條件了,那么首先檢查電腦的虛擬化開啟了沒有:進(jìn)入任務(wù)管理器(ctrl+alt+delete),點(diǎn)擊性能->cpu ,查看虛擬化是否已啟用,如果虛擬化是已禁用,那么你需要重啟電腦進(jìn)入bios開啟虛擬化(我們的發(fā)的筆記本cpu都是支持虛擬化的,重啟時(shí)進(jìn)入bios按esc -> 再按f12 -> 去開啟虛擬化)

  • 開啟虛擬化重啟后,進(jìn)入任務(wù)管理器看虛擬化是否已啟用。

  • 然后再是進(jìn)入電腦的控制面板->程序->啟用或關(guān)閉Windows功能->把Hyper-v勾上,啟用后電腦會(huì)重啟,后面就可以下載并安裝Docker for Windows了。

  • 下載安裝

  • 進(jìn)入網(wǎng)址https://docs.docker.com/docker-for-windows/install/#download-docker-for-windows?下載并安裝。我安裝的是穩(wěn)定版。安裝過程沒什么要注意的。

  • 啟動(dòng)以后會(huì)出現(xiàn)在桌面的右下角區(qū)域,鼠標(biāo)放上去以后顯示Docker is running表示啟動(dòng)成功,第一次安裝啟用好像是會(huì)彈出個(gè)Docker Cloud登錄界面,去注冊(cè)然后登錄,使用和git有點(diǎn)類似,可以pull圖像等等

  • 2.docker的入門

    開始使用

  • 檢查Docker,Compose和Machine的版本

  • 檢查版本信息,并確保docker命令正常工作


  • 運(yùn)行docker run hello-world以測試從Docker Hub中拉取圖像并啟動(dòng)容器

  • 使用命令docker run -it ubuntu bash運(yùn)行一個(gè)Ubuntu容器,我之前已經(jīng)拉取過這個(gè)容器了,大概是幾十兆吧,所以直接啟用了,輸入exit命令停止容器

  • 運(yùn)行命令docker run -d -p 80:80 –name webserver nginx 啟動(dòng)一個(gè)Dockerized webserver 會(huì)下載nginx容器圖像并啟動(dòng)它,然后再打開瀏覽器鍵入http://localhost

  • 運(yùn)行docker ps 命令,檢查容器的詳細(xì)信息

  • 停止或移除容器和圖像。如果你想停止網(wǎng)絡(luò)服務(wù)器,輸入:docker stop webserver然后重新啟動(dòng)docker start webserver。要使用單個(gè)命令停止并刪除正在運(yùn)行的容器,請(qǐng)鍵入: docker rm -f webserver。這將刪除容器,但不是 nginx圖像。您可以列出本地圖像docker images。你可能想要保留一些圖片,這樣你就不必再從Docker Hub中取出它們了。要?jiǎng)h除不再需要的圖像,請(qǐng)使用docker rmi后跟圖像ID或圖像名稱。例如docker rmi nginx

  • 3.docker的常用配置

    在PowerShell中設(shè)置 tab鍵自動(dòng)補(bǔ)全(其實(shí)用的都是cmd.exe)

  • 啟動(dòng)一個(gè)的PowerShell(即以管理員身份運(yùn)行)。搜索PowerShell,右鍵單擊,然后選擇以管理員身份運(yùn)行。在PowerShell提示符下鍵入:
    Set-ExecutionPolicy RemoteSigned
  • 檢查策略設(shè)置是否正確,運(yùn)行:get-executionpolicy
    應(yīng)該返回RemoteSigned。
  • 安裝posh-dockerPowerShell模塊以自動(dòng)完成Docker命令,鍵入:Install-Module posh-docker或者,要僅為當(dāng)前用戶安裝模塊,鍵入:
    Install-Module -Scope CurrentUser posh-docker
  • 安裝完成后,只能為當(dāng)前PowerShell啟用自動(dòng)完成功能,輸入:Import-Module posh-docker
  • 為了在所有PowerShell會(huì)話中保持Tab完成狀態(tài)$PROFILE,請(qǐng)?jiān)赑owerShell提示符處輸入:
  • if (-Not (Test-Path $PROFILE)) {New-Item $PROFILE –Type File –Force } Add-Content $PROFILE "`nImport-Module posh-docker"
    • 1
    • 2
    • 3
    • 4

    這將創(chuàng)建一個(gè)$PROFILE如果不存在,并將此行添加到文件中:
    Import-Module posh-docker
    要檢查文件是否已正確創(chuàng)建,或只需手動(dòng)編輯,請(qǐng)?jiān)赑owerShell中鍵入以下內(nèi)容:
    Notepad $PROFILE
    打開一個(gè)新的PowerShell會(huì)話。現(xiàn)在,當(dāng)你鍵入的前幾個(gè)字母后按Tab鍵,Docker命令(如開始,停止,運(yùn)行及其選項(xiàng))以及容器和映像名稱現(xiàn)在都應(yīng)該自動(dòng)完成。

    Settings

    找到右下角的docker圖標(biāo),右擊選擇settings進(jìn)去

  • General:這里是設(shè)置docker開機(jī)自啟,應(yīng)用程序啟動(dòng)時(shí)檢查更新,發(fā)布使用情況統(tǒng)計(jì)信息

  • Advanced:分配cpu數(shù)量與內(nèi)存量

  • Daemon:Docker for windows10 可以配置阿里云鏡像,到https://cr.console.aliyun.com/?注冊(cè)一個(gè)賬戶,登錄進(jìn)去后再列表選擇加速器,把你的專屬加速器地址復(fù)制粘貼到Daemon的Registry mirrors中

  • 4.用Dockerfile定義一個(gè)鏡像

    在過去,如果你要開始編寫一個(gè)Python應(yīng)用程序,你的第一步就是在你的機(jī)器上安裝一個(gè)Python運(yùn)行庫。但是,這會(huì)造成您的機(jī)器上的環(huán)境必須滿足一定條件以使您的應(yīng)用程序可以運(yùn)行。
    使用Docker,你可以將一個(gè)可移植的Python運(yùn)行庫作為一個(gè)映像,不需要安裝。然后,您的構(gòu)建可以將基礎(chǔ)Python鏡像與應(yīng)用程序代碼一起包括在內(nèi),確保您的應(yīng)用程序,依賴項(xiàng)和運(yùn)行時(shí)都一起運(yùn)行。
    這些可移植的鏡像是由一個(gè)叫做Dockerfile的東西來定義的

    新建目錄文件

    創(chuàng)建一個(gè)空目錄,我取名叫docker,然后分別在里面新建三個(gè)文件:Dockerfile,app.py,requirements.txt

    三個(gè)文件中的內(nèi)容分別設(shè)計(jì)為:

    1.Dockerfile: # Use an official Python runtime as a parent image FROM python:2.7-slim# Set the working directory to /app WORKDIR /app# Copy the current directory contents into the container at /app ADD . /app# Install any needed packages specified in requirements.txt RUN pip install --trusted-host pypi.python.org -r requirements.txt# Make port 80 available to the world outside this container EXPOSE 80# Define environment variable ENV NAME World# Run app.py when the container launches CMD ["python", "app.py"]2.app.py: from flask import Flask from redis import Redis, RedisError import os import socket# Connect to Redis redis = Redis(host="redis", db=0, socket_connect_timeout=2, socket_timeout=2)app = Flask(__name__)@app.route("/") def hello():try:visits = redis.incr("counter")except RedisError:visits = "<i>cannot connect to Redis, counter disabled</i>"html = "<h3>Hello {name}!</h3>" \"<b>Hostname:</b> {hostname}<br/>" \"<b>Visits:</b> {visits}"return html.format(name=os.getenv("NAME", "world"), hostname=socket.gethostname(), visits=visits)if __name__ == "__main__":app.run(host='0.0.0.0', port=80)3. requirements.txt: Flask Redis
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51

    構(gòu)建鏡像

    在docker目錄下打開cmd.exe運(yùn)行命令(確保能夠找到Dockerfile文件,鏡像取名叫friendlyhello):
    docker build -t friendlyhello .
    ps:千萬不要落了上面那行后面的那個(gè)點(diǎn),曾經(jīng)入過坑的。。命令包括后面的那個(gè)點(diǎn)

    然后再執(zhí)行命令:
    docker images

    運(yùn)行鏡像程序:
    docker run -p 4000:80 friendlyhello

    可以看到Python正在為應(yīng)用程序提供消息的http://0.0.0.0:80。但是,這個(gè)消息來自容器內(nèi)部,它不知道我們將該容器的端口80映射到4000,從而打開URL:?http://localhost:4000

    停止容器運(yùn)行

    首先在接著上面的操作步驟后按下ctrl+c在終端退出,這并不意味著鏡像停止運(yùn)行了
    鍵入docker container ls 列出正在運(yùn)行的容器

    運(yùn)行命令:
    docker container stop <Container NAME or ID>
    停止容器。否則,在下一步中重新運(yùn)行容器時(shí),將會(huì)收到錯(cuò)誤響應(yīng)。

    5.聯(lián)系Docker Hub的常用操作

    登錄到Docker Hub

    前面已經(jīng)說過了,docker和git的操作有類似之處,所以docker也
    有遠(yuǎn)程倉庫,如果前面已經(jīng)注冊(cè)過并登錄了docker cloud,那么
    訪問網(wǎng)址:https://hub.docker.com?在里面創(chuàng)建存儲(chǔ)庫,否則先
    注冊(cè)吧。

    push鏡像

    前面在本地創(chuàng)建了一個(gè)friendlyhello的鏡像,現(xiàn)在要把它push到
    自己的docker hub的存儲(chǔ)庫中去,首先:
    1. 登錄docker hub (我已經(jīng)登錄過了。。再登錄一次吧)

    2. 標(biāo)記鏡像:
    把鏡像放入wangliguo存儲(chǔ)庫并標(biāo)記為test

    3. 查看鏡像:

    4. 發(fā)布鏡像(推送鏡像)

    5. Docker Hub上查看鏡像:

    6. 從遠(yuǎn)程存儲(chǔ)庫中提取并運(yùn)行鏡像:現(xiàn)在當(dāng)遠(yuǎn)程存儲(chǔ)庫有了鏡像后,就可以從遠(yuǎn)程存儲(chǔ)庫提取并運(yùn)行了

    6.服務(wù)

    在分布式應(yīng)用程序中,應(yīng)用程序的不同部分被稱為“服務(wù)”。例如,想象一個(gè)視頻共享站點(diǎn),它可能包括用于將應(yīng)用程序數(shù)據(jù)存儲(chǔ)在數(shù)據(jù)庫中的服務(wù),用于用戶上傳東西的視頻轉(zhuǎn)碼服務(wù),為前端服務(wù)等等。
    服務(wù)實(shí)際上只是“生產(chǎn)中的容器”。服務(wù)只運(yùn)行一個(gè)鏡像,但它編碼鏡像運(yùn)行的方式 - 應(yīng)該使用哪個(gè)端口,容器應(yīng)該運(yùn)行多少個(gè)副本,以便服務(wù)具有所需的容量,以及等等。縮放服務(wù)會(huì)更改運(yùn)行該軟件的容器實(shí)例的數(shù)量,從而為流程中的服務(wù)分配更多的計(jì)算資源。
    使用Docker平臺(tái)定義,運(yùn)行和擴(kuò)展服務(wù)非常簡單 - 只需編寫一個(gè)docker-compose.yml文件即可。

    創(chuàng)建一個(gè)docker-compose.yml文件


    鍵入:

    version: "3" services:web:# replace username/repo:tag with your name and image detailsimage: 15433/wangliguo:testdeploy:replicas: 5resources:limits:cpus: "0.1"memory: 50Mrestart_policy:condition: on-failureports:- "80:80"networks:- webnet networks:webnet:
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    拉取的是上個(gè)步驟中的存儲(chǔ)庫的tag。
    運(yùn)行該鏡像的5個(gè)實(shí)例作為一個(gè)服務(wù)調(diào)用web,限制每個(gè)使用,最多10%的CPU(跨所有核心)和50MB的RAM。
    如果一個(gè)失敗,立即重新啟動(dòng)容器。
    將主機(jī)上的端口80映射到web端口80。
    指導(dǎo)web容器通過一個(gè)負(fù)載平衡的網(wǎng)絡(luò)共享80端口webnet。(在內(nèi)部,容器本身將web在臨時(shí)端口上發(fā)布到 端口80)。
    webnet使用默認(rèn)設(shè)置(這是一個(gè)負(fù)載平衡覆蓋網(wǎng)絡(luò))定義網(wǎng)絡(luò)。

    運(yùn)行新的負(fù)載均衡應(yīng)用程序

    先運(yùn)行命令:docker swarm init

    然后再運(yùn)行命令:docker stack deploy -c docker-compose.yml getstartedlab
    給它取名叫g(shù)etstartedlab

    服務(wù)堆棧在這臺(tái)主機(jī)上運(yùn)行了5個(gè)部署鏡像的容器實(shí)例
    運(yùn)行命令查看:docker service ls

    在服務(wù)中運(yùn)行的單個(gè)容器稱為任務(wù),可以看到上面有個(gè)getstartedlab_web的服務(wù)
    運(yùn)行命令docker service ps getstartedlab_web 查看此服務(wù)下的任務(wù):

    如果只列出系統(tǒng)中的所有容器,也會(huì)顯示任務(wù),但不會(huì)被服務(wù)過濾:
    運(yùn)行命令:docker container ls -q

    然后打開瀏覽器,鍵入http://localhost

    點(diǎn)擊刷新多次,可以發(fā)現(xiàn)Hostname的更改,以循環(huán)方式選擇5個(gè)任務(wù)中的一個(gè)來響應(yīng)。容器ID將與前一個(gè)命令(docker container ls -q)的輸出相匹配。

    更改應(yīng)用程序

    比如更改docker-compose.yml中的replicas值,保存更改并重新運(yùn)行docker stack deploy命令來更新應(yīng)用程序:

    運(yùn)行命令:
    docker stack deploy -c docker-compose.yml getstartedlab

    Docker會(huì)做一個(gè)就地更新,然后重新運(yùn)行docker container ls -q以查看重新配置的已部署實(shí)例

    可以看到之前是6個(gè),現(xiàn)在是7個(gè),剛好多了一個(gè)任務(wù)
    ps:電腦中還運(yùn)行這之前步驟中從docker hub中拉取并運(yùn)行著的那個(gè)任務(wù),所以會(huì)看到6個(gè)和7個(gè)

    關(guān)閉應(yīng)用程序和群

    關(guān)閉應(yīng)用程序docker stack rm getstartedlab

    關(guān)閉群docker swarm leave –force

    現(xiàn)在服務(wù)中的任務(wù)都關(guān)閉了以后再運(yùn)行命令:
    docker container ls -q

    這就是上面說的那個(gè)之前步驟中從docker hub中拉取并運(yùn)行著的那個(gè)任務(wù)

    7.集群

    了解集群

    swarm是運(yùn)行Docker并加入到一個(gè)集群中的一組機(jī)器。但是現(xiàn)在它們將由群集管理器在群集上執(zhí)行。群體中的機(jī)器可以是物理的或虛擬的。加入群體后,他們被稱為節(jié)點(diǎn)。
    Swarm管理人員可以使用多種策略來運(yùn)行容器,比如“最空的節(jié)點(diǎn)”(emptiest node) - 它使用容器填充最少使用的機(jī)器。或“全局”,這確保了每臺(tái)機(jī)器只能得到指定容器的一個(gè)實(shí)例。您可以指示swarm manager在Compose文件中使用這些策略。
    群體管理者是群體中唯一可以執(zhí)行你的命令的機(jī)器,或者授權(quán)其他機(jī)器作為工作者加入群體。工人提供能力,并沒有權(quán)力告訴任何其他機(jī)器可以做什么和不可以做什么。
    到目前為止,之前都是在本地機(jī)器上以單主機(jī)模式使用Docker。但是Docker也可以切換到群集模式,這就是使用群集的原因。啟用群模式使當(dāng)前機(jī)器成為群管理器。則Docker將運(yùn)行您正在管理的群集上執(zhí)行的命令,而不僅僅是在當(dāng)前的機(jī)器上。

    創(chuàng)建一個(gè)集群

    一個(gè)群由多個(gè)節(jié)點(diǎn)組成,可以是物理機(jī)或虛擬機(jī)。基本的概念很簡單:運(yùn)行docker swarm init啟用群模式,使當(dāng)前的機(jī)器成為群管理器,然后docker swarm join在其他機(jī)器上運(yùn)行 ,讓它們作為工人加入群體。下面將使用虛擬機(jī)快速創(chuàng)建一個(gè)雙機(jī)群集,并將其變成群集。
    步驟:
    1. 以管理員運(yùn)行cmd.exe 這里必須是管理員運(yùn)行,不然后續(xù)操作權(quán)限不夠

    2. 運(yùn)行docker swarm init啟用群模式,使當(dāng)前的機(jī)器成為群管理器,然后docker swarm join在其他機(jī)器上運(yùn)行 ,讓它們作為工人加入群體。
    3. 啟動(dòng)Hyper-V管理器
    點(diǎn)擊開始?windows管理工具?Hyper-V管理器

    4. 單擊右側(cè)菜單中的虛擬交換機(jī)管理器

    5. 單擊創(chuàng)建類型為外部網(wǎng)絡(luò)的虛擬交換機(jī),給它的名稱myswitch,并檢查框共享您的主機(jī)的活動(dòng)網(wǎng)絡(luò)適配器

    6. 使用節(jié)點(diǎn)管理工具創(chuàng)建幾個(gè)虛擬機(jī)docker-machine:
    docker-machine create -d hyperv –hyperv-virtual-switch “myswitch” myvm1
    docker-machine create -d hyperv –hyperv-virtual-switch “myswitch” myvm2

    之前我已經(jīng)創(chuàng)建過了,所以我現(xiàn)在再新建兩個(gè):myvm3 和 myvm4
    docker-machine create -d hyperv –hyperv-virtual-switch “myswitch” myvm3
    docker-machine create -d hyperv –hyperv-virtual-switch “myswitch” myvm4



    7. 現(xiàn)在創(chuàng)建了兩個(gè)虛擬機(jī),分別命名為myvm3和myvm4。使用命令
    docker-machine ls 列出機(jī)器并獲取其IP地址。

    初始化群并添加節(jié)點(diǎn)

  • 先使用命令docker-machine ssh myvm3

    然后讓myvm3 成為一個(gè)管理員:docker swarm init
    注意紅框中的內(nèi)容,這是后面的myvm4 加入集群要執(zhí)行的命令

    運(yùn)行命令:docker node ls

    可以看到myvm3 已經(jīng)成為管理員了

  • 以管理員身份再運(yùn)行一個(gè)cmd.exe.然后運(yùn)行命令:docker-machine ssh myvm4

    然后再運(yùn)行命令:(這就是上一頁中圖片里紅框中的內(nèi)容,下面的token是我這里的,正常運(yùn)行到這里的時(shí)候是去myvm3的docker swarm init命令中把紅框框位置里的命令復(fù)制粘貼過來執(zhí)行)

  • docker swarm join --token SWMTKN-1-0csyw4yz6uxob90h0b8ejoimimrgisiuy9t2ugm8c1mxfvxf99-7q7w5jw1mrjk1jlri2bcgqmu8 10.211.106.194:2377
    • 1


    然后再切換到myvm3 的cmd.exe中執(zhí)行命令:docker node ls

    可以看到,我們已經(jīng)創(chuàng)建了一個(gè)簡單的集群。、

    附離開群命令:docker swarm leave

    在集群上部署應(yīng)用程序

  • docker-machine為swarm管理器配置一個(gè)shell
    運(yùn)行命令:docker-machine env myvm3

    注意最后一行的內(nèi)容
    我這里是@FOR /f "tokens=*" %i IN ('docker-machine env myvm3') DO @%i
    復(fù)制粘貼運(yùn)行它

    再運(yùn)行docker-machine ls以驗(yàn)證它myvm3 是否為活動(dòng)機(jī)器

  • 在swarm管理器上部署應(yīng)用程序
    以部署我們之前docker-compose.yml服務(wù)為例

    首先在這個(gè)以管理員身份打開的cmd中進(jìn)入到docker-compose.yml文件的所在的目錄中去,我的因?yàn)樵贒/docker中,如果不過來,那么執(zhí)行命令:
    docker stack deploy -c docker-compose.yml getstartedlab會(huì)出現(xiàn):

    進(jìn)入目錄后執(zhí)行上面那條命令:

    再執(zhí)行命令docker stack ps getstartedlab 查看服務(wù)詳情:

    如果發(fā)現(xiàn)state存在shutdown的情況(也有可能出現(xiàn)你的圖片上的實(shí)例數(shù)量大于你在服務(wù)文件中定義的數(shù)量的情況,這都是我爬過的坑,現(xiàn)在我這里定義的是6,圖片上也是6,),那應(yīng)該是你在之前服務(wù)哪一章運(yùn)行過命令:
    docker stack deploy -c docker-compose.yml getstartedlab 而沒有把getstartedlab移除掉
    這時(shí)應(yīng)該執(zhí)行命令:docker stack rm getstartedlab 把getstartedlab移除掉
    Ps:我是d,c盤都執(zhí)行了這個(gè)命令,因?yàn)橹斑\(yùn)行docker stack deploy -c docker-compose.yml getstartedlab命令是在d盤的時(shí)候
    然后重新運(yùn)行:docker stack deploy -c docker-compose.yml getstartedlab 和
    docker stack ps getstartedlab 就好了

  • 瀏覽器訪問集群的網(wǎng)址:
    如圖紅框框所示,瀏覽器上訪問其中的任何一個(gè),然后刷新,將看到6個(gè)可能的容器ID,它們都是隨機(jī)循環(huán)的,展示了負(fù)載平衡

  • 其他的一些命令:
  • 比如說如果修改了docker-compose.yml文件后,執(zhí)行命令: docker stack deploy -c docker-compose.yml getstartedlab 再次運(yùn)行以部署這些更改即可 比如說前面提到的移除應(yīng)用程序:docker stack rm getstartedlab 離開群:docker swarm leave –force 重新啟動(dòng)已停止的虛擬機(jī),執(zhí)行: docker-machine start <machine-name>
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    8.參考文檔

    https://docs.docker.com/
    http://blog.csdn.net/tina_ttl/article/details/51372604
    http://blog.csdn.net/u011686226/article/details/53906976
    http://blog.csdn.net/heatdeath/article/details/70432417
    http://blog.csdn.net/fromsilence520/article/details/73480219

    轉(zhuǎn)自:https://blog.csdn.net/hunan961/article/details/79484098

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    ?

    總結(jié)

    以上是生活随笔為你收集整理的win10安装dockerx docker的常见命令 可以子腾讯云上做做练习的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。