帮助命令
docker version # 显示docker的版本信息
docker info # 显示docker的系统信息,包括镜像和容器的数量
docker 命令 —help # 帮助命令
镜像命令
dokcer images #查看当前系统上的镜像
docker search XXXXX #搜索镜像 这个是去 镜像库里去寻找
docker pull 镜像名[:tag] #下载镜像
docker pull mysql:5.7
docker rmi #删除镜像
docker rmi -f 镜像id # 删除指定的镜像
docker rmi -f 镜像id 镜像id 镜像id # 删除多个镜像(空格分隔)
docker rmi -f $(docker images -aq) # 删除全部的镜像
docker commit -m="提交的描述信息" -a="作者" 容器id 目标镜像名:[tag] #操作过的容器提交为一个镜像
容器命令
查看容器
docker ps #列出所有运行的容器
docker ps -a #列出所有的容器 运行过的 历史的 所有
通过镜像创建容器
docker run tomcat 这个命令是 以 tomcat 镜像 启动 容器,容器没有 命名 ,随机生成名字
新建容器并启动 docker run [可选参数] tomcat
[可选参数]
--name 容器名字:用来区分容器
-d 后台方式运行:相当于nohup
-it 使用交互式运行:进入容器查看内容
-p 指定容器的端口(四种方式)小写字母p
-v 数据卷挂载
-e 配置环境
docker run -d --name nginx01 -p 3344:80 nginx #后台启动nginx镜像取名nginx01 指定宿主机端口3344映射容器端口80
docker run -it tomcat /bin/bash #这个命令是 进去启动 并 进去 容器内部
退出容器内部
exit # 容器直接停止,并退出
ctrl+P+Q # 容器不停止,退出
删除容器
docker rm 容器id # 删除容器(不能删除正在运行的容器)如果要强制删除:docker rm -f 容器id
docker rm -f $(docker ps -aq) # 删除全部容器
docker ps -a -q|xargs docker rm # 删除所有容器
启动/停止容器
docker start 容器id # 启动容器
docker restart 容器id # 重启容器
docker stop 容器id # 停止当前正在运行的容器
docker kill 容器id # 强制停止当前容器
查看容器命令
docker logs -tf 625e6fabcdd5 #查看日志
docker logs -tf —tail 10 625e6fabcdd5 #十条最新的 日志
进入容器内部
docker exec -it 625e6fabcdd5 /bin/bash #进入当前正在运行的容器
docker attach 625e6fabcdd5
docker exec # 进入容器后开启一个新的终端,可以再里面操作(常用)
docker attach # 进入容器正在执行的终端,不会启动新的进程。
docker top 625e6fabcdd5 #查看容器中进程的信息
复制容器中文件
docker cp 容器id:容器内路径 目的主机的路径 #从容器内拷贝文件到主机上
其他命令
docker stats #查看docker应用占用cpu、内存情况
docker inspect 容器id #查看容器信息
数据卷挂载
docker run -v 主机目录:容器目录
#后台运行mysql5.7 挂载配置文件/数据文件到home下 设置密码123456 取名mysql01
docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
docker run -it -v /home centos /bin/bash #匿名数据卷挂在
docker run -it -v my-centos:/home centos /bin/bash #具名数据卷挂载
docker volume ls #查看数据卷
文件权限
ro(readonly):只读。
rw(readwrite):可读可写。
docker run -it -v /home/sail:/home:ro centos /bin/bash
docker run -it -v /home/sail:/home:rw centos /bin/bash
数据卷容器
docker run -it --name mysql02 --volumes-from mysql01 镜像id #docker02容器继承docker01容器实现docker01文件与docker02文件同步
Dockerfile脚本文件构建镜像
基本指令
FROM #基础镜像,开始
MAINTAINER #作者,姓名+邮箱
RUN #镜像构建的时候需要运行命令
ADD #添加压缩包
WORKDIR #镜像工作目录
VOLUME #挂载的目录
EXPOSE #指定暴露端口
CMD #指定容器启动时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT #指定容器启动时候要运行的命令,可以追加命令
ONBUILD #当构建一个被继承 DockerFile 这个时候就会出发这指令
COPY #类似ADD,将我们文件拷贝到镜像中
ENV #构建的时候设置环境变量
构建镜像
docker build -t ImageName:TagName dir
-t 给镜像加一个Tag
ImageName 给镜像起的名称
TagName 给镜像的Tag名
Dir Dockerfile所在目录
自定义网络
bridge 桥接模式(默认)
docker network
自定义网络
docker network create --driver bridge --subnet 10.1.0.0/16 --gateway 10.1.0.1 mynet
查看
docker network ls
docker network inspect mynet
docker run -d -P --name tomcat-net-01 --net mynet tomcat # --net mynet 指定网络mynet
docker run -d -P --name tomcat-net-02 --net mynet tomcat # 这样tomcat-net-01和tomcat-net-02可以互相ping通
网络联通
docker run -d -P --name tomcat01 tomcat
docker run -d -P --name tomcat02 tomcat
#tomcat01 和tomcat02默认在(docker0)172.17.0.0网段上(默认bridge模式)和tomcat-net-01、tomcat-net-02是在自定义10.1.0.0网段上 两个网段无法ping通
办法:
将网络与容器联通
docker network connect mynet tomcat01 (注:要想查看是否连通 docker network inspect mynet)
此时tomcat01网段由默认桥接网段(bridge-docker0)172.17.0.0网段上新增(自定义-mynet)10.1.0.0网段
这样就可以tomcat01容器就可以ping通tomcat-net-01/02容器