docker process tree

简介:
使用sshd这个镜像来简单的介绍一下container和宿主机的进程树结构 : 
首先使用前面我们创建的sshd镜像, 启动一个container, 
http://blog.163.com/digoal@126/blog/static/1638770402014102711413675/
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE                COMMAND               CREATED             STATUS              PORTS               NAMES
74e5b4373374        digoal/sshd:latest   "/usr/sbin/sshd -D"   29 minutes ago      Up 29 minutes       22/tcp              digoal  

container对应的IP和PID如下 : 
[root@localhost ~]# docker inspect digoal
        "IPAddress": "172.17.0.22",
        "Pid": 8378,

登录到container, 并启动一个postgresql server, 便于查看进程结构.
[root@localhost ~]# ssh 172.17.0.22
root@172.17.0.22's password: 
Last login: Thu Nov 27 13:32:37 2014 from 172.17.42.1

在container内部, pid=1的进程是docker 的entrypoint或cmd执行的命令, 例如sshd的镜像执行的是sshd -D.
[root@74e5b4373374 ~]# ps -ewf|grep 1
root         1     0  0 13:32 ?        00:00:00 /usr/sbin/sshd -D

在container内启动的其他进程是继承自PID1的, 即sshd -D进程.
postmaster进程继承自sshd, postmaster的其他子进程继承自postmaster.

[root@74e5b4373374 ~]# ps -ewfjH|grep postgres
postgres   288     1   285     8  0 13:35 ?        00:00:00   /usr/bin/postgres
postgres   289   288   289   289  0 13:35 ?        00:00:00     postgres: logger process  
postgres   291   288   291   291  0 13:35 ?        00:00:00     postgres: checkpointer process  
postgres   292   288   292   292  0 13:35 ?        00:00:00     postgres: writer process  
postgres   293   288   293   293  0 13:35 ?        00:00:00     postgres: wal writer process  
postgres   294   288   294   294  0 13:35 ?        00:00:00     postgres: autovacuum launcher process  
postgres   295   288   295   295  0 13:35 ?        00:00:00     postgres: stats collector process 

在宿主机上看的话, container继承自docker server, container中的其他进程继承自container cmd或entrypoint调用.
# ps -ewfjH|grep postgres
root      4661     1  4661  4661  1 19:23 ?        00:02:14   /usr/bin/docker -d --selinux-enabled=false -g /data01/docker
root      8378  4661  8378  8378  0 21:32 ?        00:00:00     /usr/sbin/sshd -D
26        8840  8378  8837  8458  0 21:35 ?        00:00:00       /usr/bin/postgres
26        8841  8840  8841  8841  0 21:35 ?        00:00:00         postgres: logger process  
26        8843  8840  8843  8843  0 21:35 ?        00:00:00         postgres: checkpointer process  
26        8844  8840  8844  8844  0 21:35 ?        00:00:00         postgres: writer process  
26        8845  8840  8845  8845  0 21:35 ?        00:00:00         postgres: wal writer process  
26        8846  8840  8846  8846  0 21:35 ?        00:00:00         postgres: autovacuum launcher process  
26        8847  8840  8847  8847  0 21:35 ?        00:00:00         postgres: stats collector process

PID=1的进程是systemd(CentOS 7.x 是这样的)
root         1     0  0 19:03 ?        00:00:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 23

如果CentOS 6.x 是init进程 : 
root         1     0  0 Nov20 ?        00:00:02 /sbin/init

关于cgroup请参考
图例 : 
docker process tree - 德哥@Digoal - PostgreSQL research
 


[参考]
目录
相关文章
|
3月前
|
Unix Shell Linux
5-15|Docker报错OCI runtime exec failed: exec failed: unable to start container process: exec: “/bin/ba
5-15|Docker报错OCI runtime exec failed: exec failed: unable to start container process: exec: “/bin/ba
|
6月前
|
Unix Docker 容器
使用docker 启动naocs 报错出现:standard_init_linux.go:241: exec user process caused "exec format error"
```markdown Error in Docker container startup: "standard_init_linux.go:241: exec user process caused \"exec format error\"". Occurred at 2024-06-29 09:26:19.910, followed by a failed hook with a syslog delivery error at 09:27:20.193. Seeking solutions from experts. ```
|
7月前
|
Docker 容器
Docker服务启动失败报错:Job for docker.service failed because the control process exited with error code.
Docker服务启动失败报错:Job for docker.service failed because the control process exited with error code.
|
7月前
|
Kubernetes Docker 容器
Job for docker.service failed because the control process exited with error code.
Job for docker.service failed because the control process exited with error code.
286 0
|
15天前
|
运维 Cloud Native 虚拟化
一文吃透云原生 Docker 容器,建议收藏!
本文深入解析云原生Docker容器技术,涵盖容器与Docker的概念、优势、架构设计及应用场景等,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
一文吃透云原生 Docker 容器,建议收藏!
|
2天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
2天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
19 6
|
2天前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
13 5
|
2天前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
20 3
|
2天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
13 2