1卸载旧的版本:

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 \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

更新软件包索引

yum makecache fast

安装docker ce

yum install docker-ce docker-ce-cli containerd.io

启动docker

sudo systemctl start docker
docker run hello-world
卸载
yum remove docker-ce docker-ce-cli containerd.io
sudo rm -rf /var/lib/dockersudo rm -rf /var/lib/containerd

阿里云配置镜像加速器

针对Docker客户端版本大于 1.10.0 的用户

您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{"registry-mirrors": ["https://32c9xrxj.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
搜索镜像
docker search mysql
[root@alichen /]# docker search mysql --filter stars=3000
NAME      DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
mysql     MySQL is a widely used, open-source relation…   11556     [OK]
mariadb   MariaDB Server is a high performing open sou…   4398      [OK]
下载--help
docker pull mysql
[root@alichen /]# docker pull mysql
Using default tag: latest     #不写tag默认最新版本
latest: Pulling from library/mysql
b380bbd43752: Pull complete    #分层下载
f23cbf2ecc5d: Pull complete
30cfc6c29c0a: Pull complete
b38609286cbe: Pull complete
8211d9e66cd6: Pull complete
2313f9eeca4a: Pull complete
7eb487d00da0: Pull complete
4d7421c8152e: Pull complete
77f3d8811a28: Pull complete
cce755338cba: Pull complete
69b753046b9f: Pull complete
b2e64b0ab53c: Pull complete
Digest: sha256:6d7d4524463fe6e2b893ffc2b89543c81dec7ef82fb2020a1b27606666464d87 #签名
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest等价于docker pull mysql
指定版本下载
[root@alichen /]# docker pull mysql:5.7
5.7: Pulling from library/mysql
b380bbd43752: Already exists
f23cbf2ecc5d: Already exists
30cfc6c29c0a: Already exists
b38609286cbe: Already exists
8211d9e66cd6: Already exists
2313f9eeca4a: Already exists
7eb487d00da0: Already exists #公用无需再次下载
a71aacf913e7: Pull complete
393153c555df: Pull complete
06628e2290d7: Pull complete
ff2ab8dac9ac: Pull complete
Digest: sha256:2db8bfd2656b51ded5d938abcded8d32ec6181a9eae8dfc7ddf87a656ef97e97
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7
删除镜像文件
docker rmi -f ID
docker rmi -f $(参数docker images -ap)删除所有镜像
  1. 新建并启动容器

docker pull centos
docker run [可选参数] image
--name  #容器名字
-d #后台运行
-it#使用交互方式运行,走进容器并查看内容
-p#确定容器端口-p#主机端口:容器端口(常用)-P#随机端口docker run -it centos /bin/bash删除容器docker rm -f $(docker ps -aq)#删除所有容器docker rm 容器IDdocker ps -aq|xargs docker rm #删除所有容器启动和停止的操作docker start 容器ID #启动docker restart 容器ID#重启docker stop 容器ID#停止docker kill 容器ID #杀掉强制ctrl+p+q推出不停止容器

查看docker日志

docker logs -f -t --tail 显示行数 容器ID-tf 显示所有日志--tail 显示行数显示日志行数

查看docker容器中的进程信息

dokcer top 容器ID
[root@alichen /]# docker top  容器ID
UID                 PID                 PPID                C                   STIME
root                6618                6600                0                   15:52

docker inspect ID查看容器源数据

[root@alichen /]# docker inspect 28449bc1777f
[{"Id": "28449bc1777ff637afc8e04608bf0fbd1e3084267d723a459e0547fc8f73c447","Created": "2021-10-21T07:49:38.807680988Z","Path": "/bin/bash","Args": [],"State": {"Status": "exited","Running": false,"Paused": false,"Restarting": false,"OOMKilled": false,"Dead": false,"Pid": 0,"ExitCode": 0,"Error": "","StartedAt": "2021-10-21T07:50:11.909376361Z","FinishedAt": "2021-10-21T07:51:14.720992886Z"},"Image": "sha256:5d0da3dc976460b72c77d94c8a1ad043720b0416bfc16c52c45d4847e53fadb6","ResolvConfPath": "/var/lib/docker/containers/28449bc1777ff637afc8e04608bf0fbd1e3084267d723a459e0547fc8f73c447/resolv.conf","HostnamePath": "/var/lib/docker/containers/28449bc1777ff637afc8e04608bf0fbd1e3084267d723a459e0547fc8f73c447/hostname","HostsPath": "/var/lib/docker/containers/28449bc1777ff637afc8e04608bf0fbd1e3084267d723a459e0547fc8f73c447/hosts","LogPath": "/var/lib/docker/containers/28449bc1777ff637afc8e04608bf0fbd1e3084267d723a459e0547fc8f73c447/28449bc1777ff637afc8e04608bf0fbd1e3084267d723a459e0547fc8f73c447-json.log","Name": "/youthful_spence","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/d2b35a0fa293ddc3c569161542e8d777b0691bf567a78f710fbbe44774976557-init/diff:/var/lib/docker/overlay2/6ce32b6151ac996b0dcab013a0a4c0260970c458e9d02ba2de4ca0b8500cb66c/diff","MergedDir": "/var/lib/docker/overlay2/d2b35a0fa293ddc3c569161542e8d777b0691bf567a78f710fbbe44774976557/merged","UpperDir": "/var/lib/docker/overlay2/d2b35a0fa293ddc3c569161542e8d777b0691bf567a78f710fbbe44774976557/diff","WorkDir": "/var/lib/docker/overlay2/d2b35a0fa293ddc3c569161542e8d777b0691bf567a78f710fbbe44774976557/work"},"Name": "overlay2"},"Mounts": [],"Config": {"Hostname": "28449bc1777f","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": "20210915","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": "cadc50c6aeb28ea561b303df23623b4478ba556f3c04d4b368e3ca7dcdb0c04f","HairpinMode": false,"LinkLocalIPv6Address": "","LinkLocalIPv6PrefixLen": 0,"Ports": {},"SandboxKey": "/var/run/docker/netns/cadc50c6aeb2","SecondaryIPAddresses": null,"SecondaryIPv6Addresses": null,"EndpointID": "","Gateway": "","GlobalIPv6Address": "","GlobalIPv6PrefixLen": 0,"IPAddress": "","IPPrefixLen": 0,"IPv6Gateway": "","MacAddress": "","Networks": {"bridge": {"IPAMConfig": null,"Links": null,"Aliases": null,"NetworkID": "05489496d9933ad15165664e8254cfe856b47e2f71e0d8a5c5303db4405ecbce","EndpointID": "","Gateway": "","IPAddress": "","IPPrefixLen": 0,"IPv6Gateway": "","GlobalIPv6Address": "","GlobalIPv6PrefixLen": 0,"MacAddress": "","DriverOpts": null}}}}
]

进入正在运行的容器

docker exec -it 7b22a30a140a /bin/bash#进入正在运行的容器打开新终端
[root@alichen /]# docker exec -it 7b22a30a140a /bin/bash
[root@7b22a30a140a /]# ps -ef
UID          PID    PPID  C STIME TTY          TIME CMD
root           1       0  0 07:52 pts/0    00:00:00 /bin/bash
root          15       0  0 08:17 pts/1    00:00:00 /bin/bash
root          29      15  0 08:17 pts/1    00:00:00 ps -efdocker attach 容器ID#进入正在运行的容器继续进行终端

从容器内拷贝文件到本机上

docker cp 容器id:容器内路径 目的路径

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6jmXn4BA-1644912741962)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211021163516663.png)]

安装nginx

docker search nginxdocker pull nginxdocker run -it nginx01 /bin/bash[root@alichen /]# docker exec -it nginx01 /bin/bash

安装tomcat

docker run -d -p 3332:8080 --name tomcat9 tomcat:9.0docker exec -it tomcat9 /bin/bash
docker 安装elasticsearch比较耗资源
docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" elasticsearch:7.6.2

查看系统资源使用情况

docker stats

可视化

  • portainer

    [root@alichen /]# docker run -d -p 8088:9000 \

    –restart=always -v /var/run/docker.
    –restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer

管理测试portainer

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rIzPrjN2-1644912741964)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211022092241703.png)]

如何提交自己的更改过的镜像

docker commit 自己的镜像

命令和git相似

docker commit -m=“提交的描述信息” -a=“作者” 容器ID 目标镜像名.[tag]

测试

docker run -it -p 8080:8080 tomcat:9.0docker exec -it 25670e3875b6 /bin/bashdocker commit -a="alichen" -m="add tomcat app" 25670e3875b6 tomcat9:1.0

容器数据卷

什么是容器数据卷

数据库不能存在容器内,如果删除数据就回丢失#数据持久化

mysql数据存放在本地

数据共享的的技术

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kYDo9fDn-1644912741966)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211022101539601.png)]

容器的持久化和同步操作

使用数据卷

方式1 -v 命令挂载

docker -it -v 主机目录:容器内目录

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VcCsOgky-1644912741966)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211022102036469.png)]

docker run -it -v /home/ceshi:/home centos /bin/bash 运行一个容器并进入交互操作

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dDBmqWjT-1644912741967)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211022102347954.png)]

实战

安装mysql

docker pull mysql:5.7

启动mysql

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
docker run -d -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=pw --name *** mysql:tag

##具体挂在和匿名挂载

匿名挂载

docker run -d -P --name nginx01 -v /home/nginx nginx#匿名挂载
#查看volume的情况
docker volume ls
[root@alichen /]# docker volume ls
DRIVER    VOLUME NAME
local     6d68f3fc5f7b816242aec6c7ff11bdd2e961d078d59eb60a012927e4f2616a3d
local     54c7a21cd74c1a4c3a52163b61268121d25f424b4a8cad808d27c6606bb26d83

如何查看是匿名还是具名挂

-v #容器内路径   匿名挂载
-v #卷名:/容器内路径   具名挂载
-v #主机内路径:容器内路径    具体挂载-v #卷名:/容器内路径   具#名挂载
docker volume inspect 卷名  #可以查看具体位置
#一般在/var/lib/docker/volume/卷名/_data
#拓展
docker run -d -P --name nginx01 -v /home/nginx:ro nginx#readonly只读容器内不可操作
docker run -d -P --name nginx01 -v /home/nginx:rw nginx#可读可写

Dockerfile

定义:有来构建docker镜像的构建文件

#通过这个脚本生成一个镜像,镜像是分层的脚本也是每层生成的
[root@alichen home]# mkdir docker-test
[root@alichen home]# cd docker-test/
[root@alichen docker-test]# ls
[root@alichen docker-test]# vim dockerfile
[root@alichen docker-test]# cat dockerfile
FROM centosVOLUME ["volume01","volume02"]CMD -----end-----
CMD /bin/bash
[root@alichen docker-test]# docker build -f dockerfile -t aliyuncentos .
#创建容器并加载
Sending build context to Docker daemon  2.048kB
Error response from daemon: dockerfile parse error line 5: Unknown flag: ---end-----
[root@alichen docker-test]# vim dockerfile
[root@alichen docker-test]# docker build -f dockerfile -t aliyuncentos .
Sending build context to Docker daemon  2.048kB
Step 1/4 : FROM centos---> 5d0da3dc9764
Step 2/4 : VOLUME ["volume01","volume02"]---> Running in 85eeb751e768
Removing intermediate container 85eeb751e768---> cd7d6a948f10
Step 3/4 : CMD echo"---end-----"---> Running in 9b857fe78a4b
Removing intermediate container 9b857fe78a4b---> cb8f55320954
Step 4/4 : CMD /bin/bash---> Running in ce37ba390956
Removing intermediate container ce37ba390956---> adc7df11240b
Successfully built adc7df11240b
Successfully tagged aliyuncentos:latest
[root@alichen docker-test]# docker images
REPOSITORY            TAG       IMAGE ID       CREATED         SIZE
aliyuncentos          latest    adc7df11240b   9 seconds ago   231MB

数据卷同步

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GyzwBCi8-1644912741967)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211022142109624.png)]

备份机制删除docker01之后,docker02或者多个容器之间的数据都存在,

#创建父容器
docker run -it --name docker01 aliyuncentos /bin/bash
#创建02
docker run -it --name docker02 --volumes-from docker01 aliyuncentos

Dockerfile

创建一个镜像,命令参数脚本

步骤:

  1. ​ 编写一个dockerfile
  2. docker build 构建一个镜像
  3. docker run 运行一个容器
  4. docker push 发布镜像、上传至阿里云仓库或者dockerhub

官方centos构建命令

FROM scratch
ADD centos-7-x86_64-docker.tar.xz /
LABEL \
org.label-schema.schema-version=“1.0” \
org.label-schema.name=“CentOS Base Image” \
org.label-schema.vendor=“CentOS” \
org.label-schema.license=“GPLv2” \
org.label-schema.build-date=“20201113” \
org.opencontainers.image.title=“CentOS Base Image” \
org.opencontainers.image.vendor=“CentOS” \
org.opencontainers.image.licenses=“GPL-2.0-only” \
org.opencontainers.image.created=“2020-11-13 00:00:00+00:00”
CMD ["/bin/bash"]

官方的都是基础包。

构建过程

#每个关键字都是大写字母,指令从上至下依次执行,

dockerfile面向开发,发布项目,企业交付的标准

步骤:开发、部署、运维 缺一不可

dockerfile :构建文件定义了一切的步骤,源代码

dockerimages:通过docerfile构建生成的镜像,最终发布和运行的产品

docker容器:容器就是镜像起来的提供服务

#FROM   一切从这里开始构建
#MAINTAINER    作者  。姓名+邮箱
#RUN   运行的命令
#ADD  加压缩包
#WORKDIR 工作目录
#VOLUME 设置一个挂载卷位置
#EXPOSE 指定暴漏端口
#CMD 指定这个容器启动时候的执行的命令 只执行最后最后一个,可以被替代
#ENTRYPOINT 指定这个容器启动时候的执行的命令可以追加命令
#ONBUILD    当构建一个被继承的dockerfile这个时候会激发ONBULILD指令
#COPY 类似ADD,将我们的我呢见拷贝至镜像中
#ENV 构建时候的环境变量
#自己编写一个dockerfile
FROM centos
MAINTAINER chen<123@qq.com>
ENV MYPATH /usr/local
WORKDIR $MYPATHRUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo"--end--"
CMD /bin/bash#自己构建一个镜像
docker build -f dockerfile-centos -t centos:1.0 .
#启动自己的镜像
docker run -it f9f6c9921d6e

dokcerfile中有很多相识的命令,只有通过测试才能发现些微的不同

实战

tomcat镜像

FROM   centos:1.0
MAINTAINER   alichen34917662@qqcom# now add java and tomcat support in the container
ADD jdk1.8.0_251.tar.gz /usr/local/
ADD apache-tomcat-8.5.61.tar.gz /usr/local/ENV MYPATH /usr/local
WORKDIR $MYPATH# configuration of java and tomcat ENV
ENV JAVA_HOME /usr/local/jdk1.8.0_251
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-8.5.61
ENV CATALINA_BASE /usr/local/apache-tomcat-8.5.61ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin# container listener port
EXPOSE 8080# startup web application services by selfCMD /usr/local/apache-tomcat-8.5.61/bin/startup.sh  && CMD /bin/bash#运行镜像
docker run -d -p 8090:8080 --name tomcat -v /home/build/tomcat8/web:/usr/local/apache-tomcat-8.5.61/webapps -v /home/build/tomcat8/logs:/usr/local/apache-tomcat-8.5.61/logs diytomcat

部署到docker hub上

docker login -u username -p

1. 登录阿里云Docker Registry
$ docker login --username=**** registry.cn-hangzhou.aliyuncs.com
用于登录的用户名为阿里云账号全名,密码为开通服务时设置的密码。您可以在访问凭证页面修改凭证密码。2. 从Registry中拉取镜像
$ docker pull registry.cn-hangzhou.aliyuncs.com/:[镜像版本号]
3. 将镜像推送到Registry
$ docker login --username=**** registry.cn-hangzhou.aliyuncs.com
$ docker tag [ImageId] registry.cn-hangzhou.aliyuncs.com//mydiy:[镜像版本号]
$ docker push registry.cn-hangzhou.aliyuncs.com/mydiy:[镜像版本号]
请根据实际镜像信息替换示例中的[ImageId]和[镜像版本号]参数。4. 选择合适的镜像仓库地址
从ECS推送镜像时,可以选择使用镜像仓库内网地址。推送速度将得到提升并且将不会损耗您的公网流量。如果您使用的机器位于VPC网络,请使用 registry-vpc.cn-hangzhou.aliyuncs.com 作为Registry的域名登录。5. 示例
使用"docker tag"命令重命名镜像,并将它通过专有网络地址推送至Registry。$ docker images
REPOSITORY                                                         TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
registry.aliyuncs.com/acs/agent                                    0.7-dfb6816         37bb9c63c8b2        7 days ago          37.89 MB
$ docker tag 37bb9c63c8b2 registry-vpc.cn-hangzhou.aliyuncs.com/acs/agent:0.7-dfb6816
使用 "docker push" 命令将该镜像推送至远程。$ docker push registry-vpc.cn-hangzhou.aliyuncs.com/acs/agent:0.7-dfb6816

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CFAsZ3ww-1644912741968)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211025105022273.png)]

Docker 网络

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ze7gx56Z-1644912741969)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211025110701767.png)]

[root@alichen /]# docker exec -it tomcat1 ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft forever
62: eth0@if63: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group defaultlink/ether 02:42:ac:11:00:02 brd ff:ff:ff:ff:ff:ff link-netnsid 0inet 172.17.0.2/16 brd 172.17.255.255 scope global eth0valid_lft forever preferred_lft forever
eth0@if63是docker分配的
可以ping通

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kmIYFuFr-1644912741970)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211025111241985.png)]

原理

我们每启动一个容器,就会分配一个ip地址,分配的ip都是一对对的,是一对虚拟接口,一个是协议,一个是通信,evth-pair是一个桥梁。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rCqf3Kbx-1644912741970)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211025112715711.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jtwhjk0s-1644912741971)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211025113203197.png)]

创建自己的网络

docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet[root@alichen /]# docker run -d -P --name tomcat1 --net mynet tomcat
bade0da55afbd075f14f289f30aea90626fcb1a0cf169e97baa550eaa9591931
[root@alichen /]# docker run -d -P --name tomcat2 --net mynet tomcat
8162a79a80472767f06c8077c363ef6334830801d5d63a868f6d41150e7b2148
[root@alichen /]# docker exec -it tomcat1 ping tomcat2
PING tomcat2 (192.168.0.3) 56(84) bytes of data.
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=1 ttl=64 time=0.081 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=2 ttl=64 time=0.075 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=3 ttl=64 time=0.074 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=4 ttl=64 time=0.075 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=5 ttl=64 time=0.076 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=6 ttl=64 time=0.077 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=7 ttl=64 time=0.073 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=8 ttl=64 time=0.070 ms
^C
--- tomcat2 ping statistics ---

创建自己的网络,把所有的容器互相连通,比docker0好用,已经帮我们维护好了对应的关系,推荐我们平时用这样的网络,

好处:

redis:不同的集群使用不同的网络,保证集群是安全和健康的

mysql:不同的集群使用不同的网络,保证集群是安全和健康的

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8980Hiqg-1644912741971)(C:\Users\cheny\AppData\Roaming\Typora\typora-user-images\image-20211025154639946.png)]

跨网络连通需要用connect命令
docker network connect mynet tomcat01docker exec -it tomcat01 ping tomcat1

实战部署redis

.075 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=3 ttl=64 time=0.074 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=4 ttl=64 time=0.075 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=5 ttl=64 time=0.076 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=6 ttl=64 time=0.077 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=7 ttl=64 time=0.073 ms
64 bytes from tomcat2.mynet (192.168.0.3): icmp_seq=8 ttl=64 time=0.070 ms
^C
— tomcat2 ping statistics —


创建自己的网络,把所有的容器互相连通,比docker0好用,已经帮我们维护好了对应的关系,推荐我们平时用这样的网络,### 好处:redis:不同的集群使用不同的网络,保证集群是安全和健康的mysql:不同的集群使用不同的网络,保证集群是安全和健康的[外链图片转存中...(img-8980Hiqg-1644912741971)]```shell
跨网络连通需要用connect命令
docker network connect mynet tomcat01docker exec -it tomcat01 ping tomcat1

docker安装文档-初学者相关推荐

  1. docker安装文档

    Docker离线安装以及本地yum源构建 http://blog.csdn.net/joniers/article/details/64122820 http://blog.csdn.net/wssc ...

  2. Docker软件安装文档

    软件安装文档 文章目录 软件安装文档 虚拟机安装 系统死锁问题 JDK11安装 Docker安装 Docker-Compose安装 MySQL安装 MySQL8安装 Docker-Compose安装M ...

  3. Docker部署文档

    Docker部署文档 目录 Docker部署文档 1 一.什么是Docker 3 1.1Docker简介 3 1.2对比传统虚拟机总结 4 1.3Docker通常用于如下场景: 5 1.4基本概念 5 ...

  4. GitLab安装文档

    GitLab安装文档 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务. GitLab与GitHub的功能相似,通常企业使用GitLab在局 ...

  5. Docker详细文档

    docker详细文档 1.什么是docker 解决了什么难点 在开发中,经常会遇到本地环境与生产环境不一致,然后开发和运维言语沟通或者武力沟通的情况,相互甩锅,程序员最常说的一句话就是:"为 ...

  6. docker使用文档1

    Docker概述 Docker为什么出现? 一款产品: 开发–上线 两套环境!应用环境,应用配置! 开发 - 运维. 问题:我在我的电脑上可以允许!版本更新,导致服务不可用!对于运维来说考验十分大? ...

  7. 云发布的Docker部署文档

    云发布的Docker部署文档 文章目录 云发布的Docker部署文档 1.服务器安装 Docker 2.修改后端微服务的配置 2.1 修改 MySQL 的配置 2.2 修改 Redis 的配置 2.3 ...

  8. ELK安装文档及相关优化

    前言:随着硬件成本的不断低廉,我们可以存储更多数据内容,也会对各数据加以利用,其中一项很重要的数据内容便是日志文件,无论是访问日志还是系统日志或是应用日志,都显得十分重要,而怎么加以利用一直是一个难题 ...

  9. mysql数据库21_Mysql5.7.21安装文档

    Mysql5.7.21安装文档 发布时间:2020-06-27 13:59:56 来源:51CTO 阅读:946 作者:PengChonggui --1.创建用户组mysql,创建用户mysql并将其 ...

最新文章

  1. 数据可视化,需要遵循的几条核心原则
  2. 二叉排序树(c/c++)
  3. 【下载】推荐一款免费的人脸识别SDK
  4. 异常注意事项_finally有return语句
  5. 学习面向对象和设计模式的好地方
  6. 游三圣乡山中湖岛有感
  7. 小白学算法:买卖股票的最佳时机!
  8. 如何保护 .NET 应用的安全?
  9. TensorFlow笔记(8) LeNet-5卷积神经网络
  10. 在dropdownlist中使用enum
  11. 错误: 找不到或无法加载主类 Demo
  12. 【C语言】实现简易网络聊天室
  13. 我叫mt4公会攻城战服务器维护中,公会攻城战也要讲战术《我叫MT4》攻城战策略解析...
  14. 菜鸟的mongoDB学习---(二)MongoDB 数据库,对象,集合
  15. 【蔬菜怎么吃最营养】
  16. 一、在GPU上执行运算
  17. android button的美化
  18. socket编程基础2(socket API函数介绍)
  19. pstack无法使用的问题
  20. rpath添加依赖库搜索路径

热门文章

  1. 鸿蒙用java虚拟机_鸿蒙运行Android应用的时候还会有JVM虚拟机?
  2. MySQL删除数据库的命令_删除数据库的命令是什么?
  3. 解决maven版本冲突——maven-shade
  4. mysql minus_MYSQL安装及备份 - 阿不思布丁
  5. 流量和延迟减半!挑战分布式数据库 TiDB 跨数据中心难题
  6. 求最大公约数的算法实现
  7. Flutter之Positioned
  8. 微信小程序去除button边框底色
  9. mySQL首行缩进快捷键_html首行缩进、悬停效果
  10. Java String的split方法总结