為什麼我的主管創建了很多相同的進程?

為什麼我的主管創建了很多相同的進程?

配置:

[program:aws-mysql]
command=ssh -NCf -L 13306:host1:3306 user@host2
directory=/var/www/ECAME
user=root
autorestart=true
exitcodes=0

地位:

# systemctl status supervisord.service
● supervisord.service - Process Monitoring and Control Daemon
   Loaded: loaded (/usr/lib/systemd/system/supervisord.service; enabled; vendor preset: disabled)
   Active: active (running) since Sun 2018-04-15 15:13:22 CST; 24min ago
  Process: 437 ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf (code=exited, status=0/SUCCESS)
 Main PID: 502 (supervisord)
   CGroup: /system.slice/supervisord.service
           ├─ 502 /usr/bin/python /usr/bin/supervisord -c /etc/supervisord.conf
           ├─1892 ssh -NCf -L 13306:host1:3306 user@host2
           ├─1926 ssh -NCf -L 13306:host1:3306 user@host2
           ├─1947 ssh -NCf -L 13306:host1:3306 user@host2
           ├─1967 ssh -NCf -L 13306:host1:3306 user@host2
           ├─1996 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2008 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2037 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2067 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2078 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2111 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2122 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2160 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2180 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2210 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2248 ssh -NCf -L 13306:host1:3306 user@host2
           ├─2260 ssh -NCf -L 13306:host1:3306 user@host2
           ... a lot of " ssh -NCf -L 13306:host2:3306 user@host2"

那麼,為什麼我supervisord要創造很多相同的流程呢?我想應該只有一個ssh -NCf -L 13306:host2:3306 user@host2

答案1

導師期望子進程留在前台:

打算在主管下運行的程序不應自行守護。相反,它們應該在前台運行。它們不應與啟動它們的終端分離。

ssh-f旗幟開始,意思是:

請求 ssh 在命令執行之前進入後台。

主管認為程式已關閉並在進行任何限制後啟動一個新實例。它將永遠這樣做。

如果刪除該-f標誌,它應該按預期工作。

相關內容