我是歌谣 放弃很难 但是坚持一定很酷 微信关注小歌谣一起学习
最近因为工作需要就要进行docker的一些相关学习
这边就整理了一小部分的笔记
方便一起学习 本文源自个人学习笔记
docker笔记
docker 教程方法
1.docker 的镜像和容器的基本操作
uname -r 查看系统的版本信息
docker version 查看是否安装成功
docker images --help
docker ps 查询正则运行的命令
docker ps -a 查询全部的容器
docker ps -n=1 显示 最近一个容器的
docker ps -q 只显示容器的编号
ctrl+p+q 容器退出不停止运行
docker 搜索
搜索星级大于3000
docker search mysql --filter=STARS=3000
docker pull mysql:5.7
docker 删除镜像
docker rmi -f 镜像id #删除指定的镜像
docker rmi -f 镜像id 镜像id #删除多个镜像
docker rmi -f $(docker images -aq) # 删除全部镜像
docker 容器
新建容器并启动
docker run [] image
#参数说明
–name=‘Name’ 容器名
-d 后台运行
-p 指定端口
-it 使用交互模式运行
启动并进行容器内
docker run -it centos /bin/bash
删除容器
docker rm 容器id #删除指定的容器,不能删除正则运行的容器
docker rm -f $(docker ps -aq) #删除所有容器
docker ps -a -q | xargs docker rm #删除所有容器
启动和停止容器
docker start 容器id
docker restart 容器id
docker stop 容器id
dokcer kill 容器id
docker stop 容器id
常用的其他命令
后台启动容器
docker run -d 镜像名 #比如加it可以视为前台命令
查看日志信息
docker logs
docker logs -f -t --tail 10 容器id
查看容器中的进程信息
docker top 容器id
查看容器的信息
docker inspect 容器id
进入当前正在运行的容器
docker exec -it 容器id /bin/bash #进图容器开启一个新的终端,可以在里面操作
docker attach 容器id #进入正在进行的容器内
从容器内拷贝到主机上
进入到容器内
docker cp 容器id:/home/文件名 /home /ubuntu
项目注意点
docker run -d --name nginx01 -p 3304:80 nginx
curl local:3304 # 本地运行测试
docker 配置es的命令
docker run -d --name elasticsearch -p 9200:9300 -e “discovery.type=single-node” -e ES_JAVA_OPTS="-Xms64m -Xmx51m" elasticsearch:7.6.2
commit 镜像
docker commit -a=‘sss’ -m=‘add web’ 容器id tomcat:1.0
2.容器数据卷
1.使用数据卷
方式一,直接使用命令挂载 -v
docker run -it -v /home/ceshi:/home ubutu /bin/bash
#挂载mysql
-d 后台运行
-p 端口
-v # 卷挂载
-e #环境配置
–name 容器的名字
docker run -d -p 3310:3306 -v /homge/ubuntu/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
2.具名和匿名挂载
匿名挂载
docker run -d -P --name nginx01 -v /etc/nginx nginx #-v 容器内路径,
具名挂载
docker volume ls
docker run -d -P --name nginx03 -v juming-Nginx:/etc/nginx nginx
3.初识dockerfile
dockerfile 就是用来构建docker 镜像构建文件,命令脚本,通过脚本可以生成镜像,镜像是一层一层的,脚本是一个个的命令
#创建一个dockerfile文件,名字随机,建议dockerfile
FROM centos
VOLUME [‘volume01’,‘volume02’]
CMD echo ‘–end —’
CMD /bin/bash
#运行
docker build -f /home/ubuntu/docker_test_volume/dockerfile -t jayson/ubuntu . # 后面是有点 . 代表当前的路径
docker 过个容器共用一个存储数据,称为数据卷容器
#主要是–volumes-from
docker run -it --name docker02 --volumes-from docker01 jayson_ubuntu
3.dockerfile制作镜像
1.dockerfile 构建过程
每个保留关键字都是必须大写字母
执行从上到下顺序执行
#表示注释
每一个指令都会创建提交一个新的镜像层,并提交
dockerfile都是面向开发的,我们以后发布项目,做镜像,都是编写dockerfile文件,文件十分简单
docker镜像逐渐成为企业交付的标准,必须掌握!
DokerFile :构建文件,定义了一切的步骤,源代码
Dockerimages:通过DockerFile构建生成的镜像,最终发布和运行产品
DockerFile的指令
FROM #基础镜像,一切从这里开始构建
MAINTAINER #镜像是谁写的,姓名+邮箱
ADD #步骤,tomcat镜像,添加内容
WORKDIR #镜像的工作目录
VOLUME # 挂载的目录
EXPOSE # 暴露的端口配置
CMD #指定容器启动时要运行的命令,只有一个最后的命令生效,可以被替代
ENTRYPOINT # 指的是容器启动时要运行的命令,可以追加
ONBUILD #当构建一个被继承的dockerfile,这时候会运行onbuild指令
COPY #类似于ADD,将文件拷贝到镜像当中
ENV #构建的时候设置环境变量
实战docker
创建一个centos,先创建文件
ubuntu@VM-0-4-ubuntu:~/dockerfile$ vi mydockerfile
ubuntu@VM-0-4-ubuntu:~/dockerfile$ cat mydockerfile
FROM centos
MAINTAINER jayson123@qq.com
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOST 80
CMD echo $MYPATH
CMD echo “–end–”
CMD /bin/bash
docker history 可以看到镜像的构建过程
CMD 和ENTRYPOINT的区别
3.docker 网络
ip addr
linux可以ping通docker容器内部
原理
evth-pair是linux虚拟设备接口,成对出现,,docker所有的网络接口都是虚拟的,
#可以通过ip进行ping通
docker exec -it tomat02 ping 172.18.0.3
如果通过非主机名直接ping通,需要通过–link
docker run -d -P --name tomcat03 --link tomcat02 tomcat
docker exec -it tomcat04 ping tomcat01
docker network ls#查看网络
#直接启动命令 --net bridge ,这个就是我们的docker0
docker run -d -P --name tomcat01 tomcat
docker run -d -P --name tomcat01 --net bridge tomcat
#docker0的特点默认,域名是不能访问,–link可以打通链接
#我们可以自定义一个网络
####下面是自己组建了一个网络,可以保持自己集群的健康,集群之间相互隔离
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet
#查询自己的网络
docker network ls
#加入到网络
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
2.网络连通
将容器和集群连接
docker network connect mynet tomcat01
原理是直接将容器的ip直接加入到自定义的网络当中,暴力计入
3.docker 建立redis集群实战
环境部署,三主三从,从的是备份机
docker network create redis --subnet 172.38.0.0/16
docker network ls
#创建集群配置文件
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
#启动服务
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
#第二个
docker run -p 6373:6379 -p 16373:16379 --name redis-3 -v /mydata/redis/node-3/data:/data -v /mydata/redis/node-3/conf/redis.conf:/etc/redis/redis.conf -d --net redis --ip 172.38.0.13 redis:5.0.9-alpine3.11 redis-server /etc/redis/redis.conf
e0ddd2844f8565575f3228ef16308828b14feb508e65dbc7c0eb8e02df870263
#一共启动了6个
#接下来创建集群
进入到sh
docker exec -it redis-01 /bin/sh
/data# redis-cli --cluster create 172.38.0.11:6379 172.38.0.12:6379 172.38.0.13:6379
172.38.0.14:6379 172.38.0.15:6379 172.38.0.16:6379 --cluster-replicas 1
#显示下面的结果表示成功
>>> 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: 8742bf66934ec467e43d74c9fd2c9c06d1b0adfe 172.38.0.11:6379
slots:[0-5460] (5461 slots) master
M: b9e11f701c7ca13eb9c35d1b786bd4f5c0fa0731 172.38.0.12:6379
slots:[5461-10922] (5462 slots) master
M: e5ae04bff43034f04f0dfa23ee66c4563160aa37 172.38.0.13:6379
slots:[10923-16383] (5461 slots) master
S: dba613da945914b339adf96a2a7fbc30fb01848e 172.38.0.14:6379
replicates e5ae04bff43034f04f0dfa23ee66c4563160aa37
S: 7858895f332bd68775267adf5c3530ab1172fa60 172.38.0.15:6379
replicates 8742bf66934ec467e43d74c9fd2c9c06d1b0adfe
S: 3472dc464937a645af57ece9a4ec8769ed6b2fa0 172.38.0.16:6379
replicates b9e11f701c7ca13eb9c35d1b786bd4f5c0fa0731
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: 8742bf66934ec467e43d74c9fd2c9c06d1b0adfe 172.38.0.11:6379
slots:[0-5460] (5461 slots) master
1 additional replica(s)
S: 7858895f332bd68775267adf5c3530ab1172fa60 172.38.0.15:6379
slots: (0 slots) slave
replicates 8742bf66934ec467e43d74c9fd2c9c06d1b0adfe
M: e5ae04bff43034f04f0dfa23ee66c4563160aa37 172.38.0.13:6379
slots:[10923-16383] (5461 slots) master
1 additional replica(s)
S: dba613da945914b339adf96a2a7fbc30fb01848e 172.38.0.14:6379
slots: (0 slots) slave
replicates e5ae04bff43034f04f0dfa23ee66c4563160aa37
S: 3472dc464937a645af57ece9a4ec8769ed6b2fa0 172.38.0.16:6379
slots: (0 slots) slave
replicates b9e11f701c7ca13eb9c35d1b786bd4f5c0fa0731
M: b9e11f701c7ca13eb9c35d1b786bd4f5c0fa0731 172.38.0.12:6379
slots:[5461-10922] (5462 slots) master
1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.