Docker run命令详解

2020-12-13 19:49:32

下面是docker run命令的一些详细解释翻译,使用用法

命令格式:docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
Usage: Run a command in a new container
中文意思为:通过run命令创建一个新的容器(container)

  • 常用选项说明

    • no:容器退出时不重启

    • on-failure:容器故障退出(返回值非零)时重启

    • always:容器退出时总是重启

    • bridge 使用docker daemon指定的网桥

    • host //容器使用主机的网络

    • container:NAME_or_ID >//使用其他容器的网路,共享IP和PORT等网络资源

    • none 容器使用自己的网络(类似--net=bridge),但是不进行配置

    • -d, --detach=false, 指定容器运行于前台还是后台,默认为false

    • -i, --interactive=false, 打开STDIN,用于控制台交互

    • -t, --tty=false, 分配tty设备,该可以支持终端登录,默认为false

    • -u, --user="", 指定容器的用户

    • -a, --attach=[], 登录容器(必须是以docker run -d启动的容器)

    • -w, --workdir="", 指定容器的工作目录

    • -c, --cpu-shares=0, 设置容器CPU权重,在CPU共享场景使用

    • -e, --env=[], 指定环境变量,容器中可以使用该环境变量

    • -m, --memory="", 指定容器的内存上限

    • -P, --publish-all=false, 指定容器暴露的端口

    • -p, --publish=[], 指定容器暴露的端口

    • -h, --hostname="", 指定容器的主机名

    • -v, --volume=[], 给容器挂载存储卷,挂载到容器的某个目录

    • --volumes-from=[], 给容器挂载其他容器上的卷,挂载到容器的某个目录

    • --cap-add=[], 添加权限,权限清单详见:http://linux.die.net/man/7/capabilities

    • --cap-drop=[], 删除权限,权限清单详见:http://linux.die.net/man/7/capabilities

    • --cidfile="", 运行容器后,在指定文件中写入容器PID值,一种典型的监控系统用法

    • --cpuset="", 设置容器可以使用哪些CPU,此参数可以用来容器独占CPU

    • --device=[], 添加主机设备给容器,相当于设备直通

    • --dns=[], 指定容器的dns服务器

    • --dns-search=[], 指定容器的dns搜索域名,写入到容器的/etc/resolv.conf文件

    • --entrypoint="", 覆盖image的入口点

    • --env-file=[], 指定环境变量文件,文件格式为每行一个环境变量

    • --expose=[], 指定容器暴露的端口,即修改镜像的暴露端口

    • --link=[], 指定容器间的关联,使用其他容器的IP、env等信息

    • --lxc-conf=[], 指定容器的配置文件,只有在指定--exec-driver=lxc时使用

    • --name="", 指定容器名字,后续可以通过名字进行容器管理,links特性需要使用名字

    • --net="bridge", 容器网络设置:

    • --privileged=false, 指定容器是否为特权容器,特权容器拥有所有的capabilities

    • --restart="no", 指定容器停止后的重启策略:

    • --rm=false, 指定容器停止后自动删除容器(不支持以docker run -d启动的容器)

    • --sig-proxy=true, 设置由代理接受并处理信号,但是SIGCHLD、SIGSTOP和SIGKILL不能被代理

示例

  • 运行一个在后台执行的容器,同时,还能用控制台管理:docker run -i -t -d ubuntu:latest

  • 运行一个带命令在后台不断执行的容器,不直接展示容器内部信息:docker run -d ubuntu:latest ping www.docker.com

  • 运行一个在后台不断执行的容器,同时带有命令,程序被终止后还能重启继续跑,还能用控制台管理,docker run -d --restart=always ubuntu:latest ping www.docker.com

  • 为容器指定一个名字,docker run -d --name=ubuntu_server ubuntu:latest

  • 容器暴露80端口,并指定宿主机80端口与其通信(: 之前是宿主机端口,之后是容器需暴露的端口),docker run -d --name=ubuntu_server -p 80:80 ubuntu:latest

  • 指定容器内目录与宿主机目录共享(: 之前是宿主机文件夹,之后是容器需共享的文件夹),docker run -d --name=ubuntu_server -v /etc/www:/var/www ubuntu:latest



  • 2019-10-08 14:09:57

    git创建分支并提交到远程分支

    远程分支的创建,一般都是基于本地分支的。即将本地的某个分支提交到远程,作为远程分支。命令如下:

  • 2019-10-09 13:38:20

    NPM依赖包版本号~和^和*的区别

    ~ 会匹配最近的小版本依赖包,比如~1.2.3会匹配所有1.2.x版本,但是不包括1.3.0 ^ 会匹配最新的大版本依赖包,比如^1.2.3会匹配所有1.x.x的包,包括1.3.0,但是不包括2.0.0 * 这意味着安装最新版本的依赖包

  • 2019-10-09 14:39:40

    import双反斜杠\\的意思

    ​ \表示引用根目录下面的PHPEXcel;不用\的话是引用当前目录下面的 PHPExcel

  • 2019-10-09 15:33:31

    nuxt,nuxtjs简单介绍以及使用

    在集成的服务器端框架之间进行选择: 选择您喜欢的 UI 框架: 选择您喜欢的测试框架: 选择你想要的 Nuxt 模式 (Universal or SPA) 添加 axios module 以轻松地将 HTTP 请求发送到您的应用程序中。 添加 EsLint 以在保存时代码规范和错误检查您的代码。 添加 Prettier 以在保存时格式化/美化您的代码。

  • 2019-10-10 00:21:35

    laravel 5.6以上日志理解及日志格式定义

    Laravel/Lumen的日志默认是基于Monolog进行了一层封装,如果要求不高,用起来还是十分容易的,本文基于laravel5.6/Lumen5.6版本进行解说。5.6版对日志系统做了升级,将日志的配置单独放以了config/logging.php 配置文件中,所以现在实用多了。

  • 2019-10-10 10:10:49

    @Scheduled注解各参数详解

    每隔5秒执行一次:*/5 * * * * ? 每隔1分钟执行一次:0 */1 * * * ? 每天23点执行一次:0 0 23 * * ? 每天凌晨1点执行一次:0 0 1 * * ? 每月1号凌晨1点执行一次:0 0 1 1 * ? 每月最后一天23点执行一次:0 0 23 L * ? 每周星期天凌晨1点实行一次:0 0 1 ? * L 在26分、29分、33分执行一次:0 26,29,33 * * * ? 每天的0点、13点、18点、21点都执行一次:0 0 0,13,18,21 * * ?

  • 2019-10-10 11:07:47

    Java8 - Map更优雅的迭代方式:forEach

    用于两个参数之间进行操作的函数式接口是 BiConsumer。这个函数式接口正好用来操作 Map 的 key 和 value。JDK8强化了针对 Map 类的迭代方式,新增了一个默认方法 forEach,它接收一个 BiConsumer 函数。JDK给出的描述如下: