主机论坛_虚拟主机_美国主机_美国虚拟主机_云主机技术_全球主机交流聚集地—Web Hosting Talk 中文站

找回密码
立即注册
发新帖

0

收听

5

听众

991

主题
发表于 2022-1-26 17:13:16 | 查看: 63| 回复: 0

一、Docker镜像操作基础命令
[root@localhost ~]# docker search    镜像名称      //搜索镜像(在docker hub官网上进行查找)
[root@localhost ~]# docker pull 镜像名称           //下载镜像(如果不指定镜像标签默认下载最新版的镜像)
[root@localhost ~]# docker push 仓库名称/仓库账号/镜像名称         //上传镜像
[root@localhost ~]# docker images                 //查询本地下载的所有镜像
[root@localhost ~]# docker images 镜像名称         //查询指定的镜像
[root@localhost ~]# docker inspect    容器名称或容器ID       //查询镜像的详细信息
[root@localhost ~]# docker tag 原本的镜像名称及标签       生成以后的镜像名称及标签       //为本地镜像起一个新的名称、标签(源镜像还存在)
[root@localhost ~]# docker rmi  镜像名或镜像ID         //删除本地镜像
[root@localhost ~]# docker rmi  镜像名或镜像ID      //强制删除本地镜像
//注意:强制的这种方式适用于有容器正在使用这个镜像
//这种方式容器如果在运行时也是无法删除的,容器停止后删除的话,容器依然可以使用
[root@localhost ~]# docker save >     通过镜像生成的文件    镜像名称  
[root@localhost ~]# docker save -o   通过镜像生成的文件    镜像名称      //通过镜像生成新的镜像文件
[root@localhost ~]# docker load < 镜像文件
[root@localhost ~]# docker load --i 镜像文件        //将本地的镜像文件生成为镜像
//建议:“>”“<”号成对使用、“i”“o”成对使用
[root@localhost ~]# docker history 镜像名称
//查看生成镜像执行的历史命令
二、Docker容器操作基础命令
[root@localhost ~]# docker create -it --name 容器名称 使用的镜像 /bin/bash
//使用指定的镜像生成一个容器,并指定一个shell
常用选项解释如下:
-i:采用交互式的方式;
-t:分配一个伪终端;
-d:后台运行;
--name:指定容器名称
--restart=always:始终保持容器运行(随着docker的启动而启动)
[root@localhost ~]# docker ps            //查询本机正在运行的容器
[root@localhost ~]# docker ps    -a       //查询本机所有的容器,不管容器是否在运行
[root@localhost ~]# docker start 容器名称或容器ID          //启动容器
[root@localhost ~]# docker stop 容器名称或容器ID          //停止容器
[root@localhost ~]# docker restart 容器名称或容器ID          //重新启动容器
[root@localhost ~]# docker exec -it 容器名称或容器ID /bin/bash      //进入容器并分配一个可用的shell
[root@localhost ~]# docker attach dhcp               //也是进入容器
//如果是attach进入容器,使用exit退出的话这个容器也会关闭。
//使用ctrl+p  ctrl+q退出容器,并不会关闭这个容器,会保持容器的运行状态。
[root@localhost ~]# docker cp docker宿主机文件       docker容器的目录           //从本地上传文件到容器中
[root@localhost ~]# docker cp    docker容器名称:文件  docker宿主机文件       //将容器中的文件下载到本地
[root@localhost ~]# docker commit 容器名称  镜像名称及标签        
//通过容器生成镜像
[root@localhost ~]# docker run -itd --name registry --restart=always  -p 5000:5000 -v /registry:/var/lib/registry registry:2
//-p:端口映射(前面是宿主机端口:后面是容器暴露的端口)
//-v:挂载目录(前面是宿主机的目录:后面的是容器的目录)自动创建宿主机的目录
[root@localhost ~]# docker run -itd --name nginx 192.168.1.1:5000/centos:nginx nginx -g "daemon off;"
//创建容器,不进入容器即开启容器中的服务
[root@localhost ~]# docker logs  容器名称会容器ID            
//查看容器的日志,可以在后面加“-f”选项,动态输出
//如果没有内容输出则表示容器正常没有错误
[root@localhost ~]# docker inspect 容器名称     
//查看容器的详细信息
execattach两者的区别:
使用exec的方式进入容器,使用“exit”的方式退出容器后容器并不会停止;
使用attach的方式进入容器,使用“exit”的方式退出容器后容器便会停止;可以使用Ctrl + p 或者 Ctrl + q 组合键的方式退出容器后,并不会关闭这个容器;
exec方式:进入容器是会产生新的进程;
attach方式:进入容器不会产生新的进程;
以下方式生产环境不建议使用:
[root@localhost ~]# docker ps -a -q | xargs docker start       //启动本机所有容器
[root@localhost ~]# docker ps -a -q | xargs docker stop        //停止本机所有容器
[root@localhost ~]# docker ps -a -q | xargs docker restart     //重新启动本机所有容器
[root@localhost ~]# docker pa -a -q | xargs docker rm -f         //删除所有容器,相当于“rm -rf /*”
[root@localhost ~]# docker rm 容器名称或容器ID             //删除容器(容器是停止的状态)
[root@localhost ~]# docker rm 容器名称或容器ID  -f         //强制删除容器(容器是运行的状态)
三、docker Swarm群集常用命令
[root@node02 ~]# docker swarm leave
//那个节点想推出swarm群集,就在那台节点上执行这条命令
//节点自动退出swarm群集(相当于辞职)
[root@node01 ~]# docker node rm 节点名称
//manager主动删除节点(相当于开除)
[root@node01 ~]# docker node promote 节点名称
//将节点升级
[root@node01 ~]# docker node demote 节点名称
//将节点降级
[root@node01 ~]# docker node ls           
//查看swarm群集的信息(只可以在manager角色的主机上查看)
[root@node01 ~]# docker node update --availability drain 节点名称
//调整节点不参加工作
[root@node01 ~]# docker swarm join-token worker
//查看加入swarm群集的令牌(可以是worker也可以是manager
[root@node01 ~]# docker service scale web=4
//扩容、收缩swarn群集servie的数量(取决与群集原本的数量)
//比原本群集数量多,就是扩容,反之、收缩
[root@node01 ~]# docker service ls
//查看创建的service
[root@node01 ~]# docker service ps service的名称
//查看创建的service运行在那些容器上
[root@node01 ~]# docker service create --replicas 6  --name web -p 80:80 nginx
//指定运行的service副本数量
[root@node01 ~]# docker service create --replicas 3 --constraint node.hostname==node03 --name test nginx
//指定node节点,创建名为test的容器
[root@node01 ~]# docker node update --label-add mem=max node02
//以键值对的方式给docker02主机打上标签“mem=max”,等号两边的内容是可以自定义的
[root@node01 ~]# docker service create --name test1 --replicas 3 --constraint 'node.labels.mem==max' nginx
//基于nginx镜像在标签为“mem==max”的主机上运行3个名为test1的服务
[root@node01 ~]# docker node inspect node02
//标签相关的信息,在Spec{  }中有显示


云专线 海外专线 http://www.vecloud.com

收藏回复 显示全部楼层 道具 举报

您需要登录后才可以回帖 登录 | 立即注册

Archiver|手机版|小黑屋|WebHostingTalk中文站

GMT+8, 2024-5-3 15:51 , Processed in 0.068523 second(s), 23 queries .

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.

快速回复 返回顶部 返回列表