赞
踩
仓库
存放镜像
,主机通过仓库下载镜像,通过镜像创建容器
仓库
仓库
镜像
容器
docker pull
拉取镜像
docker create
创建容器
docker rm
删除容器
docker ps
列出正在运行的容器列表
docker run
创建容器并运行指定命令
docker start
启动容器
docker stop
停止运行容器
docker restart
重启容器
docker rm
删除容器
docker exec
进入容器内部,容器执行指定命令
docker rmi
删除镜像
docker pull ubuntu //获取镜像
docker run -it ubuntu /bin/bash //启动容器
docker start <容器 ID> //启动一个已停止的容器
docker stop <容器 ID> //停止一个容器
docker rm -f <容器 ID> //删除容器
docker ps //查看正在运行的容器
runoob@runoob:~# docker ps
CONTAINER ID IMAGE PORTS NAMES
bf08b7f2cd89 training/webapp ... 0.0.0.0:5000->5000/tcp wizardly_chandrasekhar
d3d5e39ed9d3 training/webapp ... 0.0.0.0:32769->5000/tcp xenodochial_hoov
更多:Docker 命令大全
Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。
FROM
构建镜像基于哪个镜像
MAINTAINER
镜像维护者姓名或邮箱地址
RUN
构建镜像时运行的指令
CMD
容器启动的命令,如果有多个则以最后一个为准,也可以为 ENTRYPOINT 提供参数
VOLUME
指定容器挂载点到宿主机自动生成的目录或其他容器
USER
为RUN、CMD、和 ENTRYPOINT 执行命令指定运行用户
WORKDIR
为 RUN、CMD、ENTRYPOINT、COPY 和 ADD 设置工作目录,就是切换目录
HEALTHCHECH
健康检查
ARG
构建参数,与 ENV 作用一致。不过作用域不一样。ARG 设置的环境变量仅对 Dockerfile 内有效,也就是说只有 docker build 的过程中有效,构建好的镜像内不存在此环境变量。
EXPOSE
声明容器的服务端口(仅仅是声明)
ENV
设置容器环境变量
ADD
拷贝文件或目录到容器中,如果是URL或压缩包便会自动下载或自动解压
COPY
拷贝文件或目录到容器中,跟ADD类似,但不具备自动下载或解压的功能
ENTRYPOINT
运行容器时执行的 shell 命令
FROM cr.d.xm.net/container/xm_centos7:release MAINTAINER ldz <ldz@xm.com> RUN mkdir -p /home/work/bin/tmp # 复制应用程序 COPY devsecops_backend /home/work/bin # 复制配置文件 COPY config/local.toml /home/work/bin COPY config/staging.toml /home/work/bin COPY config/prod.toml /home/work/bin COPY config/preview.toml /home/work/bin # 暴露端口 EXPOSE 1416 # 打开工作目录 WORKDIR /home/work/bin # 执行命令 ENTRYPOINT [""]
例如,制作一个 centos 镜像
1.编写 Dockerfile,文件命名为 mydockerfile-centos
FROM centos:7.9.2009
MAINTAINER ldz ldz@whu.edu.cn
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim
RUN yum -y install net-tools
EXPOSE 80
CMD echo $MYPATH
CMD echo "-----end-----"
CMD /bin/bash
2.通过命令构建镜像 (最后有个 . )
// docker build -f dockerfile文件名 -t 镜像名:[tag] .
[root@ldz] docker build -f mydockerfile-centos -t mycentos:0.1 .
// 成功显示如下
Successfully built f29d77d79136
Successfully tagged mycentos:0.1
3.查看本地进行的变更历史(这一步骤可选)
4.启动容器
docker run -it mycentos:0.1
Kubernetes 是容器集群管理系统,是一个开源的平台,可以实现容器集群的自动化部署、自动扩缩容、维护等功能
可以。实际上一些小型公司,在业务不太复杂的情况下都是直接使用 Docker。
尽管 k8s 有很多好处,但是众所周知它非常复杂,业务比较简单可以放弃使用 k8s。
没有 Docker 可以使用 k8s 吗?
k8s 只是一个容器编排器,没有容器拿什么编排?!
k8s 经常与 Docker 进行搭配使用,但是也可以使用其他容器,如RunC、Containerted 等。
Docker Swarm 和 k8s 怎么选?
选 k8s。
2019年底Docker Enterprise已经出售给Mirantis,Mirantis声明要逐步淘汰Docker Swarm,后续会将 k8s 作为默认编排工具。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。