Apache kann den PM2-Knotenprozess nicht sehen

Apache kann den PM2-Knotenprozess nicht sehen

Ich habe Apache unter Ubuntu 20 laufen und erhalte immer wieder diesen Fehler /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

Mein virtueller Host ist wie folgt eingerichtet:

<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>

In meinem Webverzeichnis ( /var/www/example.com) habe ich meine App mit pm2 wie folgt gestartet:

pm2 start index.js -p 4000

Wenn ich das tue, pm2 statussehe ich, dass mein Prozess online ist. Es liegen keine Fehler vor pm2 logs. Aus irgendeinem Grund kommunizieren Apache und pm2 nicht miteinander.

netstat -tulpnbestätigt, dass auf Port 4000 nichts lauscht.

Ich weiß nicht, was ich sonst tun soll. Irgendwelche Ideen?

Antwort1

Sie können den Port in PM2 nicht definieren -p, es gibt keine solche Option. Wahrscheinlich kann die Variable die Arbeit erledigen (wie Sie in Ihrem Kommentar erwähnen):

port=4000 pm2 start index.js

verwandte Informationen