docker安装文档-初学者
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)删除所有镜像
新建并启动容器
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
创建一个镜像,命令参数脚本
步骤:
- 编写一个dockerfile
- docker build 构建一个镜像
- docker run 运行一个容器
- 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安装文档-初学者相关推荐
- docker安装文档
Docker离线安装以及本地yum源构建 http://blog.csdn.net/joniers/article/details/64122820 http://blog.csdn.net/wssc ...
- Docker软件安装文档
软件安装文档 文章目录 软件安装文档 虚拟机安装 系统死锁问题 JDK11安装 Docker安装 Docker-Compose安装 MySQL安装 MySQL8安装 Docker-Compose安装M ...
- Docker部署文档
Docker部署文档 目录 Docker部署文档 1 一.什么是Docker 3 1.1Docker简介 3 1.2对比传统虚拟机总结 4 1.3Docker通常用于如下场景: 5 1.4基本概念 5 ...
- GitLab安装文档
GitLab安装文档 GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务. GitLab与GitHub的功能相似,通常企业使用GitLab在局 ...
- Docker详细文档
docker详细文档 1.什么是docker 解决了什么难点 在开发中,经常会遇到本地环境与生产环境不一致,然后开发和运维言语沟通或者武力沟通的情况,相互甩锅,程序员最常说的一句话就是:"为 ...
- docker使用文档1
Docker概述 Docker为什么出现? 一款产品: 开发–上线 两套环境!应用环境,应用配置! 开发 - 运维. 问题:我在我的电脑上可以允许!版本更新,导致服务不可用!对于运维来说考验十分大? ...
- 云发布的Docker部署文档
云发布的Docker部署文档 文章目录 云发布的Docker部署文档 1.服务器安装 Docker 2.修改后端微服务的配置 2.1 修改 MySQL 的配置 2.2 修改 Redis 的配置 2.3 ...
- ELK安装文档及相关优化
前言:随着硬件成本的不断低廉,我们可以存储更多数据内容,也会对各数据加以利用,其中一项很重要的数据内容便是日志文件,无论是访问日志还是系统日志或是应用日志,都显得十分重要,而怎么加以利用一直是一个难题 ...
- mysql数据库21_Mysql5.7.21安装文档
Mysql5.7.21安装文档 发布时间:2020-06-27 13:59:56 来源:51CTO 阅读:946 作者:PengChonggui --1.创建用户组mysql,创建用户mysql并将其 ...
最新文章
- 数据可视化,需要遵循的几条核心原则
- 二叉排序树(c/c++)
- 【下载】推荐一款免费的人脸识别SDK
- 异常注意事项_finally有return语句
- 学习面向对象和设计模式的好地方
- 游三圣乡山中湖岛有感
- 小白学算法:买卖股票的最佳时机!
- 如何保护 .NET 应用的安全?
- TensorFlow笔记(8) LeNet-5卷积神经网络
- 在dropdownlist中使用enum
- 错误: 找不到或无法加载主类 Demo
- 【C语言】实现简易网络聊天室
- 我叫mt4公会攻城战服务器维护中,公会攻城战也要讲战术《我叫MT4》攻城战策略解析...
- 菜鸟的mongoDB学习---(二)MongoDB 数据库,对象,集合
- 【蔬菜怎么吃最营养】
- 一、在GPU上执行运算
- android button的美化
- socket编程基础2(socket API函数介绍)
- pstack无法使用的问题
- rpath添加依赖库搜索路径