docker基础命令集合

网友投稿 255 2022-10-22

docker基础命令集合

docker镜像与容器

一、镜像操作

1、查找指定镜像

docker search 服务名 docker search centos

2、下载镜像

docker pull 服务名 docker pull cengtos

3、查看镜像信息

docker images docker inspect 镜像的ID 例: docker images docker inspect 5d0da3dc9764

4、添加新标签

docker tag 仓库名:原镜像名 仓库名:新镜像名 例如: docker tag centos:latest centos:test docker images docker images | grep centos

5、删除镜像

指定镜像ID删除的时候,要求不能有该镜像不能有标签

docker rmi 镜像的ID docker rmi 仓库名:镜像名 例如: docker rmi 5d0da3dc9764 docker images docker rmi centos:test docker images

6、将镜像存储到本机上,命名为nginx_latest

docker save -o 存放镜像的位置 仓库名:镜像名 例如: docker save -o /opt/nginx_latest nginx:latest

7、载入镜像

方法一: docker load < 本地导出的镜像名 方法二: docker --input 本地导出的镜像名 例如: docker load < nginx_latest docker load --input nginx_latest

8、上传镜像

将本地的镜像上传到公有的镜像仓库,要先登陆到镜像仓库 上传镜像前要修改标签,标签前面要加上Docker官网的账号名 标签格式: Docker官网的账号名/仓库名:镜像名 不过一般不会上传到公有仓库中,公司内部都使用私有仓库 私有云到后面再说

docker push [OPTIONS] NAME[:TAG] 例如:按照下面的流程就可以上传到公有云,有兴趣的可以上传 #改标签 docker tag 仓库名:镜像名 用户名/仓库名:镜像名 #登录 docker login Username: #用户名 Password: #密码 #上传 docker push 用户名/仓库名:镜像名

二、容器操作

1、查看容器的运行状态

容器状态
up 正在运行的容器
Exited (0) 正常停止的容器
Exited (非0) 异常停止的容器

docker ps #查看运行中的容器 docker ps -a #加-a 列出所有的容器,包括未运行的容器

2、创建容器

docker create [选项] 镜像运行的程序 -i:让容器的标准输入保持打开 -t:让Docker分配一个伪终端 例; docker create -it nginx:latest /bin/bash

-i 使用户可以在容器中输入
-t 分配终端,没有终端,容器无法运行

3、启动、停止、重启容器

docker start 容器ID:启动一个或多个已经被停止的容器 docker stop 容器ID:停止一个运行中的容器 docker restart 容器ID:重启容器 例: docker start 75defdf24307 docker ps -a docker stop 75defdf24307 docker ps -a docker restart 75defdf24307

4、运行容器

==run和start的作用有些类似,准确来说run相当于create+start==

==一般第一次可以使用run,后面维护还是使用start/stop/restart==

docker run [选项] 镜像 [命令] [变量] -d: 后台运行容器,并返回容器ID; -i: 以交互模式运行容器,通常与 -t 同时使用 -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用 -c 命令表示后面的参数将会作为字符串读入作为执行的命令 -v: 绑定一个卷 -P: 随机端口映射,容器内部端口随机映射到主机的端口 -p: 指定端口映射,格式为:主机(宿主)端口:容器端口 --name="名称": 为容器指定一个名称 --link name:alias 添加链接到另一个容器,格式“--link容器名:别名” 例如: docker run nginx docker run -d nginx docker run -d nginx /bin/bash -c "ls"

5、进入,退出容器

进入的容器状态一定要是运行状态

docker exec [选项] 容器 命令 例: docker exec -it 75defdf24307 /bin/bash docker exec -it f7396f53833a /bin/bash exit//退出容器

6、容器到处、导入

#容器导出 docker export 容器ID > 备份文件名 #容器导入(会生成镜像,而不会创建容器) cat 备份文件名 | docker import - 仓库名:镜像名 例如: docker export f7396f53833a > nginx_up docker export 75defdf24307 > nginx_exited cat nginx_up | docker import - nginx:web

7、删除容器

docker rm 容器ID 例如: docker rm 4d8dcf51a4ef //批量删除容器 docker ps -a | awk '{print "docker rm "$1}' | bash

三、私有仓库的操作

1、创建私有仓库

docker pull registry

==修改==

vim /etc/docker/daemon.json { "insecure-registries": ["192.168.89.129:5000"], 添加 "registry-mirrors": ["阿里云加速地址"] } systemctl restart docker.service docker create -it registry /bin/bash docker ps -a docker start 19e8f2ae8b57

2、挂载容器

宿主机的/data/registry自动创建挂载容器中的/tmp/registry

docker run -d -p 宿主机端口:容器内部端口 -v 宿主机目录:容器内目录 镜像 例: docker run -d -p 5000:5000 -v /data/registry:/tmp/registry registry

3、更改标记

更改标记为192.168.89.129:5000/nginx docker tag nginx:latest 192.168.89.129:5000/nginx

4、上传

docker push 192.168.89.129:5000/nginx

5、获取私有仓库列表

curl -XGET http://192.168.89.129:5000/v2/_catalog //显示上传成功 (""repositories":[""nginx"")

6、测试私有仓库下载

docker pull 192.168.89.129:5000/nginx

四、Docker数据卷和数据卷容器

在创建数据卷和数据卷容器的时候,如果挂载目录不存在,则会自动创建

1、数据卷

将宿主机目录/var/run -v /var/--name test -it centos:7 /bin/bash cd /data1/ touch test1111 返回宿主机进行查看 ls /var/www/

2、数据卷容器

//数据卷容器 docker run --name juan -v /data1 -v /data2 -it centos:7 /bin/bash //新容器挂载数据卷容器juan docker run -it --volumes-from juan --name test2 centos:7 /bin/bash

数据卷与数据卷容器的区别数据卷是挂载在宿主机上的数据卷容器是通过–volumes-from实现容器与容器之间的挂载

五、端口映射

docker run -d -P httpd:centos7 docker run -d -p 49280:80 httpd:centos7

六、容器互联(使用centos镜像)

//创建并运行容器取名web1,端口号自动映射 docker run -itd -P --name web11 centos:7 /bin/bash //创建并运行容器取名web2,链接到web1和其通信进web22容器 ping web1 docker run -itd -P --name web2 --link web1:web11 centos:7 /bin/bash --link name:alias --link容器名:别名

==小结==

镜像查找镜像(search)—上传(pull)、下载(push)—打标签(tag)—删除(rm)—导出(save)、导入(load) 容器查看(ps)—创建(create)—启动(start)、停止(stop)、重启(restart)—运行(run)—进入(exec)、退出(exit)—导入(import)、导出(export)—删除(rmi) 仓库下载registry镜像—>运行容器、暴露端口5000—>修改daemon.json文件—>重启docker挂载容器—>打标签—>上传—>查询—>下载

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Docker 文件系统-Devicemapper 原理解析(32)
下一篇:ThreadLocal 在上下文传值场景实践源码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~