前言:
docker技术应该是每个后端开发人员都需要掌握的知识,熟练掌握docker的常见命令十分必要。
docker常见指令部分转载于网络
作者: DeepInThought
出处: https://www.cnblogs.com/DeepInThought
##查看docker容器版本 docker version ##查看docker容器信息 docker info ##查看docker容器帮助 docker --help2、镜像操作 2、1镜像查看
##列出本地images docker images ##含中间映像层 docker images -a ##只显示镜像ID docker images -q ##含中间映像层 docker images -qa ##显示镜像摘要信息(DIGEST列) docker images --digests ##显示镜像完整信息 docker images --no-trunc ##显示指定镜像的历史创建;参数:-H 镜像大小和日期,默认为true;--no-trunc 显示完整的提交记录;-q 仅列出提交记录ID docker history -H redis2、2镜像搜索
##搜索仓库MySQL镜像 docker search mysql ## --filter=stars=600:只显示 starts>=600 的镜像 docker search --filter=stars=600 mysql ## --no-trunc 显示镜像完整 DEscriptION 描述 docker search --no-trunc mysql ## --automated :只列出 AUTOMATED=OK 的镜像 docker search --automated mysql2、3镜像下载
##下载Redis官方最新镜像,相当于:docker pull redis:latest docker pull redis ##下载仓库所有Redis镜像 docker pull -a redis ##下载私人仓库镜像 docker pull bitnami/redis2、4镜像删除
##单个镜像删除,相当于:docker rmi redis:latest docker rmi redis ##强制删除(针对基于镜像有运行的容器进程) docker rmi -f redis ##多个镜像删除,不同镜像间以空格间隔 docker rmi -f redis tomcat nginx ##删除本地全部镜像 docker rmi -f $(docker images -q)2、5镜像构建
##(1)编写dockerfile cd /docker/dockerfile vim mycentos ##(2)构建docker镜像 docker build -f /docker/dockerfile/mycentos -t mycentos:1.13、容器操作 3、1容器启动
##新建并启动容器,参数:-i 以交互模式运行容器;-t 为容器重新分配一个伪输入终端;--name 为容器指定一个名称 docker run -i -t --name mycentos ##后台启动容器,参数:-d 已守护方式启动容器 docker run -d mycentos ##启动一个或多个已经被停止的容器 docker start redis ##重启容器 docker restart redis3、2容器进程
##top支持 ps 命令参数,格式:docker top [OPTIONS] ConTAINER [ps OPTIONS]
##列出redis容器中运行进程
docker top redis
##查看所有运行容器的进程信息
for i in `docker ps |grep Up|awk '{print $1}'`;do echo &&docker top $i; done
3、3容器日志
##查看redis容器日志,默认参数 docker logs rabbitmq ##查看redis容器日志,参数:-f 跟踪日志输出;-t 显示时间戳;--tail 仅列出最新N条容器日志; docker logs -f -t --tail=20 redis ##查看容器redis从2019年05月21日后的最新10条日志。 docker logs --since="2019-05-21" --tail=10 redis3、4容器的进入与退出
##使用run方式在创建时进入 docker run -it centos /bin/bash ##关闭容器并退出 exit ##仅退出容器,不关闭 快捷键:Ctrl + P + Q ##直接进入centos 容器启动命令的终端,不会启动新进程,多个attach连接共享容器屏幕,参数:--sig-proxy=false 确保CTRL-D或CTRL-C不会关闭容器 docker attach --sig-proxy=false centos ##在 centos 容器中打开新的交互模式终端,可以启动新进程,参数:-i 即使没有附加也保持STDIN 打开;-t 分配一个伪终端 docker exec -i -t centos /bin/bash ##以交互模式在容器中执行命令,结果返回到当前终端屏幕 docker exec -i -t centos ls -l /tmp ##以分离模式在容器中执行命令,程序后台运行,结果不会反馈到当前终端 docker exec -d centos touch cache.txt3、5查看容器
##查看正在运行的容器
docker ps
##查看正在运行的容器的ID
docker ps -q
##查看正在运行+历史运行过的容器
docker ps -a
##显示运行容器总文件大小
docker ps -s
##显示最近创建容器
docker ps -l
##显示最近创建的3个容器
docker ps -n 3
##不截断输出
docker ps --no-trunc
##获取镜像redis的元信息
docker inspect redis
##获取正在运行的容器redis的 IP
docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' redis
3、6容器的停止与删除
##停止一个运行中的容器 docker stop redis ##杀掉一个运行中的容器 docker kill redis ##删除一个已停止的容器 docker rm redis ##删除一个运行中的容器 docker rm -f redis ##删除多个容器 docker rm -f $(docker ps -a -q) docker ps -a -q | xargs docker rm ## -l 移除容器间的网络连接,连接名为 db docker rm -l db ## -v 删除容器,并删除容器挂载的数据卷 docker rm -v redis3、7生成容器
##基于当前redis容器创建一个新的镜像;参数:-a 提交的镜像作者;-c 使用Dockerfile指令来创建镜像;-m :提交时的说明文字;-p :在commit时,将容器暂停 docker commit -a="DeepInThought" -m="my redis" [redis容器ID] myredis:v1.13、8容器与宿主机间的数据拷贝
##将rabbitmq容器中的文件copy至本地路径 docker cp rabbitmq:/[container_path] [local_path] ##将主机文件copy至rabbitmq容器 docker cp [local_path] rabbitmq:/[container_path]/ ##将主机文件copy至rabbitmq容器,目录重命名为[container_path](注意与非重命名copy的区别) docker cp [local_path] rabbitmq:/[container_path]常用指令汇总:
docker pull ${ConTAINER NAME} #拉取镜像
docker images #查看本地所有镜像
docker ps #查看所有正在运行的容器,加-q返回id
docker ps -a #查看所有容器,加-q返回id
docker rmi ${IMAGE NAME/ID} #删除镜像
docker rm ${ConTAINER NAME/ID} #删除容器
docker save ${IMAGE NAME} > ${FILE NAME}.tar #将镜像保存成文件
docker load < ${FILE NAME}.tar #从文件加载镜像
docker start ${ConTAINER NAME/ID} #运行一个以前运行过的容器
docker stop ${ConTAINER NAME/ID} #停止一个正在运行的容器
docker logs ${ConTAINER NAME/ID} #显示运行容器的日志
docker run... #运行一个容器
--name ${container name} #设置容器名称
-p ${host port}:${container port} #映射主机和容器内的端口
-e ${env name}=${env value} #添加环境变量
-d #后台运行
-v ${host folder path}:${container folder path} #将主机目录挂在到容器内
##高级指令
# Advance use
docker ps -f "status=exited" #显示所有退出的容器
docker ps -a -q #显示所有容器id
docker ps -f "status=exited" -q #显示所有退出容器的id
docker restart $(docker ps -q) #重启所有正在运行的容器
docker stop $(docker ps -a -q) #停止所有容器
docker rm $(docker ps -a -q) #删除所有容器
docker rm $(docker ps -f "status=exited" -q) #删除所有退出的容器
docker rm $(docker stop $(docker ps -a -q)) #停止并删除所有容器
docker start $(docker ps -a -q) #启动所有容器
docker rmi $(docker images -a -q) #删除所有镜像
docker exec -it ${ConTAINER NAME/ID} /bin/bash #进入容器内
docker exec -it ${ConTAINER NAME/ID} ping ${ConTAINER NAME/ID} #一个容器ping另外一个容器
docker top ${ConTAINER NAME/ID} #显示一个容器的top信息
docker stats #显示容器统计信息(正在运行)
docker stats -a #显示所有容器的统计信息(包括没有运行的)
docker stats -a --no-stream #显示所有容器的统计信息(包括没有运行的) ,只显示一次
docker stats --no-stream | sort -k8 -h #统计容器信息并以使用流量作为倒序
docker system
docker system df #显示硬盘占用
docker system events #显示容器的实时事件
docker system info #显示系统信息
docker system prune #清理文件
Docker安装常见容器
创建mysql5.7容器:
docker run -id -p 3306:3306 --name=new_mysql -v $PWD/mysql5.7/conf:/etc/mysql/conf.d -v $PWD/mysql5.7/logs:/logs -v $PWD/mysql5.7/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
配置mysql文件:
// 在文件末尾添加以下字段,此时我默认编码格式为utf8,如果用GBK自己改即可 [mysql] default-character-set=utf8mb4 [mysqld] character_set_server=utf8mb4 init_connect='SET NAMES utf8' lower_case_table_names = 1// 保存配置文件,并使用exit命令退出mysql容器创建tomcat容器:
docker run -id -p 8080:8080 --name=c_tomcat -v $PWD:/usr/local/tomcat/webapps tomcat:9.0创建redis容器:
docker run -id --name=new_redis -p 6379:6379 -v $PWD/redis/redis.conf:/etc/redis/redis.conf -v $PWD/redis/data:/data --requirepass torlesse123 redis:latest #备注 --requirepass失效时先创建容器后设置密码 为现有的redis创建密码或修改密码的方法: 1.进入redis的容器 docker exec -it 容器ID bash 2.进入redis目录 cd /usr/local/bin 3.运行命令:redis-cli 4.查看现有的redis密码:config get requirepass 5.设置redis密码config set requirepass ****(****为你要设置的密码) 6.若出现(error) NOAUTH Authentication required.错误,则使用 auth 密码 来认证密码创建宝塔镜像:
#宝塔镜像创建 docker run -i -t -d --name=baota -p 20:20 -p 21:21 -p 80:80 -p 443:443 -p 888:888 -p 8888:8888 -p 3306:3306 --privileged=true -v /home/www:/www centos



