Apache не видит процесс узла PM2

Apache не видит процесс узла PM2

У меня Apache запущен на Ubuntu 20, и я постоянно получаю эту ошибку /var/logs/apache2/error.log:

[proxy:error] [pid 7064] (111)Connection refused: AH00957: http: attempt to connect to 127.0.0.1:4000 (127.0.0.1) failed

[proxy_http:error] [pid 7064] [client ...] AH01114: HTTP: failed to make connection to backend: 127.0.0.1

Мой виртуальный хост настроен следующим образом:

<IfModule mod_ssl.c>
<VirtualHost *:443>
    ServerAdmin [email protected]
    ServerName example.com
    ServerAlias www.example.com
    DocumentRoot /var/www/example.com
    ErrorLog ${APACHE_LOG_DIR}/error.log
    CustomLog ${APACHE_LOG_DIR}/access.log combined

RewriteEngine on

# Reverse Proxy Stuff for Node
ProxyPreserveHost On
ProxyPass / http://127.0.0.1:4000/ Keepalive=On
ProxyPassReverse / http://127.0.0.1:4000/ Keepalive=On

SSLCertificateFile /etc/letsencrypt/live/example.com/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/example.com/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
</IfModule>

В моем веб-каталоге ( /var/www/example.com) я запустил свое приложение с pm2 следующим образом:

pm2 start index.js -p 4000

Когда я это делаю, pm2 statusя вижу, что мой процесс в сети. Ошибок в pm2 logs. Каким-то образом Apache и pm2 не общаются друг с другом.

netstat -tulpnподтверждает, что порт 4000 никто не прослушивает.

Я не знаю, что еще делать. Есть идеи?

решение1

Вы не можете определить порт -pв PM2, такой опции нет. Вероятно, переменная может сделать эту работу (как вы упоминаете в своем комментарии):

port=4000 pm2 start index.js

Связанный контент