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



  • 2018-12-04 15:30:01

    如何在Mac OS X上安装 Ruby运行环境

    ​ 对于新入门的开发者,如何安装 Ruby和Ruby Gems 的运行环境可能会是个问题,本页主要介绍如何用一条靠谱的路子快速安装 Ruby 开发环境。 此安装方法同样适用于产品环境!

  • 2018-12-04 15:31:15

    iOS--Pod install && Pod update

    许多人在最初接触CocoaPods时认为pod install只是在第一次为项目设置CocoaPods时使用,之后都应该使用pod update.看起来是这样,但也不是(But that's not the case at all.)。 这篇文章的目的就是教你啥时候用pod install,啥时候用pod update

  • 2018-12-04 15:33:19

    CocoaPods安装和使用教程

    当你开发iOS应用时,会经常使用到很多第三方开源类库,比如JSONKit,AFNetWorking等等。可能某个类库又用到其他类库,所以要使用它,必须得另外下载其他类库,而其他类库又用到其他类库,“子子孙孙无穷尽也”,这也许是比较特殊的情况。总之小编的意思就是,手动一个个去下载所需类库十分麻烦。另外一种常见情况是,你项目中用到的类库有更新,你必须得重新下载新版本,重新加入到项目中,十分麻烦。如果能有什么工具能解决这些恼人的问题,那将“善莫大焉”。所以,你需要 CocoaPods。

  • 2018-12-04 23:37:37

    pod install 和 pod update

    当我们新建一个Podfile文件运行后,会自动生成一个Podfile.lock文件,Podfile.lock文件里存储着我们已经安装的依赖库(pods)的版本。 当我们第一次运行Podfile时,如果对依赖库不指定版本的话,cocoapods会安装最新的版本,同时将pods的版本记录在Podfile.lock文件中。这个文件会保持对每个pod已安装版本的跟踪,并且锁定这些版本。

  • 2018-12-04 23:40:26

    pod删除已导入的第三方库和移除项目中的cocoapods

    CocoaPods是一个负责管理iOS项目中第三方开源库的工具。CocoaPods的项目源码在Github上管理。在我们有了CocoaPods这个工具之后,只需要将用到的第三方开源库放到一个名为Podfile的文件中,然后在命令行执行$ pod install命令。CocoaPods就会自动将这些第三方开源库的源码下载下来,并且为我的工程设置好相应的系统依赖和编译参数. 但是如果我们导入的某个第三方不适用,或者我们又不想使用该第三方,那我们又该如何将这些相关的东西从我们的项目中清理出去呢?

  • 2018-12-04 23:41:47

    制作自己的Pod库(公有/私有)

    目的:1.管理自己常用的类;2.组件化开发步骤:1.想一个比较酷的名字,在桌面简历文件夹。2.打开terminal,cd到这个文件夹下面,执行pod lib create  xxx(这里我们以JJCategoryKit为例子,下同)命令,如下图。这个过程会问几个问题,根据实际情况输入回答即可。这里我们选择添加demo,结束的时候会自动Lanuch这个app. 作者:深水日月 链接:https://www.jianshu.com/p/ece0b5721461 來源:简书 简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

  • 2018-12-05 06:08:26

    CocoaPods建立私有仓库 spec repo

    好多项目里都有公共的组件,copy来,copy去很容易出错,而且不容易维护,所以就想到用用cocoapods 建自己的私有库,Carthage用法虽然相对简单,但是它是把公共组件都放在framework里不容易单步调试,所以我还是选择用Cocoapods 来建立私有仓库 参考使用Cocoapods创建私有podspec

  • 2018-12-05 15:11:18

    为什么 Objective-C非常难

    作为一个Objective-C的coder,我总能听到一部 分人在这门语言上抱怨有很多问题。他们总在想快速学习这门语言来写一个App出来,但他们也总是联想到Objective-C看上去实在太难了或者在想这 些语法符号都是神马玩意?不错,他们问得非常好,所以本人也解释一下为什么很多程序员相比较学习Ruby或者Java很容易,但在决定开发iOS或者OS X应用时会那么犹豫。