测试开发CICD——Docker——docker run —— 创建一个新的容器并运行一个命令...

==============================================================

docker run :创建一个新的容器并运行一个命令

 

语法

docker   run   [OPTIONS] IMAGE [COMMAND]  [ARG...]

OPTIONS说明:

 

 

 

栗子一

使用镜像 tomcat:7  ,容器命名为 tomcat7

docker run --name tomcat7 tomcat:7

这样运行,会直接将容器运行日志打印出来,所以一般都需要加 -d,否则无法继续敲其他命令

docker ps 看看容器

其实打印的日志就是 catalina.sh run 命令运行之后的日志

栗子二

  • 使用镜像 tomcat:7 
  • 以后台模式启动一个容器
  • 容器名字自定义为 tomcat7
docker run -d --name tomcat7 tomcat:7

创建容器之后还能执行其他命令,这样方便很多

栗子三

  • 使用镜像 tomcat:7 
  • 以后台模式启动一个容器
  • 将容器的 8080 端口映射到主机的随机端口
  • 容器名字自定义为 tomcat9999
docker run -d -P --name tomcat9999 tomcat:7

栗子四

  • 使用镜像 tomcat:7 
  • 以后台模式启动一个容器
  • 将容器的 8080 端口映射到主机的 9999 端口
  • 容器名字自定义为 tomcat7
docker run -d -p 9999:8080 --name tomcat7 tomcat:7

可以看到 PORTS 一列,主机的 9999 端口指向了容器的 8888 端口

栗子五

  • 使用镜像 tomcat:7 
  • 以后台模式启动一个容器
  • 将容器的 8080 端口映射到主机的 9999 端口
  • 容器名字自定义为 tomcat7
  • 主机的目录 /usr/local/tomcat/webapps 映射到容器的 /usr/local/tomcat/webapps 
  • 以后直接在主机的 webapps 目录上传 war 包,就能在浏览器访问对应的项目
 docker run -d -p 9999:8080 -i --name tomcat7 -v /usr/local/tomcat/webapps:/usr/local/tomcat/webapps tomcat:7

栗子六

  • 使用镜像 tomcat:7  
  • 以后台模式启动一个容器
  • 将容器的 8080 端口映射到主机的 111.20.72.43:8888 端口
  • 容器名字自定义为 tomcat77
  • 主机的目录 /usr/local/tomcat/webapp 映射到容器 /usr/local/tomcat/webapps  
  • 启动容器后,在容器内执行 bash 命令
  • 注意:这里不加 -it 的话,容器是无法再启动的,加上才能启动容器并执行 bash 命令
docker run -d -p 111.20.72.43:8888:8080 -v /usr/local/webapps:/usr/local/webapps -it --name tomcat77 tomcat:7 bash

栗子七

  • 容器 8080 端口映射到主机的 1111 端口
  •  -it 以交互模式启动一个容器,在容器内执行 bash 命令
  • 注意:如果这里加了 -d  参数,则不会进入容器的 CLI 界面;如果不加 bash 命令,则会执行 tomcat 容器本身自动会执行的命令( catalina.sh run ),也会进不了 CLI 界面,因为会打印一堆运行日志
docker run -it -p 1111:8080 tomcat:7 bash
不加 bash的执行结果

加 bash的执行结果

顺利进入容器的 CLI 界面,此时再去运行服务也是可以的

栗子八

以 root 权限创建容器,当进入容器之后,拥有 root 权限去执行命令

docker run -d --name jenkin2 --privileged=true jenkins/jenkins

虽然是拥有了 root 权限,但并不一定是 root 用户身份,所以最好加 -uroot 指定 root 用户身份

不加 --privileged 的小栗子

即使加了 -uroot ,指定了 root 用户身份,但并不是真正拥有 root 权限

总结
  • -uroot:是给了 root 用户身份,但并没有真正的 root 权限
  • --privileged:真正让当前用户有了 root 权限
  • 若想要最高的权限,两者可以结合使用

栗子九

该容器在 Docker 重启后会自动启动无需手动启动

docker run -d --name jenkins2 --restart always jenkins/jenkins

  1. 创建了两个容器:jenkins2、jenkins3
  2. 重启 docker 服务
  3. 再次查看正在运行的容器,只有 jenkins2

退出容器

exit         #容器直接退出
ctrl +P +Q  #容器不停止退出     ---注意:这个很有用的操作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值