欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

輕松安裝docker并運(yùn)行docker swarm模式

 更新時(shí)間:2016年12月08日 13:57:49   作者:月冷X心寒  
這篇文章主要介紹了安裝docker并運(yùn)行docker swarm模式的相關(guān)知識,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友一起學(xué)習(xí)吧

概要

docker 1.12版本最大的改變在于集成了docker swarm,在docker engine下提供了 swarm 模式,這里主要說一下docker swarm。

docker engine本身只提供了容器技術(shù),沒有解決集群環(huán)境下的容器編排和通信。docker swarm是一個(gè)容器編排管理工具,docker-engine在1.12版本之后集成了docker swarm,不需要再單獨(dú)安裝。

docker swarm的功能,舉個(gè)例子,有3臺機(jī)器都安裝了docker環(huán)境,稱為3臺docker節(jié)點(diǎn)。那么如何管理這3臺docker節(jié)點(diǎn),并把容器以類似于負(fù)載均衡的模式分別部署到這3臺節(jié)點(diǎn)上,并讓這些分布在不同節(jié)點(diǎn)上的容器之間互相通信呢。這時(shí)候需要用到容器編排工具,常用的編排工具有Google開源的kubernetes、apache的mesos、docker公司的swarm。

kubernetes作為Google開源的工具,已經(jīng)在Google的生產(chǎn)環(huán)境運(yùn)行了多年,功能豐富并且穩(wěn)定可靠,目前有很多公司都在使用。docker在1.12版本之后內(nèi)置了swarm模式,把容器編排以核心組件的模式集成到了docker engine中,并借鑒了kubernetes的成功經(jīng)驗(yàn)。

安裝docker

以centos7為例,這里附上官網(wǎng)的安裝文檔,docker官網(wǎng)實(shí)在太慢了。
使用yum安裝

1.更新yum源,sudo yum update;、。

2.添加docker的yum倉庫

sudo tee /etc/yum.repos.d/docker.repo <<-'EOF'
[dockerrepo]
name=Docker Repository
baseurl=https://yum.dockerproject.org/repo/main/centos/7/
enabled=1
gpgcheck=1
gpgkey=https://yum.dockerproject.org/gpg
EOF

3.安裝docker-engine,sudo yum install docker-engine

4.啟動docker守護(hù)進(jìn)程,sudo systemctl start docker
docker的安裝到這里就結(jié)束了,下邊說一下在公司內(nèi)網(wǎng)環(huán)境通過代理安裝docker需要注意的問題。

1.首先讓機(jī)器能通過代理上網(wǎng)

修改/etc/profile,增加export http_proxy=代理用戶名:密碼@代理地址:端口

使修改生效,source /etc/profile

2.配置yum使用代理

vim /etc/yum.conf 增加proxy=http://代理用戶名:密碼@代理地址:端口

經(jīng)過這兩步之后,就可以在內(nèi)網(wǎng)通過代理安裝docker了。

配置docker

打開docker遠(yuǎn)程管理端口2375,并配置docker hub國內(nèi)倉庫。

1.新建docker配置文件

vim /etc/sysconfig/docker

增加

DOCKER_OPTS="-H unix:///var/run/docker.sock -H 0.0.0.0:2375 --registry-mirror=國內(nèi)倉庫地址"

如果需要通過代理訪問還需要增加

HTTP_PROXY=http://代理用戶名:密碼@代理地址:端口

2.啟動docker守護(hù)進(jìn)程時(shí)加載配置文件

vim /lib/systemd/system/docker.servic

修改ExecStart配置為

ExecStart=/usr/bin/dockerd $DOCKER_OPTS

在[Service]中增加配置文件路徑的配置

EnvironmentFile=-/etc/sysconfig/docker

把配置文件加載路徑指定到第一步創(chuàng)建的配置文件/etc/sysconfig/docker

3.重啟docker守護(hù)進(jìn)程

sudo systemctl stop docker
sudo systemctl start docker

4.檢查配置是否生效

ps -ef|grep docker

如果配置生效,會在dockerd進(jìn)程后邊加上剛才配置的參數(shù)。

啟動swarm模式

只需要在一個(gè)docker節(jié)點(diǎn)上初始化swarm集群, 其他節(jié)點(diǎn)加入這個(gè)集群就行了。

選擇一臺docker節(jié)點(diǎn)作為swarm模式的leader,運(yùn)行

docker swarm init --advertise-addr 主機(jī)ip

按照提示信息在其他節(jié)點(diǎn)上執(zhí)行命令加入swarm集群

在leader節(jié)點(diǎn)上執(zhí)行docker node ls 查看節(jié)點(diǎn)信息

創(chuàng)建集群網(wǎng)絡(luò)

1.在swarm集群中的任意一個(gè)節(jié)點(diǎn)上運(yùn)行

docker network ls 查看當(dāng)前網(wǎng)絡(luò)狀況

scope為local的網(wǎng)絡(luò)只能作用于本機(jī),下邊創(chuàng)建swarm集群使用的網(wǎng)絡(luò)。

2.運(yùn)行 docker network create --driver overlay my-network

創(chuàng)建一個(gè)名為my-network的集群網(wǎng)絡(luò)

再次運(yùn)行 docker network ls,可以看到剛才創(chuàng)建的my-network ,scope為swarm,這個(gè)網(wǎng)絡(luò)可以用于swarm模式,并讓多個(gè)節(jié)點(diǎn)上的容器可以互通。

在swarm中創(chuàng)建service時(shí)可以通過 --network 網(wǎng)絡(luò)名稱 指定使用的網(wǎng)絡(luò)。多個(gè)service如果使用同一個(gè)scope為swarm的network,可以通過service的名稱互相通信。

docker swarm簡單使用

下邊簡單介紹docker swarm的使用,有興趣的可以查看docker官方文檔進(jìn)行深入了解。

下邊的命令全部是在swarm的leader節(jié)點(diǎn)運(yùn)行!!

docker service create --replicas 1 --name tomcat --publish 9090:8080 tomcat:latest

這里創(chuàng)建了一個(gè)名為tomcat 的service,swarm把容器封裝為service,類似于kubernates中的pod,一個(gè)service是一個(gè)可供swarm調(diào)度的容器組合。

這里的--replicas 1指定了service的副本數(shù)。

--publish 9090:8080把容器中的8080端口發(fā)布到宿主機(jī)的9090端口

運(yùn)行 docker service ls 查看當(dāng)前的服務(wù)列表,可以看到有一個(gè)名為tomcat的服務(wù)。

運(yùn)行 docker service ps tomcat 可以看到tomcat服務(wù)運(yùn)行在哪個(gè)swarm節(jié)點(diǎn),以及當(dāng)前運(yùn)行的狀態(tài)。

切換到tomcat服務(wù)運(yùn)行的節(jié)點(diǎn),運(yùn)行 docker ps 可以看到容器的ID,以及端口映射的情況。

運(yùn)行 docker logs -f 容器ID 查看tomcat運(yùn)行日志。

tomcat啟動成功后,可以在瀏覽器中訪問tomcat主頁,地址是docker節(jié)點(diǎn)的ip(隨便哪一個(gè)節(jié)點(diǎn)都可以),端口是9090,是在創(chuàng)建服務(wù)時(shí)指定的publish。

上邊已經(jīng)成功運(yùn)行了一個(gè)tomcat服務(wù),這里對這個(gè)服務(wù)進(jìn)行擴(kuò)展部署。

運(yùn)行 docker service scale tomcat=2 把tomcat服務(wù)擴(kuò)展為兩個(gè)實(shí)例。

運(yùn)行 docker service ls 可以看到tomcat服務(wù)的replicas變成了1/2,第二個(gè)實(shí)例啟動成功之后會變?yōu)?/2。

運(yùn)行 docker service ps tomcat 查看兩個(gè)tomcat服務(wù)實(shí)例運(yùn)行在哪個(gè)docker節(jié)點(diǎn),以及運(yùn)行狀態(tài)。

swarm會自動在兩個(gè)service中做負(fù)載均衡

swarm還有一些其他的命令,比如 docker service rm service名稱 刪除指定service,以及灰度發(fā)布等,具體使用請參照官方文檔,這里不再細(xì)說。

swarm模式下需要注意的問題

swarm只會在docker節(jié)點(diǎn)之間調(diào)度容器,不會調(diào)度容器使用的掛載卷volume。在用swarm部署數(shù)據(jù)庫的容器時(shí),需要注意數(shù)據(jù)文件的問題?;蛘呒虞d了外部配置文件的容器,也需要注意配置文件的問題。
一種簡單的解決方式,是讓這些容器每次都被調(diào)度到相同的docker節(jié)點(diǎn)上。需要在創(chuàng)建service時(shí)指定--constraint 參數(shù),比如 --constraint 'node.hostname==myhost' ,這樣創(chuàng)建的service只會被調(diào)度到主機(jī)名為myhost的docker節(jié)點(diǎn)。
另一種解決方式,使用docker volume插件,比如flocker。flocker可以在容器調(diào)度的時(shí)候,連同volume一起調(diào)度,這里不再細(xì)說,可以參照flocker的官網(wǎng)文檔。

最后

這里只是對docker的安裝配置以及docker swarm的使用做了簡單介紹,想要有更深入的了解,請參照官方文檔,官方文檔是學(xué)習(xí)的最好途徑。docker只是微服務(wù)架構(gòu)的開篇,想要實(shí)踐微服務(wù),docker必不可少。

后續(xù)會陸續(xù)推出基于docker部署的微服務(wù)架構(gòu),使用spring cloud做微服務(wù)解決方案,基于docker的mysql和mongodb的部署,基于docker的rabbitmq和activemq消息中間件的部署,以及基于docker部署的kafka、elk日志收集統(tǒng)計(jì)等。

以上所述是小編給大家介紹的輕松安裝docker并運(yùn)行docker swarm模式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Docker 容器日志查看和清理的實(shí)現(xiàn)步驟

    Docker 容器日志查看和清理的實(shí)現(xiàn)步驟

    在處理Docker容器的過程中,經(jīng)常需要查看容器的日志輸出來排查問題或者進(jìn)行系統(tǒng)監(jiān)控,本文主要介紹了Docker容器日志查看和清理的實(shí)現(xiàn)步驟,感興趣的可以了解一下
    2023-11-11
  • 什么是docker Docker入門教程第一篇

    什么是docker Docker入門教程第一篇

    什么是docker?這篇文章主要為大家分享了Docker簡介與入門教程第一篇,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Docker基礎(chǔ)知識之Linux namespace圖文詳解

    Docker基礎(chǔ)知識之Linux namespace圖文詳解

    這篇文章主要給大家介紹了關(guān)于Docker基礎(chǔ)知識之Linux namespace的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • 使用docker部署hadoop集群的詳細(xì)教程

    使用docker部署hadoop集群的詳細(xì)教程

    這篇文章主要介紹了使用docker部署hadoop集群的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值需要的朋友可以參考下
    2020-09-09
  • Docker安裝MySQL和Redis的方法步驟

    Docker安裝MySQL和Redis的方法步驟

    這篇文章主要介紹了Docker安裝MySQL和Redis的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • docker之MySQL同步數(shù)據(jù)的實(shí)現(xiàn)

    docker之MySQL同步數(shù)據(jù)的實(shí)現(xiàn)

    本文主要介紹了docker之MySQL同步數(shù)據(jù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Docker?安裝啟動Jenkins的方法(docker-compose)

    Docker?安裝啟動Jenkins的方法(docker-compose)

    這篇文章主要介紹了Docker?安裝啟動?Jenkins(docker-compose)的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • Docker NFS volume創(chuàng)建與使用方式

    Docker NFS volume創(chuàng)建與使用方式

    這篇文章主要介紹了Docker NFS volume創(chuàng)建與使用方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • SpringCloud與Docker的集成原理解析

    SpringCloud與Docker的集成原理解析

    Docker的核心原理是通過將應(yīng)用程序及其所有依賴項(xiàng)封裝到獨(dú)立的容器中,實(shí)現(xiàn)了跨平臺、一致性和可移植性,這篇文章主要介紹了SpringCloud-Docker原理解析,需要的朋友可以參考下
    2024-02-02
  • Docker部署SpringBoot應(yīng)用的實(shí)現(xiàn)步驟

    Docker部署SpringBoot應(yīng)用的實(shí)現(xiàn)步驟

    本文主要介紹了Docker部署SpringBoot應(yīng)用,Docker可以巧妙的解決函數(shù)庫、依賴沖突問題,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-11-11

最新評論