Docker学习

一.安装docker

根据官网步骤:

官网地址:https://docs.docker.com

1.卸载旧版本的docker配置

$ sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

2.环境安装包

$ sudo yum install -y yum-utils

3.设置环境的仓库

yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo(国外的,比较慢)
    
 yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo(国内的,比较快推荐使用)

4.安装docker相关内容

安装前最好更新下yum软件索引

yum makecache fast

docker -ce 代表社区版的推荐使用,docker -ee 企业版的

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

5.测试启动

systemctl start docker

查看安装版本

docker version 

在这里插入图片描述

6.运行hellowork镜像

docker run hello-world

安装成功:

在这里插入图片描述

7.查看helloword 的镜像

docker images

在这里插入图片描述

了解:若是要卸载

分别执行一下命令移除即可

卸载依赖and 删除资源:

yum remove docker-ce docker-ce-cli containerd.io
rm -rf /var/lib/docker
rm -rf /var/lib/containerd

二.阿里云镜像加速

1.登录阿里云找到容器服务

在这里插入图片描述

2.找到镜像加速器
在这里插入图片描述

配置使用:

sudo mkdir -p /etc/docker 

sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://25szgwmc.mirror.aliyuncs.com"]
}
EOF

sudo systemctl daemon-reload 

sudo systemctl restart docker

配置完毕!!!

回顾:

docker run 镜像名 的原理:

在这里插入图片描述

底层原理
在这里插入图片描述
在这里插入图片描述

三.Docker的常用命令

1.帮助命令

docker version    #docker 的版本信息

docker info          #docker 的系统信息,包括镜像,容器的数量

docker --help       #docker 的帮助命令

docker官网的命令:

https://docs.docker.com/engine/reference

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

2.镜像命令

docker images 查看主机上的所有镜像

在这里插入图片描述

docker search 搜索镜像

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

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

docker pull 下载镜像

下载默认使用新版: docker pull mysql

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

在这里插入图片描述

docker rmi --删除镜像

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

3.容器命令

docker pull centos – 再docker容器里面安装小型的centos的服务器(套娃)

docker run -it centos /bin/bash – 运行并进去容器内部的bin/bash目录

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

容器不退出运行,查看运行的情况
Ctrl+P+Q

在这里插入图片描述

删除容器:

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

常用的其他命令

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

查看当前容器运行的进程信息

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

查看镜像的元数据:

#命令

docker inspect 714c594e1748

#测试

[root@tianqinhuafirstecs /]# docker inspect 714c594e1748
[
{
“Id”: “714c594e17487ada1024e6ed3da802d71d821cc6b6927e11bb9c4567cef408bd”,
“Created”: “2021-04-18T13:02:27.148142235Z”,
“Path”: “/bin/sh”,
“Args”: [
“-c”,
“while true;do echo tianqinhua sleep 100;done”
],
“State”: {
“Status”: “running”,
“Running”: true,
“Paused”: false,
“Restarting”: false,
“OOMKilled”: false,
“Dead”: false,
“Pid”: 20863,
“ExitCode”: 0,
“Error”: “”,
“StartedAt”: “2021-04-18T13:02:27.531686409Z”,
“FinishedAt”: “0001-01-01T00:00:00Z”
},
“Image”: “sha256:300e315adb2f96afe5f0b2780b87f28ae95231fe3bdd1e16b9ba606307728f55”,
“ResolvConfPath”: “/var/lib/docker/containers/714c594e17487ada1024e6ed3da802d71d821cc6b6927e11bb9c4567cef408bd/resolv.conf”,
“HostnamePath”: “/var/lib/docker/containers/714c594e17487ada1024e6ed3da802d71d821cc6b6927e11bb9c4567cef408bd/hostname”,
“HostsPath”: “/var/lib/docker/containers/714c594e17487ada1024e6ed3da802d71d821cc6b6927e11bb9c4567cef408bd/hosts”,
“LogPath”: “/var/lib/docker/containers/714c594e17487ada1024e6ed3da802d71d821cc6b6927e11bb9c4567cef408bd/714c594e17487ada1024e6ed3da802d71d821cc6b6927e11bb9c4567cef408bd-json.log”,
“Name”: “/elastic_varahamihira”,
“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/a709c3503ecfea8f6e5660c8b9d55741c80e9deda6f3f5ec29790cab456c92ba-init/diff:/var/lib/docker/overlay2/cb10b343a94489ecbf43edbd225374d2b838d0e689b5de991c94ca59ff71246c/diff”,
“MergedDir”: “/var/lib/docker/overlay2/a709c3503ecfea8f6e5660c8b9d55741c80e9deda6f3f5ec29790cab456c92ba/merged”,
“UpperDir”: “/var/lib/docker/overlay2/a709c3503ecfea8f6e5660c8b9d55741c80e9deda6f3f5ec29790cab456c92ba/diff”,
“WorkDir”: “/var/lib/docker/overlay2/a709c3503ecfea8f6e5660c8b9d55741c80e9deda6f3f5ec29790cab456c92ba/work”
},
“Name”: “overlay2”
},
“Mounts”: [],
“Config”: {
“Hostname”: “714c594e1748”,
“Domainname”: “”,
“User”: “”,
“AttachStdin”: false,
“AttachStdout”: false,
“AttachStderr”: false,
“Tty”: false,
“OpenStdin”: false,
“StdinOnce”: false,
“Env”: [
“PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin”
],
“Cmd”: [
“/bin/sh”,
“-c”,
“while true;do echo tianqinhua sleep 100;done”
],
“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”: “a4eb972757d9b2daca37e748a115ab622bfb0d799a1cc1fdaba3fa1793e0617a”,
“HairpinMode”: false,
“LinkLocalIPv6Address”: “”,
“LinkLocalIPv6PrefixLen”: 0,
“Ports”: {},
“SandboxKey”: “/var/run/docker/netns/a4eb972757d9”,
“SecondaryIPAddresses”: null,
“SecondaryIPv6Addresses”: null,
“EndpointID”: “231124bc09d99d7014f7307a528ecd67cbb6ef80bd7dd91b162a6f7a162b4bfb”,
“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”: “7e86895ef17e6aaf6dd8983265ee9072e7b33469c25c27f9b967da33207a634b”,
“EndpointID”: “231124bc09d99d7014f7307a528ecd67cbb6ef80bd7dd91b162a6f7a162b4bfb”,
“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
}
}
}
}
]

进入当前正在运行的容

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

将容器内的文件拷贝到主机

命令:

docker cp e91e6e6e2db7:/home/test.java /home

在这里插入图片描述

小结:

在这里插入图片描述
docker一些帮助文档的命令:
在这里插入图片描述
**

docker 部署nginx

1.查找nginx镜像:
docker search nginx
2.下载镜像安装
docker pull nginx
3.启动并本机自测:
命令:docker run -d --name nginx03 -p 3344:80 nginx
-d :后台运行
–name:给启动的容器命名,可以启动多个容器分别命名
-p:给启动的nginx暴露端口; -p: 宿主机端口:容器内部端口
对应暴露端口原理关系:
在这里插入图片描述
要开放阿里的安全组端口:

内部网络访问:
在这里插入图片描述
外部访问测试:
在这里插入图片描述

可以进入容器查看部署的nginx的相关配置信息:
在这里插入图片描述

Docker 下载安装tomcat

docker官方文档查询:docker hub
$ docker run -it --rm tomcat:9.0
**这个命令一般用来测试,–rm用完即删
查看:docker ps -a 发现并没有记录,说明用完后即删了
在这里插入图片描述
#正式自己下载:
docker pull tomcat:9.0
下载成功启动运行容器
docker run -d --name tomcat01 -p 3355:8080 tomcat
#测试启动没问题,但是进入容器发现问题:
在这里插入图片描述

1.一些linux不完整;
2.webapps没有内是空的
原因:
阿里云镜像的原因:
默认提供的是最小镜像;保证最小可运行的环境;
#将wepapps.dist下的文件都拷贝到webapps的目录下
在这里插入图片描述
拷贝完成后在此访问tomcat 发现:
外网访问都是可以的:
在这里插入图片描述

思考问题:

不需要进入容器,在容器外部提供一个映射路径,webapps,在外部放置项目后,能够自动同步到容器内部?

docker 部署es+Kibana

部署es安装相关了解

#es 暴露的端口多

#es 十分耗内存

#es 的数据一般安置在安全的目录!挂载!

#首先查看下Docker hub 官网的elasticsearch

#启动es
docker run -d --name elasticsearch  -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" elasticsearch:7.6.2
#启动后linux服务器非常卡,因为es真的很大
#查看cpu的状态
docker stats

在这里插入图片描述
#查看是否安装成功

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

#关闭es,增加内存限制,修改配置文件,-e:环境配置修改

docker run -d --name elasticsearch04  -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" -e  ES_JAVA_OPTS="-Xms64m -Xmx512m" elasticsearch:7.6.2

增加内存先之后查看状态,发现内存限制起作用了

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

#kibana怎么链接es?

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

可视化

#portainer(暂时先用这个可视化面板),之后使用:Rancher(CI/CD)

docker run -d -p 8088:9000 --restart=always -v /var/run/docker.sock:/var/run/docker.sock --privileged=true portainer/portainer

#访问测试

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

#设置密码后选择 Local

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

![在这里插入图片描述](https://img-blog.csdnimg.cn/20210502170752224.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3RxaGhoaGhoMTIz,size_16,color_FFFFFF,t_7
在这里插入图片描述

#从可视化面板中可以看到,运行中的容器和已停止的容器,都可以可视化执行

当前只是运行两个容器,接下来用可视化启动nginx01

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tQiIoD1S-1619946255019)(C:\Users\天气好\AppData\Roaming\Typora\typora-user-images\image-20210502165928920.png)]
可以看到启动是可以的
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ydF4P4fF-1619946255021)(C:\Users\天气好\AppData\Roaming\Typora\typora-user-images\image-20210502170053542.png)]

Docker 镜像分层原理

#Docker 镜像都是只读的,当容器启动的时候,一个新的可写层就被加载到镜像的顶部;
这一层就是容器层,容器层之下的都是镜像层;
在这里插入图片描述
#commit 自己的镜像
docker commit 提交容器生成一个新的副本(镜像层+可写的容器层)
命令(类似git):
docker commit -m=“提交的描述信息” -a=“作者” 容器ID 容器镜像名:[TAG]

测试一下

初始化tomcat只有这两个版本的
在这里插入图片描述
#启动tomcat镜像
发现默认的是没有webapps内容的
在这里插入图片描述
#将webapps.dist的内容拷贝到 webapps内
在这里插入图片描述
#这就相当于我们改动了原镜像启动起来的容器,现在我们要commit这个改动的容器
在这里插入图片描述
#现在启动我们commit的新版本,进入容器发现就有存在我们修改过的容器的版本
在这里插入图片描述

容器数据卷

#Docker的理念回顾
将应用和环境打包成一个镜像;
那么容器的数据怎么存放呢?如果只是存放在我们启动起来的容器内,那么删除容器后数据即丢失,所以,我们需要将容器内产生的有用数据同步到容器外的我们的本地,即我们的宿主机linux的对应目录下;
容器之间有一个数据共享的技术,docker容器产生的数据同步到本地;
即 “数据卷” 就是目录的挂载。将docker容器的目录挂载到我们的linux上。
在这里插入图片描述
总之就一句话:数据卷就是实现容器的数据持久化和同步操作,容器间的数据是可以共享的

数据卷使用:
方式一:
使用命令挂载目录:-v
docker run -it -v 主机目录:容器目录
测试:
docker run -it -v /home/test2:/home/ centos /bin/bash
若是挂载失败:
touch: cannot touch ‘/var/jenkins_home/copy_reference_file.log’: Permission denied
Can not write to /var/jenkins_home/copy_reference_file.log. Wrong volume permissions?
需要修改下目录权限, 因为当映射本地数据卷时,/path/to/jenkins目录的拥有者为root用户,而容器中jenkins user的uid为1000。所以需要执行如下命令
chown -R 1000:1000 /tools/jenkins_home
那么也可以 给容器加上特权 --privileged=true
docker run -it -v /home/test2:/home/ centos --privileged=true /bin/bash
# Jenkins的案例
docker run -d --name jenkins_002 -p 6379:8080 -v /tools/jenkins_home/:/var/jenkins_home --privileged=true jenkins/jenkins
在这里插入图片描述
然后,到主机上面我们挂载的目录,即:test2的目录
在这里插入图片描述
在这里插入图片描述
可以看到,我们容器home目录下产生的数据或者文件就能同步到主机的挂载目录下,
查看容器的详细信息:docker inspect 37e1480d2cde
在这里插入图片描述
测试:现在停止容器,然后修改主机上的文件,再启动容器观察文件是否有发生同步
在这里插入图片描述
总结
通过这个容器数据卷我们就可以知道一个很大的好处,就是,我们不需要进入容器内部,只需要在我们主机本地修改即可同步到容器;
例如:一些配置信息:tomcat,nginx等等的一些配置;
-v 主机的nginx的/user/nginx/conf:/home/nginx/conf的配置文件同步

MySql 同步数据

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值