原文出处:https://blog.csdn.net/qq_29303759/article/details/87639016
启动docker
systemctl start docker
守护进程重启
sudo systemctl daemon-reload
重启docker服务
systemctl restart docker
重启docker服务
sudo service docker restart
关闭docker
service docker stop
关闭docker
systemctl stop docker
避免输出Sudo
这里把当前用户加入到docker组就可以直接使用命令,而不用每次都加sudo
sudo groupadd docker
改完后需要重新登陆用户
sudo gpasswd -a ${USER} docker
Docker版本
sudo docker --version
当前Docker宿主机的信息
docker info
查看容器内部的进程信息
docker top [container]
查看正在运行的容器
?sudo docker ps
查看所有的容器
sudo docker ps -a
从指定image里生成一个container并在其中运行一个命令
docker run [image][cmd]
在container里运行交互式命令,比如shell
docker run -i -t [image][cmd]
例如
docker run -i -t ubuntu /bin/bash
在container里运行后台任务
docker run -d [image][cmd]
列出最近一个运行过的container
不加-l则只列出正在运行的container(比如后台任务)
docker ps -l
查看container详情
docker inspect [container]
删除某个container
其中container_id不需要输入完整,只要能保证唯一即可。
运行中的Docker容器是无法删除的,必须先通过docker stop或者docker kill命令停止。
docker rm [container]
docker rm `docker ps -a -q` #删除所有容器,-q表示只返回容器的ID
再次运行某个container
docker start [container]
查看某个container的运行日志
docker logs [container]
docker logs -f [container] 类似tailf
切换到后台任务container, 需要当前容器正常运行
注意:切换到后台任务以后无法用Ctrl-C退出
docker attach [container]
中止后台任务container
docker stop [container]
将container保存为一个image
docker push [image_name]
为容器指定名称,容器的名称是唯一
$ docker run --name edison -i -t ubuntu /bin/bash
有三种方式可以唯一指代容器
短UUID: 716d3c16dc65(12位)
长UUID:716d3c16dc654230ada14f555faadd036474231dfca0ca44b597574a5c618565(64位)
名称: edison
在容器中运行后台任务,只对正在运行的容器有效。
$ docker exec -d [container][cmd]
$ docker exec -d edison touch /home/haha
在容器中运行交付式任务,只对正在运行的容器有效。
$ docker exec -t -i edison /bin/bash
注:在/var/lib/docker中,可以查看Docker Image、Container和Volumes等细节信息。
进入一个已经启动的docker容器
docker attach ContainerID ,exit退出就会导致容器stop
docker exec -it ContainerID /bin/bash 这个命令exit退出,容器还在运行
查看本地镜像
sudo docker images
从镜像中运行/停止一个新实例
sudo docker run/stop containerID
搜索Docker Image
docker search tutorial
搜索网址是:index.docker.io [国内无法访问]
其他网址是:https://hub.docker.com/
通过docker命令下载tutorial镜像
docker pull learn/tutorial
删除images
docker rmi [image id]
原文出处:https://www.jianshu.com/p/10ed530766af
部分 | 命令 |
---|---|
基础镜像信息 | FROM |
维护者信息 | MAINTAINER |
镜像操作指令 | RUN、COPY、ADD、EXPOSE、WORKDIR、ONBUILD、USER、VOLUME等 |
容器启动时执行指令 | CMD、ENTRYPOINT |
1 FROM
指定哪种镜像作为新镜像的基础镜像,如:
FROM ubuntu:14.04
2 MAINTAINER
指明该镜像的作者和其电子邮件,如:
MAINTAINER vector4wang "xxxxxxx@qq.com"
3 RUN
在新镜像内部执行的命令,比如安装一些软件、配置一些基础环境,可使用\来换行,如:
RUN echo 'hello docker!' > /usr/local/file.txt
也可以使用exec格式RUN ["executable", "param1", "param2"]的命令,如:
RUN ["apt-get","install","-y","nginx"]
要注意的是,executable是命令,后面的param是参数
4 COPY
将主机的文件复制到镜像内,如果目的位置不存在,Docker会自动创建所有需要的目录结构,但是它只是单纯的复制,并不会去做文件提取和解压工作。如:
COPY application.yml /etc/springboot/hello-service/src/resources
注意:需要复制的目录一定要放在Dockerfile文件的同级目录下
原因:
因为构建环境将会上传到Docker守护进程,而复制是在Docker守护进程中进行的。任何位于构建环境之外的东西都是不可用的。COPY指令的目的的位置则必须是容器内部的一个绝对路径。
---《THE DOCKER BOOK》
5 ADD
将主机的文件复制到镜像中,跟COPY一样,限制条件和使用方式都一样,如:
ADD application.yml /etc/springboot/hello-service/src/resources
但是ADD会对压缩文件(tar, gzip, bzip2, etc)做提取和解压操作。
6 EXPOSE
暴露镜像的端口供主机做映射,启动镜像时,使用-P参数来讲镜像端口与宿主机的随机端口做映射。使用方式(可指定多个):
EXPOSE 8080
EXPOSE 8081
...
7 WORKDIR
在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录。如
WORKDIR /usr/local
WORKDIR webservice
RUN echo 'hello docker' > text.txt
...
最终会在/usr/local/webservice/目录下生成text.txt文件
8 ONBUILD
当一个包含ONBUILD命令的镜像被用作其他镜像的基础镜像时(比如用户的镜像需要从某为准备好的位置添加源代码,或者用户需要执行特定于构建镜像的环境的构建脚本),该命令就会执行。
如创建镜像image-A
FROM ubuntu
...
ONBUILD ADD . /var/www
...
然后创建镜像image-B,指定image-A为基础镜像,如
FROM image-A
...
然后在构建image-B的时候,日志上显示如下:
Step 0 : FROM image-A
Execting 1 build triggers
Step onbuild-0 : ADD . /var/www
...
9 USER
指定该镜像以什么样的用户去执行,如:
USER mongo
10 VOLUME
用来向基于镜像创建的容器添加卷。比如你可以将mongodb镜像中存储数据的data文件指定为主机的某个文件。(容器内部建议不要存储任何数据)
如:
VOLUME /data/db /data/configdb
注意:VOLUME 主机目录 容器目录
11 CMD
容器启动时需要执行的命令,如:
CMD /bin/bash
同样可以使用exec语法,如
CMD ["/bin/bash"]
当有多个CMD的时候,只有最后一个生效。
12 ENTRYPOINT
ENTRYPOINT作用和用法和CMD一模一样,区别:
1 CMD的命令会被 docker run 的命令覆盖而ENTRYPOINT不会
2 CMD和ENTRYPOINT都存在时,CMD的指令变成了ENTRYPOINT的参数,并且此CMD提供的参数会被 docker run 后面的命令覆盖
Docker 本地导入镜像/保存镜像/载入镜像/删除镜像
1.docker导入本地镜像
我们可以把本地的镜像导入,使用docker import 命令。
cat alibaba-rocketmq-3.2.6.tar.gz | docker import - rocketmq:3.2.6(镜像名自己定义)
注意镜像文件必须是tar.gz类型的文件。
2.保存镜像
使用docker save命令,保存镜像到本地。
?docker save -o rocketmq.tar rocketmq ##-o:指定保存的镜像的名字;rocketmq.tar:保存到本地的镜像名
称;rocketmq:镜像名字,通过"docker images"查看
然后可以通过ll查看到本地的rocketmq.tar文件
3.载入镜像
使用docker load将本地保存的镜像再次导入docker中
docker load --input rocketmq.tar 或 docker load < rocketmq.tar
4.删除镜像
docker rmi -f image_id ##-f:表示强制删除镜像;image_id:镜像id
镜像命名规则,是系统名+系统版本+服务名+服务版本:代码版本,比如我centos 6.5系统安装了nginx 1.4.7版本,放入代码是2.0版本,那么容器命令规则为centos6.5-nginx-1.4.7:2.0
.
原文:https://www.cnblogs.com/mrlwc/p/12083830.html