今天部署一個(gè)項(xiàng)目的時(shí)候,使用了腳本在機(jī)器上啟動(dòng)了項(xiàng)目,但是上去機(jī)器上,用sudo pm2 ls查看的時(shí)候,卻發(fā)現(xiàn)返回的進(jìn)程列表是空的。但是項(xiàng)目又真的已經(jīng)啟動(dòng)且可訪問?,F(xiàn)象就是項(xiàng)目已經(jīng)啟動(dòng),但是在pm2卻看不到這個(gè)項(xiàng)目,找了很久的問題,終于在github的一個(gè)issue找到了原因。
原因就是腳本啟動(dòng)項(xiàng)目的時(shí)候,重新開了一個(gè)PM2 God Daemon進(jìn)程,跟我用sudo看的PM2 進(jìn)程不是同一個(gè):
ps aux | grep pm2
root 16281 0.0 0.1 686328 50708 ? Ssl Aug25 0:26 PM2 v4.4.0: God Daemon (/root/.pm2)
root 24513 1.8 0.1 605484 41308 ? Ssl 19:54 0:00 PM2 v4.4.0: God Daemon (/data/services/pm2home/)
第一個(gè)God Daemon是使用sudo時(shí)查看的PM2,腳本使用的是第二個(gè)God Daemon
如何查看同一臺(tái)機(jī)器上的PM2實(shí)例
實(shí)際上,這是PM2提供的一個(gè)功能,允許用戶在同一臺(tái)機(jī)器上生成多個(gè)PM2 實(shí)例。要查看不同實(shí)例下PM2管理的進(jìn)程,可以使用:
sudo PM2_HOME=/data/services/pm2home/ pm2 ls
這樣,第二個(gè)PM2實(shí)例的項(xiàng)目就可以被打印出來了。
至于為什么腳本控制pm2啟動(dòng)的進(jìn)程會(huì)重新開啟一個(gè)PM2實(shí)例, 而不是使用/root/.pm2這個(gè)就還需要再研究下。否則其他人維護(hù)項(xiàng)目的時(shí)候,使用sudo pm2 ls卻看不到進(jìn)程可能會(huì)引起困惑。
參考資料:
multiple-pm2-on-the-same-server
Apps not showing on list #992