首页 > 系统相关 >将docker容器作为进程来使用

将docker容器作为进程来使用

时间:2023-01-30 17:33:11浏览次数:55  
标签:容器 run 命令 前台 进程 docker


1. 容器只是一个进程

使用docker部署一个mysql服务,或者一个nginx服务,这些服务是持久存在的,加上环境的隔离特性,我一直都将docker容器的使用限定在容器这个范围内。在容器内,启动某个程序对外提供服务。

但本质上,容器相对于宿主机,不过是一个进程而已。用进程的视角去看待它,我突然有了一个想法,或许早已经有人在这样做,或许我的这个思路存在一些问题,如果你对此有自己的经验和看法,欢迎你能够与我交换意见。

我的想法很简单,对于一些任务,或者一些命令,如果执行他们需要特定的环境,那么就可以将这个环境制作成docker 镜像,需要执行命令或启动任务时,启动容器,待任务或者命令执行结束后,容器自然也会退出。

前面所说的命令,你可以理解为类似spark-submit这样的命令,它需要spark环境的支持,任务,可以是一个可执行程序,一个pyhton脚本,或者一个jar包,任务不是持久存在的,任务完成进程也就随之结束。这样的思路正是想利用docker容器技术所带来的环境隔离,尤其在生产环境,一旦两个程序所依赖的环境有冲突,使用docker很容易就能够解决。

想要将想法变为现实,有两个问题需要解决:

  1. 在宿主机上获得容器内前台进程的标准输出
  2. 容器退出状态码必须和前台进程的退出状态码保持一致

2. 前台进程

容器内部必须有一个前台进程,否则容器就会退出,在使用容器部署nginx等其他服务时,都必须指定前台运行参数。

在宿主机运行前台进程时,进程的输出内容,都会输出到你的屏幕上。容器里所运行的前端进程的标准输出,你在进入容器后是看不到的,但在宿主机里,可以通过docker logs container_id 来查看。如果在使用docker run 命令启动容器时,不使用-d选项,那么docker run 启动的容器于你而言就是前台进程,容器内前台进程的标准输出会成为容器的标准输出,这样,在宿主机上,就获得了容器内前台进程的标准输出。

这份标准输出是十分有必要获得的,你可能需要根据这份标准输出来对程序的运行状态进行判断。

标准输出的问题解决了,接下来要看容器的退出状态码和容器内前台进程的退出状态码是否保持一致。先说结论,两者一致,如果不一致,那么利用docker容器执行命令或者任务的想法就是不可实施的,原因在于,需要通过这个状态码来判断命令是否被正确执行。

(base) [root]# docker run -it --rm --name test_exit centos:7 ls /root
anaconda-ks.cfg
(base) [root]# echo $?
0

ls /root 是可以被正确执行的,这个命令的退出状态码是0, 使用echo $?命令查看的是最近一条命令(docekr run)的退出状态码,也是0。接下来验证命令无法正常执行的情况

(base) [root]# docker run -it --rm --name test_exit centos:7 ls /rootsdf
anaconda-ks.cfg
(base) [root]# echo $?
2

/rootsdf 是不存在的目录,ls 不能正常执行,退出码是2,docker run命令的退出码也是2,由此可以证明,docker run 退出的状态码就是容器内前台进程的退出状态码。除此外,还有一些状态码需要关注

状态码

描述

0

正常退出

非0

表示异常退出(退出状态码采用 chroot 标准)

125

Docker 守护进程本身的错误

126

容器启动后,要执行的默认命令无法调用

127

容器启动后,要执行的默认命令不存在

137

表明容器收到了 SIGKILL 信号,进程被杀掉,对应kill -9

139

表明容器收到了 SIGSEGV 信号,无效的内存引用,对应kill -11

143

表明容器收到了 SIGTERM 信号,终端关闭,对应kill -15

两个问题都得到了解决,那么在此思路下,启动某个命令或者某个任务,就变成了使用docker run 启动一个docker容器,命令或任务结束后,docker容器也就退出,通过查看docker run 命令的退出码就可以知道命令或任务是否正确执行。


标签:容器,run,命令,前台,进程,docker
From: https://blog.51cto.com/u_15948370/6027508

相关文章

  • python web框架多进程部署下数据库连接问题
    python常用的web框架,诸如flask,django,在生产部署时,都会选择多进程的部署方式,选用的中间件多为uwsgi或者gunicorn。如果项目里使用了数据库,那么就要考虑数据库连接在多进程下......
  • 【Amadeus原创】centos7安装docker
    ​1.installDocker.sh,然后自行安装#安装所需资源包sudoyuminstall-yyum-utils#设置docker下载地址sudoyum-config-manager\--add-repo\https://down......
  • 使用证书连接远端docker daemon
    生成证书#!/bin/bash#创建DockerTLS证书#相关配置信息SERVER="{{此处替换为服务器ip,如114.2.1.2}}"PASSWORD="mimamimamiamamdmd"COUNTRY="CN"STATE="广东......
  • docker+Jmeter实现分布式压测
    1、先编写一个基础dockerFile命名:jmbase#UseJava8slimJREFROMopenjdk:8-jre-slimMAINTAINERQJP#JMeterversionARGJMETER_VERSION=5.3#Installfewut......
  • Docker搭建本地仓库
    一、搭建本地私有仓库有时候使用DockerHub这样的公共仓库可能不方便,这种情况下用户可以使用registry创建一个本地仓库供私人使用,这点跟Maven的管理类似。使用私有仓库有......
  • 部署docker
    #安装docker#参考文档如下#https://docs.docker.com/install/linux/docker-ce/centos/#https://docs.docker.com/install/linux/linux-postinstall/#系统版本CentOS......
  • Docker 容器添加自定义root ca
    比如如果我们基于了step-ca工具做为我们的ca机制,就会有不可信的问题,业务使用就特别不方便了,以下是一个参考配置实际上很简单就是使用update-ca-certificates更新信息参......
  • Docker第一章:Docker理念与安装配置
    什么是DockerDocker是基于Go语言实现的云开源项目,本身是一个容器运行载体或称之为管理引擎。Docker的主要目标是通过对应用组件的封装、分发、部署、运行等生命周期的管......
  • python进程绑定CPU的意义
    1.绑定CPU后对计算密集型的任务可能会一定程度上提升运算性能:(小幅度的性能提升,甚至小幅度落后,总之就是差别不大)对比1代码A:importosfrommultiprocessingimportProcessfr......
  • python进程绑定CPU的一些Demo
    从​​中知道如何对python进程设置CPU绑定,本文对此进行一些延伸,给出一些例子:代码1:importosfrommultiprocessingimportProcessimporttimecpu_avia=os.sched_getaffini......