docker安裝卸載以及使用


# 1、卸載舊版的docker
yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
# 2、需要的安裝包
yum install -y yum-utils
# 3、設置鏡像的倉庫
yum-config-manager \
    --add-repo \
    https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/centos/docker-ce.repo

# 更新yum軟件包索引
yum makecache fast

# 4、安裝docker  docker-ce 社區版  ee 企業版
yum install -y docker-ce docker-ce-cli containerd.io

# 5、啟動docker
systemctl start docker

# 6、測試docker是否安裝成功
docker version

# 7、hello-world
docker run hello-world
# 8、查看一下下載的這個 hello-world 鏡像
[root@iZ2ze261ew0wzy5zenjh2xZ local]# docker images
REPOSITORY    TAG       IMAGE ID       CREATED       SIZE
hello-world   latest    d1165f221234   3 weeks ago   13.3kB

了解:卸載docker

# 先把docker服務停止
systemctl stop docker

# 1、卸載依賴
yum remove docker-ce docker-ce-cli containerd.io

# 2、刪除資源
rm -rf /var/lib/docker

# /var/lib/docker    docker的默認工作路徑!

鏡像命令

docker images 查看所有本地的主機上的鏡像

[root@iZ2ze261ew0wzy5zenjh2xZ docker]# docker images
REPOSITORY    TAG       IMAGE ID       CREATED       SIZE
hello-world   latest    d1165f221234   3 weeks ago   13.3kB

# 解釋
REPOSITORY	鏡像的倉庫源
TAG			鏡像的標簽
IMAGE ID	鏡像的ID
CREATED		鏡像的創建時間
SIZE		鏡像的大小

# 可選項
-a, --all		#列出所有鏡像
-q, --quiet		#只顯示鏡像的ID

docker search 搜索鏡像

[root@iZ2ze261ew0wzy5zenjh2xZ docker]# docker search mysql
NAME                              DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql                             MySQL is a widely used, open-source relation…   10676     [OK]       
mariadb                           MariaDB Server is a high performing open sou…   4010      [OK]       
mysql/mysql-server                Optimized MySQL Server Docker images. Create…   780                  [OK]


# 可選項,過濾
--filter=STARS=3000		#搜索出來的鏡像就是STARS大於3000的
[root@iZ2ze261ew0wzy5zenjh2xZ docker]# docker search mysql --filter=stars=3000
NAME      DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql     MySQL is a widely used, open-source relation…   10676     [OK]       
mariadb   MariaDB Server is a high performing open sou…   4010      [OK]       

docker pull 下載鏡像

# 下載鏡像	docker pull 鏡像名[:tag]
[root@iZ2ze261ew0wzy5zenjh2xZ docker]# docker pull mysql		#默認下載的是最新版的mysql

# 指定版本下載
[root@iZ2ze261ew0wzy5zenjh2xZ docker]# docker pull mysql:5.7	#下載的是5.7版的mysql

# 可以使用 docker images 查看下載的鏡像

docker rmi 刪除鏡像

[root@iZ2ze261ew0wzy5zenjh2xZ docker]# docker rmi -f d1165f221234


image-20210331153603176

容器命令

說明:有鏡像才可以創建容器,Linux,下載一個centos鏡像來測試學習

docker pull centos

新建容器並啟動

docker run [可選參數] image

# 參數說明
--name="Name"		容器名字 tomcat01  tomcat02,用來區分容器
-d					后台方式運行
-it					使用交互方式運行,進入容器查看內容
-p					指定容器的端口 -p 8080:8080
	-p ip:主機端口:容器端口
	-p 主機端口:容器端口(常用)
	-p 容器端口
-P					隨機指定端口

退出容器

exit # 直接容器停止並退出
ctrl + p + q #容器不停止退出   或者Ctrl+d

刪除容器

docker rm 容器id			# 刪除指定的容器,不能刪除正在運行的容器,如果要強制刪除 rm -f
docker rm -f $(docker ps -aq) 	# 刪除所有的容器
docker rm -a -q|xargs docker rm #刪除所有的容器

啟動和停止容器的操作

docker start 容器id		# 啟動容器
docker restart 容器id		# 重啟容器
docker stop 容器id		# 停止當前正在運行的容器
docker kill 容器id		# 強制停止當前容器

常用其他命令

后台啟動容器

# 命令 docker run -d 鏡像名
# docker run -d centos

# 問題 docker ps ,發現centos停止了

# 常見的坑,docker容器使用后台運行,就必須要有一個前台進程,docker發現沒有應用就會自動停止
# nginx,容器啟動后,發現自己沒喲提供服務,就會立刻停止。就是沒有程序了

查看日志

 docker logs -f -t --tail [number] 容器id,沒有日志,因為沒有操作
 # docker run -it centos /bin/bash ,	進入容器有操作就有日志
 或者
 # docker run -d centos /bin/bash -c "while true;do echo www;sleep 3;done" ,	
 每隔3秒寫一個www,產生日志,再用 
 # docker logs -tf --tail 10 容器ID
 查看產生的日志  --tail [參數]  用來顯示多少行數
 -tf		#顯示日志

image-20210401110328125

查看鏡像的元數據

[root@iZ2ze261ew0wzy5zenjh2xZ ~]# docker inspect 862ed1bc55a7
[
    {
        "Id": "862ed1bc55a7d026a17f0b1a4a261c0ff76ebb88e31ac619d0ee81e4d67232c7",
        "Created": "2021-04-01T02:41:22.562883069Z",
        "Path": "/bin/bash",
        "Args": [],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 55765,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2021-04-01T03:05:06.111738395Z",
            "FinishedAt": "2021-04-01T02:47:42.224360066Z"
        },
        "Image": "sha256:300e315adb2f96afe5f0b2780b87f28ae95231fe3bdd1e16b9ba606307728f55",
        "ResolvConfPath": "/var/lib/docker/containers/862ed1bc55a7d026a17f0b1a4a261c0ff76ebb88e31ac619d0ee81e4d67232c7/resolv.conf",
        "HostnamePath": "/var/lib/docker/containers/862ed1bc55a7d026a17f0b1a4a261c0ff76ebb88e31ac619d0ee81e4d67232c7/hostname",
        "HostsPath": "/var/lib/docker/containers/862ed1bc55a7d026a17f0b1a4a261c0ff76ebb88e31ac619d0ee81e4d67232c7/hosts",
        "LogPath": "/var/lib/docker/containers/862ed1bc55a7d026a17f0b1a4a261c0ff76ebb88e31ac619d0ee81e4d67232c7/862ed1bc55a7d026a17f0b1a4a261c0ff76ebb88e31ac619d0ee81e4d67232c7-json.log",
        "Name": "/epic_shannon",
        "RestartCount": 0,
        "Driver": "overlay2",
        "Platform": "linux",
        "MountLabel": "",
        "ProcessLabel": "",
        "AppArmorProfile": "",
        "ExecIDs": null,
        "HostConfig": {
            "Binds": null,
            "ContainerIDFile": "",
            "LogConfig": {
                "Type": "json-file",
                "Config": {}
            },
            "NetworkMode": "default",
            "PortBindings": {},
            "RestartPolicy": {
                "Name": "no",
                "MaximumRetryCount": 0
            },
            "AutoRemove": false,
            "VolumeDriver": "",
            "VolumesFrom": null,
            "CapAdd": null,
            "CapDrop": null,
            "CgroupnsMode": "host",
            "Dns": [],
            "DnsOptions": [],
            "DnsSearch": [],
            "ExtraHosts": null,
            "GroupAdd": null,
            "IpcMode": "private",
            "Cgroup": "",
            "Links": null,
            "OomScoreAdj": 0,
            "PidMode": "",
            "Privileged": false,
            "PublishAllPorts": false,
            "ReadonlyRootfs": false,
            "SecurityOpt": null,
            "UTSMode": "",
            "UsernsMode": "",
            "ShmSize": 67108864,
            "Runtime": "runc",
            "ConsoleSize": [
                0,
                0
            ],
            "Isolation": "",
            "CpuShares": 0,
            "Memory": 0,
            "NanoCpus": 0,
            "CgroupParent": "",
            "BlkioWeight": 0,
            "BlkioWeightDevice": [],
            "BlkioDeviceReadBps": null,
            "BlkioDeviceWriteBps": null,
            "BlkioDeviceReadIOps": null,
            "BlkioDeviceWriteIOps": null,
            "CpuPeriod": 0,
            "CpuQuota": 0,
            "CpuRealtimePeriod": 0,
            "CpuRealtimeRuntime": 0,
            "CpusetCpus": "",
            "CpusetMems": "",
            "Devices": [],
            "DeviceCgroupRules": null,
            "DeviceRequests": null,
            "KernelMemory": 0,
            "KernelMemoryTCP": 0,
            "MemoryReservation": 0,
            "MemorySwap": 0,
            "MemorySwappiness": null,
            "OomKillDisable": false,
            "PidsLimit": null,
            "Ulimits": null,
            "CpuCount": 0,
            "CpuPercent": 0,
            "IOMaximumIOps": 0,
            "IOMaximumBandwidth": 0,
            "MaskedPaths": [
                "/proc/asound",
                "/proc/acpi",
                "/proc/kcore",
                "/proc/keys",
                "/proc/latency_stats",
                "/proc/timer_list",
                "/proc/timer_stats",
                "/proc/sched_debug",
                "/proc/scsi",
                "/sys/firmware"
            ],
            "ReadonlyPaths": [
                "/proc/bus",
                "/proc/fs",
                "/proc/irq",
                "/proc/sys",
                "/proc/sysrq-trigger"
            ]
        },
        "GraphDriver": {
            "Data": {
                "LowerDir": "/var/lib/docker/overlay2/6b7891313697fd320e1355bb72bd9889ef263932149a823c6d79556debdb0fb7-init/diff:/var/lib/docker/overlay2/c1d31f0d19365fe68b75826b1f17fc0bb5eb9fc29fe886019023c65717b37b47/diff",
                "MergedDir": "/var/lib/docker/overlay2/6b7891313697fd320e1355bb72bd9889ef263932149a823c6d79556debdb0fb7/merged",
                "UpperDir": "/var/lib/docker/overlay2/6b7891313697fd320e1355bb72bd9889ef263932149a823c6d79556debdb0fb7/diff",
                "WorkDir": "/var/lib/docker/overlay2/6b7891313697fd320e1355bb72bd9889ef263932149a823c6d79556debdb0fb7/work"
            },
            "Name": "overlay2"
        },
        "Mounts": [],
        "Config": {
            "Hostname": "862ed1bc55a7",
            "Domainname": "",
            "User": "",
            "AttachStdin": true,
            "AttachStdout": true,
            "AttachStderr": true,
            "Tty": true,
            "OpenStdin": true,
            "StdinOnce": true,
            "Env": [
                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
                "/bin/bash"
            ],
            "Image": "centos",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": {
                "org.label-schema.build-date": "20201204",
                "org.label-schema.license": "GPLv2",
                "org.label-schema.name": "CentOS Base Image",
                "org.label-schema.schema-version": "1.0",
                "org.label-schema.vendor": "CentOS"
            }
        },
        "NetworkSettings": {
            "Bridge": "",
            "SandboxID": "f5e19523fa10dbe27f6ac6df65921b90261759af1d54658f673ba7d55cc9e6cf",
            "HairpinMode": false,
            "LinkLocalIPv6Address": "",
            "LinkLocalIPv6PrefixLen": 0,
            "Ports": {},
            "SandboxKey": "/var/run/docker/netns/f5e19523fa10",
            "SecondaryIPAddresses": null,
            "SecondaryIPv6Addresses": null,
            "EndpointID": "acb1d725b711d2d73432cb9b66c82b9216e434617d18bf4d7d1e901a73a28b95",
            "Gateway": "172.17.0.1",
            "GlobalIPv6Address": "",
            "GlobalIPv6PrefixLen": 0,
            "IPAddress": "172.17.0.2",
            "IPPrefixLen": 16,
            "IPv6Gateway": "",
            "MacAddress": "02:42:ac:11:00:02",
            "Networks": {
                "bridge": {
                    "IPAMConfig": null,
                    "Links": null,
                    "Aliases": null,
                    "NetworkID": "203a54de0f1ce79f9bc8159b3af851168210981fd8d286b123eb1def0b0d76bf",
                    "EndpointID": "acb1d725b711d2d73432cb9b66c82b9216e434617d18bf4d7d1e901a73a28b95",
                    "Gateway": "172.17.0.1",
                    "IPAddress": "172.17.0.2",
                    "IPPrefixLen": 16,
                    "IPv6Gateway": "",
                    "GlobalIPv6Address": "",
                    "GlobalIPv6PrefixLen": 0,
                    "MacAddress": "02:42:ac:11:00:02",
                    "DriverOpts": null
                }
            }
        }
    }
]

進入當前正在運行的容器

# docker exec -it 容器id /bin/bash
進入容器后,開啟一個新的終端,可以在里面操作
# docker attach 容器id /bin/bash
進入容器后,進到正在執行的終端,不會啟動新的終端

從容器內拷貝文件到主機上

# docker cp 容器id:/文件地址 /容器外要拷貝到的地址

image-20210401112502353

docker 安裝nginx

# 1、搜索鏡像 search 
# 2、下載鏡像 pull
# 3、運行測試
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker images
REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
hello-world   latest    d1165f221234   3 weeks ago    13.3kB
nginx         latest    f6d0b4767a6c   2 months ago   133MB
centos        latest    300e315adb2f   3 months ago   209MB

# -d 后台運行
# --name 給容器命名
# -p 宿主機端口,容器內部端口
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker run -d --name nginx01 -p 8081:80 nginx
46d7baf86853094fadd6fdb1a4ccb85fd9216277bebab9904abb3157b75df3f7
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker ps
CONTAINER ID   IMAGE     COMMAND                  CREATED          STATUS          PORTS                  NAMES
46d7baf86853   nginx     "/docker-entrypoint.…"   29 minutes ago   Up 24 minutes   0.0.0.0:8081->80/tcp   nginx01
862ed1bc55a7   centos    "/bin/bash"              4 hours ago      Up 4 hours                             epic_shannon

[root@iZ2ze261ew0wzy5zenjh2xZ /]# curl localhost:8081
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
    body {
        width: 35em;
        margin: 0 auto;
        font-family: Tahoma, Verdana, Arial, sans-serif;
    }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

docker安裝tomcat

# 官方使用--用來測試
docker run -it --rm tomcat:9.0
# 用完即刪

# 下載
docker pull tomcat		--默認最新版本
# 啟動運行
docker run -d -p 1433:8080 --name tomcat01 tomcat
# 進入容器
docker exec -it tomcat01 /bin/bash
# cd /usr/local/tomcat		把 webapps.list 下的文件拷貝到webapps下才能正確訪問到tomcat
# cp -r webapps.list/* webapps
# curl localhost:1433

image-20210401155119855

image-20210401155137743

image-20210401155222166

image-20210401155329845

docker 鏡像的特點

image-20210401172521039

commit

image-20210401172400690

容器數據卷

什么是容器數據卷

docker的理念回顧

將應用和環境打包成一個鏡像!

數據?如果數據都在容器中,那么我么容器刪除,數據就會丟失!需求:數據可以持久化

mysql,容器刪了!刪庫跑路! 需求:mysql數據可以存儲在本地!

容器之間可以有一個數據共享的技術!docker容器中產生的數據,同步到本地!

這就 是卷技術!目錄的掛載,將我們容器內的目錄,掛載到Linux上面!

image-20210402104358483

總結一句話:容器的持久化和同步操作!容器建也是可以數據共享的!

實戰:安裝mysql並掛載

image-20210402112820323

具名和匿名掛載

# 匿名掛載
-v 容器內路徑
-P 隨機指定宿主機端口和容器內端口映射
docker run -d -P --name nginx01 -v /etc/nginx nginx

#查看卷的所有情況
# docker volume ls
[root@iZ2ze261ew0wzy5zenjh2xZ data]# docker volume ls
DRIVER    VOLUME NAME
local     6c8d91314d0c23b08c6f6e8bd41bd1733fcfef904cb916c42c2d4fa7f4af2b6c

# 這里發現,這種就是匿名掛載,我們只在-v 只寫了容器內的路徑,沒有寫容器外的路徑!

# 具名掛載
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker run -d -P -v juming-nginx04:/etc/nginx --name nginx04 nginx
eb83e3e7b71c4ff21ee462aa23564d1ff1e799ee9bb60ec1974b113d3bf0ed84
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker volume ls
DRIVER    VOLUME NAME
local     2c425f8cd07e8435b03af6039b57dab0e86d7b2ba682d01d5d9f1710ceb1642c
local     6c8d91314d0c23b08c6f6e8bd41bd1733fcfef904cb916c42c2d4fa7f4af2b6c
local     juming-nginx04

# 通過 -v 卷名:容器內路徑
# 查看一下這個卷
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker volume inspect juming-nginx04
[
    {
        "CreatedAt": "2021-04-02T12:59:41+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/juming-nginx04/_data",
        "Name": "juming-nginx04",
        "Options": null,
        "Scope": "local"
    }
]

# 所有的docker容器內的卷,沒有指定目錄的情況下都在/var/lib/docker/volumes/xxxx/_data
我們通過具名掛載可以方便的找到我們的一個卷,大多數情況在使用的 ==具名掛載==

# 如何確定是具名掛載還是匿名掛載,還是指定路徑掛載!
-v 容器內路徑		#匿名掛載
-v 卷名:容器內路徑		#具名掛載
-v /宿主機路徑:/容器內路徑		# 指定路徑掛載

拓展
# 通過 -v 容器內路徑:ro  rw 改變讀寫權限
ro	readonly	# 只讀
rw	readwrite	# 可讀可寫

#一旦這個設置了容器權限,容器對我們掛載出來的內容就有限定了!
[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker run -d -P -v juming-nginx04:/etc/nginx:ro --name nginx04 nginx

[root@iZ2ze261ew0wzy5zenjh2xZ /]# docker run -d -P -v juming-nginx04:/etc/nginx:rw --name nginx04 nginx

# ro 只要看到ro就說明這個路徑只能通過宿主機來操作,容器內部是無法操作的!

ro 容器內部無法操作!!!

數據卷容器

[root@iZ2ze261ew0wzy5zenjh2xZ ~]# docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 mysql:5.7

# 創建一個容器-和mysql01公用一個數據卷(宿主機和mysql01和mysql02都可以同步數據)
[root@iZ2ze261ew0wzy5zenjh2xZ ~]# docker run -d -p 3311:3306 -e MYSQL_ROOT_PASSWORD=111111 --name mysql02 --volumes-from mysql01 mysql:5.7
6f72801eea425be5c51b8c47bbfedfd6d150ae104893ed681441be07f8f0f9a9
-----------------------------------------------------------------------------
mysql數據庫好像不太好使的樣子
多個MySQL實例共享數據卷,要看MySQL Server之間是怎么處理共享存儲上文件並發讀寫問題的。如果MySQL用的是文件鎖,數據卷需要支持文件鎖。
推薦的方式是每個MySQL實例獨占一個數據卷,采用主從復制或者多Master。

也就是,mysql數據文件不能同時被多個文件讀寫
-----------------------------------------------------------------------------
--volumes-from 實現兩個容器數據同步!

結論:

容器之間配置信息的傳遞,數據卷容器的生命周期一直持續到沒有容器使用為止。

但是一旦你持久化到了本地,這個時候,本地的數據是不會刪除的!

dockerfile

dockerfile是用來構建docker鏡像的文件!命令參數腳本!

構建步驟:

1、編寫一個dockerfile文件
2、docker build構建成為一個鏡像

3、docker run 運行鏡像

4、docker push 發布鏡像(dockerhub、阿里雲鏡像倉庫!)

dockerfile構建過程

基礎知識:

1、每個保留關鍵字(指令)都是必須是大寫字母

2、執行從上到下順序執行

3、# 表示注釋

4、每一個指令都會創建提交一個新的鏡像層,並提交!

image-20210402233649178

dockerfile是面向開發的,我們以后要發布項目,做鏡像,就需要編寫dockerfile文件,這個文件十分簡單

docker鏡像 逐漸成為企業交付的標准,必須要掌握!

dockerfile:構建文件,定義了一切的步驟,源代碼

dockerimages:通過dockerfile構建生成的鏡像,最終發布和運行的產品

docker容器:容器就是鏡像運行起來提供服務器

dockerfile的指令

FROM				# 基礎鏡像,一切從這開始構建
MAINTAINER			# 鏡像是誰寫的,姓名+郵箱
RUN					# 鏡像構建的時候要運行的命令
ADD					# 步驟,tomcat鏡像,這個tomcat壓縮包!添加內容
WORKDIR				# 鏡像的工作目錄
VOLUME				# 掛載的目錄
EXPOST				# 保留端口配置
CMD					# 指定這個容器啟動的時候要運行的命令
ENTRYPOINT			# 指定這個容器啟動的時候要運行的命令,可以追加命令
ONBUILD				# 當構建一個被繼承 dockerfile 這個時候就會運行ONBUILD 的指令,出發指令
COPY				# 類似ADD,將我們文件拷貝到鏡像中
ENV					# 構建的時候設置環境變量!
ENV MYPATH			# 指定當進入容器時所處的位置

image-20210403093548994

實戰測試

docker hub 中99%鏡像都是從這個基礎鏡像過來的FROM 的scratch,然后配置需要的軟件和配置來進行的構建

image-20210403093737506

創建一個自己的centos

# 1、編寫dockerfile的文件
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# cat dockerfile-centos 
FROM centos
MAINTAINER wuguofeng<123@qq.com>

ENV MYPATH /usr/local
WORKDIR $MYPATH

RUN yum -y install vim
RUN yum -y install net-tools

EXPOSE 80

RUN echo $MYPATH
RUN echo "-----end------"
CMD /bin/bash 


# 2、通過這個文件構建鏡像
# 命令 docker build -f dockerfile-centos -t textcentos:0.1 .
--注意后面的.點
# 3、測試運行
[root@iZ2ze261ew0wzy5zenjh2xZ ~]# docker run -it textcentos:0.1
[root@213e211b2acc local]# pwd
/usr/local
[root@213e211b2acc local]# ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 172.17.0.4  netmask 255.255.0.0  broadcast 172.17.255.255
        ether 02:42:ac:11:00:04  txqueuelen 0  (Ethernet)
        RX packets 13  bytes 1165 (1.1 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
        
[root@iZ2ze261ew0wzy5zenjh2xZ ~]# docker images
REPOSITORY   TAG       IMAGE ID       CREATED             SIZE
textcentos   0.1       9dfecdb872e1   About an hour ago   242MB
mysql        5.7       a70d36bc331a   2 months ago        449MB
nginx        latest    f6d0b4767a6c   2 months ago        133MB
centos       latest    300e315adb2f   3 months ago        209MB

 # 看看構建過程
[root@iZ2ze261ew0wzy5zenjh2xZ ~]# docker history 9dfecdb872e1
IMAGE          CREATED             CREATED BY                                      SIZE      COMMENT
9dfecdb872e1   About an hour ago   /bin/sh -c #(nop)  CMD ["/bin/sh" "-c" "/bin…   0B        
c37d66fb8239   About an hour ago   /bin/sh -c echo "-----end------"                0B        
39d281b56e62   About an hour ago   /bin/sh -c echo $MYPATH                         0B        
8fe1356f0df5   About an hour ago   /bin/sh -c #(nop)  EXPOSE 80                    0B        
323f59102150   About an hour ago   /bin/sh -c yum -y install net-tools             32.5MB    
80800f78e54a   2 hours ago         /bin/sh -c #(nop) WORKDIR /usr/local            0B        
a878a31893c0   2 hours ago         /bin/sh -c #(nop)  ENV MYPATH=/usr/local        0B        
d49d25fed779   2 hours ago         /bin/sh -c #(nop)  MAINTAINER wuguofeng         0B        
300e315adb2f   3 months ago        /bin/sh -c #(nop)  CMD ["/bin/bash"]            0B        
<missing>      3 months ago        /bin/sh -c #(nop)  LABEL org.label-schema.sc…   0B        
<missing>      3 months ago        /bin/sh -c #(nop) ADD file:bd7a2aed6ede423b7…   209MB     

CMD 和ENTRYPOINT的區別

CMD 		# 指定這個容器啟動的時候要運行的命令,只有最后一個會生效,可被替代
ENTRYPOINT	# 指定這個容器啟動的時候要運行的命令,可以追加命令

測試CMD

# 編寫cmd
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# vim dockerfile-entrypoint 
FROM centos
CMD ["ls","-a"]
# 構建鏡像
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# docker build -f dockerfile-entrypoint -t centos-entrypoint .
Sending build context to Docker daemon  3.072kB
Step 1/2 : FROM centos
 ---> 300e315adb2f
Step 2/2 : CMD ["ls","-a"]
 ---> Running in 17a8e6cc90db
Removing intermediate container 17a8e6cc90db
 ---> a99fd74544ec
Successfully built a99fd74544ec
Successfully tagged centos-entrypoint:latest
# run運行,發現我們的ls -a 命令生效
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# docker run a99fd74544ec
.
..
.dockerenv
bin
dev
etc
home
lib
lib64
lost+found
media
mnt
opt
proc
root
run
sbin
srv
sys
tmp
usr
var
# 想要追加一個命令 -l     也就是ls -al
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# docker run a99fd74544ec -l
docker: Error response from daemon: OCI runtime create failed: container_linux.go:367: starting container process caused: exec: "-l": executable file not found in $PATH: unknown.
# cmd的清理下 -l 替換了CMD["ls","-a"]命令,-l不是命令,所以報錯!

測試ENTRYPOINT

# 編寫ENTRYPOINT
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# vim dockerfile-entrypoint 
FROM centos
ENTRYPOINT ["ls","-a"]
# 構建鏡像
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# docker build -f dockerfile-entrypoint -t centos-l .
Sending build context to Docker daemon  3.072kB
Step 1/2 : FROM centos
 ---> 300e315adb2f
Step 2/2 : ENTRYPOINT ["ls","-a"]
 ---> Running in f1b9ebba1240
Removing intermediate container f1b9ebba1240
 ---> 6bb9564028ed
Successfully built 6bb9564028ed
Successfully tagged centos-l:latest
# run運行,發現我們的ls -a 命令生效
# 想要追加一個命令 -l     也就是ls -al
[root@iZ2ze261ew0wzy5zenjh2xZ dockerfile]# docker run 6bb9564028ed -l
total 0
drwxr-xr-x   1 root root   6 Apr  3 05:56 .
drwxr-xr-x   1 root root   6 Apr  3 05:56 ..
-rwxr-xr-x   1 root root   0 Apr  3 05:56 .dockerenv
lrwxrwxrwx   1 root root   7 Nov  3 15:22 bin -> usr/bin
drwxr-xr-x   5 root root 340 Apr  3 05:56 dev
drwxr-xr-x   1 root root  66 Apr  3 05:56 etc
drwxr-xr-x   2 root root   6 Nov  3 15:22 home
lrwxrwxrwx   1 root root   7 Nov  3 15:22 lib -> usr/lib
lrwxrwxrwx   1 root root   9 Nov  3 15:22 lib64 -> usr/lib64
drwx------   2 root root   6 Dec  4 17:37 lost+found
drwxr-xr-x   2 root root   6 Nov  3 15:22 media
drwxr-xr-x   2 root root   6 Nov  3 15:22 mnt
drwxr-xr-x   2 root root   6 Nov  3 15:22 opt
dr-xr-xr-x 124 root root   0 Apr  3 05:56 proc
dr-xr-x---   2 root root 162 Dec  4 17:37 root
drwxr-xr-x  11 root root 163 Dec  4 17:37 run
lrwxrwxrwx   1 root root   8 Nov  3 15:22 sbin -> usr/sbin
drwxr-xr-x   2 root root   6 Nov  3 15:22 srv
dr-xr-xr-x  13 root root   0 Apr  3 05:56 sys
drwxrwxrwt   7 root root 145 Dec  4 17:37 tmp
drwxr-xr-x  12 root root 144 Dec  4 17:37 usr
drwxr-xr-x  20 root root 262 Dec  4 17:37 var
# 發現我們的追加命令,是直接拼接在我們的ENTRYPOINT 命令后面的!

實戰:tomcat鏡像

1、准備鏡像文件 tomcat壓縮包,jdk的壓縮包!注意:要放在一個目錄下

image-20210403143055738

2、編寫dockerfile文件,官方命名 Dockerfile,build會自動尋找這個文件,就不需要-f指定了!

[root@iZ2ze261ew0wzy5zenjh2xZ home]# cat Dockerfile 
FROM centos
MAINTAINER wuguofeng

COPY readme.txt /usr/local/readme.txt

ADD jdk-8u221-linux-x64.tar.gz /usr/local
ADD apache-tomcat-9.0.34.tar.gz /usr/local


ENV MYPATH /usr/local
WORKDIR $MYPATH

ENV JAVA_HOME /usr/local/jdk1.8.0_221
ENV CLASSPATH $JAVA_HOME/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.34
ENV CATALINA_BASH /usr/local/apache-tomcat-9.0.34
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin

EXPOSE 8080

CMD /usr/local/apache-tomcat-9.0.34/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.34/logs/catalina.out

# 開始構建
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker build -t tomcatjiayou .
Sending build context to Docker daemon  413.4MB
Step 1/14 : FROM centos
 ---> 300e315adb2f
Step 2/14 : MAINTAINER wuguofeng
 ---> Using cache
 ---> d49d25fed779
Step 3/14 : COPY readme.txt /usr/local/readme.txt
 ---> Using cache
 ---> ae5cb51076a2
Step 4/14 : ADD jdk-8u221-linux-x64.tar.gz /usr/local
 ---> Using cache
 ---> af8fb1fb00e4
Step 5/14 : ADD apache-tomcat-9.0.34.tar.gz /usr/local
 ---> Using cache
 ---> 1fe61ee51ab8
Step 6/14 : ENV MYPATH /usr/local
 ---> Running in c46a6f652437
Removing intermediate container c46a6f652437
 ---> 0f8031dfe2f3
Step 7/14 : WORKDIR $MYPATH
 ---> Running in 93e66ec574cc
Removing intermediate container 93e66ec574cc
 ---> 7498459bedd9
Step 8/14 : ENV JAVA_HOME /usr/local/jdk1.8.0_221
 ---> Running in f71b8b05273c
Removing intermediate container f71b8b05273c
 ---> 2773439c6b10
Step 9/14 : ENV CLASSPATH $JAVA_HOME/dt.jar:$JAVA_HOME/lib/tools.jar
 ---> Running in ea4a3b60f8d9
Removing intermediate container ea4a3b60f8d9
 ---> 8cc4d635c0b9
Step 10/14 : ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.34
 ---> Running in cbca5e4c0d01
Removing intermediate container cbca5e4c0d01
 ---> b739796fc78c
Step 11/14 : ENV CATALINA_BASH /usr/local/apache-tomcat-9.0.34
 ---> Running in 6804a1289d14
Removing intermediate container 6804a1289d14
 ---> 0463052c7019
Step 12/14 : ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
 ---> Running in f8d00e4e44da
Removing intermediate container f8d00e4e44da
 ---> 6f1f5a55d7f3
Step 13/14 : EXPOSE 8080
 ---> Running in f2b220f241e4
Removing intermediate container f2b220f241e4
 ---> 12965b9ae89d
Step 14/14 : CMD /usr/local/apache-tomcat-9.0.34/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.34/logs/catalina.out
 ---> Running in be94f2c3a63c
Removing intermediate container be94f2c3a63c
 ---> fb2bc4e0a568
Successfully built fb2bc4e0a568
Successfully tagged tomcatjiayou:latest


# 查看一下構建的鏡像
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker images
REPOSITORY          TAG       IMAGE ID       CREATED          SIZE
tomcatjiayou        latest    fb2bc4e0a568   15 seconds ago   632MB
tomcat01            latest    e3787290ae16   21 minutes ago   690MB
centos-l            latest    6bb9564028ed   3 hours ago      209MB
centos-entrypoint   latest    a99fd74544ec   3 hours ago      209MB
textcentos          0.1       9dfecdb872e1   4 hours ago      242MB
mysql               5.7       a70d36bc331a   2 months ago     449MB
nginx               latest    f6d0b4767a6c   2 months ago     133MB
centos              latest    300e315adb2f   3 months ago     209MB

# 啟動鏡像
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker run -d -p 7070:8080 -v /home/wenjian:/usr/local/apache-tomcat-9.0.34/webapps/test -v /home/zhizhi:/usr/local/apache-tomcat-9.0.34/logs --name huanjing02 fb2bc4e0a568
d54392bd56180b80b8c86131372f2aeba056ac11b06e9319073aadfa550831d6


# 本地查看是否目錄中已掛載
[root@iZ2ze261ew0wzy5zenjh2xZ home]# ls
apache-tomcat-9.0.34.tar.gz  dockerfile  Dockerfile  jdk-8u221-linux-x64.tar.gz  loglog  mysql  readme.txt  rizhi  webapps  wenjian  wu  zhizhi


# 這樣就可以直接把項目放在wenjian這個目錄里,然后通過 地址:7070/test/項目名 來訪問頁面了

發布自己的鏡像

# docker login -u賬號
# 密碼
# 登錄上去,提交一定要有版本號
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker login -uchenhongguang
Password: 
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker images
REPOSITORY          TAG       IMAGE ID       CREATED          SIZE
tomcatjiayou        latest    fb2bc4e0a568   38 minutes ago   632MB
tomcat01            latest    e3787290ae16   59 minutes ago   690MB
centos-l            latest    6bb9564028ed   3 hours ago      209MB
centos-entrypoint   latest    a99fd74544ec   3 hours ago      209MB
textcentos          0.1       9dfecdb872e1   5 hours ago      242MB
mysql               5.7       a70d36bc331a   2 months ago     449MB
nginx               latest    f6d0b4767a6c   2 months ago     133MB
centos              latest    300e315adb2f   3 months ago     209MB
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker tag fb2bc4e0a568 chenhongguang/tomcat:0.1
[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker images
REPOSITORY             TAG       IMAGE ID       CREATED             SIZE
chenhongguang/tomcat   0.1       fb2bc4e0a568   40 minutes ago      632MB
tomcatjiayou           latest    fb2bc4e0a568   40 minutes ago      632MB
tomcat01               latest    e3787290ae16   About an hour ago   690MB
centos-l               latest    6bb9564028ed   3 hours ago         209MB
centos-entrypoint      latest    a99fd74544ec   3 hours ago         209MB
textcentos             0.1       9dfecdb872e1   5 hours ago         242MB
mysql                  5.7       a70d36bc331a   2 months ago        449MB
nginx                  latest    f6d0b4767a6c   2 months ago        133MB
centos                 latest    300e315adb2f   3 months ago        209MB

[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker push chenhongguang/tomcat:0.1
The push refers to repository [docker.io/chenhongguang/tomcat]
254c39ac9769: Pushed 
430320a63cd0: Pushed 
444a5b764b49: Pushed 
2653d992f4ef: Mounted from library/centos 
0.1: digest: sha256:32bb8a539c3cf885f06ae729853e2025b7a93b90f20baef57750220476909bb9 size: 1161


自定義網絡

容器互聯

查看所有的docker網絡

[root@iZ2ze261ew0wzy5zenjh2xZ home]# docker network ls
NETWORK ID     NAME      DRIVER    SCOPE
4d0255a86b75   bridge    bridge    local
a62b564db56a   host      host      local
642d353ee256   none      null      local

網絡模式

bridge:橋接 docker(默認,自己創建也使用bridge模式)

none:不配置網絡

host:和宿主機共享網絡

container:容器網絡連通(用的少!局限很大)

測試

# 我們直接啟動的命令 --net bridge, 而這個就是我們的docker0
docker run -d -P --name tomcat01 tomcat
docker run -d -P --name tomcat01 --net bridge tomcat

#docker0特點,默認,域名不能訪問,--link可以打通鏈接!

# 我們可以自己定義一個網絡!

下面是重點

image-20210403234927702

創建了一個網絡,啟動時就可以使用這個網絡啟動,就可以保證在一個指定的網段了

# docker run -d -P --name tomcat-net-01 --net mynet tomcat
# docker run -d -P --name tomcat-net-02 --net mynet tomcat
# 運行了兩個容器,都指定了用之前創建的網段,再查看元數據
# docker network inspect mynet

image-20210404000412376

也能ping名字了

我們自定義的網絡docker都已經幫我們維護好了對應的關系,推薦我們平時這樣使用網絡!

好處:

redis:不同的集群使用不同的網絡,保證集群時安全和健康的

mysql:不同的集群使用不同的網絡,保證集群是安全和健康的

image-20210404000957935

相互隔離,但是也是可以打通的

網絡連通

容器跟容器是不能打通的,但是可以跟所在的網絡打通,這樣就都通了

建了一個tomcat01,一個tomcat02 --默認網絡是docker0

tomcat-net-01,tomcat-net-02 --這兩個用的自建的網絡

所以兩個網絡不互通

現在通過打通 容器 tomcat01 和 網絡mynet ,就能使tomcat01能ping通tomcat-net-01

# 測試打通tomcat01 - mynet

# docker network connect mynet tomcat01
這樣就把tomcat01和mynet網絡連通了

image-20210404003812707

image-20210404004050583

結論:假設要跨網絡操作別人,就需要使用docker network connect 連通!

redis集群部署實戰

# 創建網卡
docker network create redis --subnet 172.38.0.0/16

# 通過腳本創建六個redis配置
for port in $(seq 1 6); \
do \
mkdir -p /mydata/redis/node-${port}/conf
touch /mydata/redis/node-${port}/conf/redis.conf
cat << EOF >>/mydata/redis/node-${port}/conf/redis.conf
port 6379
bind 0.0.0.0
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
cluster-announce-ip 172.38.0.1${port}
cluster-announce-port 6379
cluster-announce-bus-port 16379
appendonly yes
EOF
done

#通過腳本啟動6個redis
for port in $(seq 1 6); \
do \
docker run -p 637${port}:6379 -p 1637${port}:16379 --name redis-${port} \
-v /mydata/redis/node-${port}/data:/data \
-v /mydata/redis/node-${port}/conf/redis.conf:/etc/redis/redis.conf \
-d --net redis --ip 172.38.0.1${port} redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf; \
done
#這個是單個啟動的
docker run -p 6371:6379 -p 16371:16379 --name redis-1 \
-v /mydata/redis/node-1/data:/data \
-v /mydata/redis/node-1/conf/redis.conf:/etc/redis/redis.conf \
-d --net redis --ip 172.38.0.11 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf; 
# 看到了6個redis 然后進入一個
[root@iZ2ze261ew0wzy5zenjh2xZ conf]# docker ps
CONTAINER ID   IMAGE                    COMMAND                  CREATED         STATUS         PORTS                                              NAMES
b21b1b02dd7f   redis:5.0.9-alpine3.11   "docker-entrypoint.s…"   4 seconds ago   Up 2 seconds   0.0.0.0:6376->6379/tcp, 0.0.0.0:16376->16379/tcp   redis-6
1b856f095d96   redis:5.0.9-alpine3.11   "docker-entrypoint.s…"   4 seconds ago   Up 3 seconds   0.0.0.0:6375->6379/tcp, 0.0.0.0:16375->16379/tcp   redis-5
aac1ec4711fc   redis:5.0.9-alpine3.11   "docker-entrypoint.s…"   5 seconds ago   Up 4 seconds   0.0.0.0:6374->6379/tcp, 0.0.0.0:16374->16379/tcp   redis-4
c2c52b0f0c5d   redis:5.0.9-alpine3.11   "docker-entrypoint.s…"   6 seconds ago   Up 5 seconds   0.0.0.0:6373->6379/tcp, 0.0.0.0:16373->16379/tcp   redis-3
e6aa8c256205   redis:5.0.9-alpine3.11   "docker-entrypoint.s…"   7 seconds ago   Up 6 seconds   0.0.0.0:6372->6379/tcp, 0.0.0.0:16372->16379/tcp   redis-2
cf356f08e3ee   redis:5.0.9-alpine3.11   "docker-entrypoint.s…"   8 seconds ago   Up 7 seconds   0.0.0.0:6371->6379/tcp, 0.0.0.0:16371->16379/tcp   redis-1
[root@iZ2ze261ew0wzy5zenjh2xZ conf]# docker exec -it b21b1b02dd7f /bin/sh
/data # ls
appendonly.aof  nodes.conf

#創建redis集群-6個(自動分配三主三從)
/data # redis-cli --cluster create 172.38.0.11:6379 172.38.0.12:6379 172.38.0.13:6379 172.38.0.
>>> Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 172.38.0.15:6379 to 172.38.0.11:6379
Adding replica 172.38.0.16:6379 to 172.38.0.12:6379
Adding replica 172.38.0.14:6379 to 172.38.0.13:6379
M: 57d682bb1c6bfa4529b5c56ea8d0784a53612176 172.38.0.11:6379
   slots:[0-5460] (5461 slots) master
M: ef57138e7cd079bf79135aeca5e8dd497f591a09 172.38.0.12:6379
   slots:[5461-10922] (5462 slots) master
M: 8b891bf98ea8408409897dda4c1d8ae295d7ca1b 172.38.0.13:6379
   slots:[10923-16383] (5461 slots) master
S: b4763404c28683e973f5844e86412b390874597f 172.38.0.14:6379
   replicates 8b891bf98ea8408409897dda4c1d8ae295d7ca1b
S: b1d31a707e707bdd1a843829a7ff9b4cffe0cec4 172.38.0.15:6379
   replicates 57d682bb1c6bfa4529b5c56ea8d0784a53612176
S: e43d8850ec1673aab2a1ceb1620b19b05c277876 172.38.0.16:6379
   replicates ef57138e7cd079bf79135aeca5e8dd497f591a09
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join
...
>>> Performing Cluster Check (using node 172.38.0.11:6379)
M: 57d682bb1c6bfa4529b5c56ea8d0784a53612176 172.38.0.11:6379
   slots:[0-5460] (5461 slots) master
   1 additional replica(s)
S: b4763404c28683e973f5844e86412b390874597f 172.38.0.14:6379
   slots: (0 slots) slave
   replicates 8b891bf98ea8408409897dda4c1d8ae295d7ca1b
M: ef57138e7cd079bf79135aeca5e8dd497f591a09 172.38.0.12:6379
   slots:[5461-10922] (5462 slots) master
   1 additional replica(s)
S: e43d8850ec1673aab2a1ceb1620b19b05c277876 172.38.0.16:6379
   slots: (0 slots) slave
   replicates ef57138e7cd079bf79135aeca5e8dd497f591a09
M: 8b891bf98ea8408409897dda4c1d8ae295d7ca1b 172.38.0.13:6379
   slots:[10923-16383] (5461 slots) master
   1 additional replica(s)
S: b1d31a707e707bdd1a843829a7ff9b4cffe0cec4 172.38.0.15:6379
   slots: (0 slots) slave
   replicates 57d682bb1c6bfa4529b5c56ea8d0784a53612176
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

#啟動redis  -c 是啟動集群選項

/data # redis-cli -c
127.0.0.1:6379> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3									--看到有三個
cluster_current_epoch:6
cluster_my_epoch:2
cluster_stats_messages_ping_sent:288
cluster_stats_messages_pong_sent:279
cluster_stats_messages_meet_sent:3
cluster_stats_messages_sent:570
cluster_stats_messages_ping_received:276
cluster_stats_messages_pong_received:291
cluster_stats_messages_meet_received:3
cluster_stats_messages_received:570
127.0.0.1:6379> cluster nodes					--查看集群關系
b1d31a707e707bdd1a843829a7ff9b4cffe0cec4 172.38.0.15:6379@16379 slave 57d682bb1c6bfa4529b5c56ea8d0784a53612176 0 1617506962000 5 connected
8b891bf98ea8408409897dda4c1d8ae295d7ca1b 172.38.0.13:6379@16379 master - 0 1617506962388 3 connected 10923-16383
57d682bb1c6bfa4529b5c56ea8d0784a53612176 172.38.0.11:6379@16379 master - 0 1617506962589 1 connected 0-5460
e43d8850ec1673aab2a1ceb1620b19b05c277876 172.38.0.16:6379@16379 myself,slave ef57138e7cd079bf79135aeca5e8dd497f591a09 0 1617506961000 6 connected
ef57138e7cd079bf79135aeca5e8dd497f591a09 172.38.0.12:6379@16379 master - 0 1617506961000 2 connected 5461-10922
b4763404c28683e973f5844e86412b390874597f 172.38.0.14:6379@16379 slave 8b891bf98ea8408409897dda4c1d8ae295d7ca1b 0 1617506961387 4 connected
127.0.0.1:6379> set a b							--看使用的哪個端口
-> Redirected to slot [15495] located at 172.38.0.13:6379
OK
172.38.0.13:6379> get a							--這里已經把redis3容器停了
Error: Operation timed out
/data # redis-cli -c
127.0.0.1:6379> get a							--重新登錄驗證,自動切換為14端口
-> Redirected to slot [15495] located at 172.38.0.14:6379
"b"
172.38.0.14:6379> cluster nodes					--發現13fail了,14變成了master(主)
57d682bb1c6bfa4529b5c56ea8d0784a53612176 172.38.0.11:6379@16379 master - 0 1617507328000 1 connected 0-5460
ef57138e7cd079bf79135aeca5e8dd497f591a09 172.38.0.12:6379@16379 master - 0 1617507328629 2 connected 5461-10922
b1d31a707e707bdd1a843829a7ff9b4cffe0cec4 172.38.0.15:6379@16379 slave 57d682bb1c6bfa4529b5c56ea8d0784a53612176 0 1617507328629 5 connected
8b891bf98ea8408409897dda4c1d8ae295d7ca1b 172.38.0.13:6379@16379 master,fail - 1617507103428 1617507102523 3 connected
b4763404c28683e973f5844e86412b390874597f 172.38.0.14:6379@16379 myself,master - 0 1617507327000 7 connected 10923-16383
e43d8850ec1673aab2a1ceb1620b19b05c277876 172.38.0.16:6379@16379 slave ef57138e7cd079bf79135aeca5e8dd497f591a09 0 1617507328000 6 connected
172.38.0.14:6379> 


image-20210404113640840

springboot微服務打包docker鏡像

1、構架springboot項目

2、打包應用

3、編寫Dockerfile

4、構建鏡像

5、發布運行



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM