对美团的 LEGO-Agent 很感兴趣,并且要做一个功能弱化版的 LEGO-Agent,大家帮忙看看思路

2021-03-16 15:34:11 +08:00
 zhoudaiyu

美团刚发了一篇文章,是讲 Service Mesh 的(文章在此,https://tech.meituan.com/2021/03/08/octo-2.0-service-mesh.html ) 。这里面有个容器内运行的组件叫 LEGO-Agent https://sm.ms/image/NXrZc8zvFoJBMA6,我比较关心这个进程充当容器的父进程( 1 号进程)是怎么做到管理子进程的,难道就用命令行去做吗?比如杀一个子进程就用 kill,启动子进程就用./xxx.sh start 这么原始的方法吗?有什么更高级的控制进程的方式吗?我们的需求是写个程序作为 1 号进程去管理其他进程,包括启动一些进程,停止一些进程,并且能暴露出 API 供其他平台调用,不知道大家有什么想法吗?

1760 次点击
所在节点    Kubernetes
7 条回复
AstroProfundis
2021-03-16 16:02:44 +08:00
有个这个东西可能可以参考 https://github.com/just-containers/s6-overlay
wangkai123
2021-03-16 16:12:32 +08:00
systemd ?
zhoudaiyu
2021-03-16 16:15:37 +08:00
@AstroProfundis #1 十分感谢,但是一时没弄懂这个东西是做啥的。。
@wangkai123 #2 我看了 docker 官网推荐了 supervisord,systemd 和这个功能是类似的,但是我们可能还要操作一下暴露出的 API,systemd 好像没有( supervisord 有一些 API )
generic
2021-03-16 16:15:49 +08:00
很多选择。比如 supervisord 。
你想直接在容器里跑 systemd 也可以啊。podman 默认支持。docker 需要设置一下。
zhoudaiyu
2021-03-16 16:19:20 +08:00
@generic #4 比较骚的需求是这个管理进程要暴露 api,而且以后可能还得执行一些命令行的东西
generic
2021-03-16 16:26:50 +08:00
@zhoudaiyu systemd 有(dbus) api 。systemctl 就是通过它操作 systemd 的。
但是,显然 supervisord 简单得多。
zhoudaiyu
2021-03-16 16:30:56 +08:00
@generic #6 感谢,如果没有其他更好的管理方式,我就想用 supervisor 了,不想自己写这种玩意了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/762143

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX