Apache Reverse Proxy NestJS/NodeJS
Using NestJS. It is easy to build a server-side application. But it's a bit troublesome to deploy. Because the files packaged by NestJS. There is no index.php/index.html file like in PHP projects or static HTML projects
To run NestJS applications behind Apache, you need to ensure that the NestJS application is listening on a port, and then configure Apache as a reverse proxy. Here is a basic Apache configuration example that proxies traffic to NestJS applications running on port 3000:
Firstly, make sure that your NestJS application is listening on a port, such as 3000.
In the Apache configuration file. Enable proxy_module and proxy_http_module
data:image/s3,"s3://crabby-images/8ca16/8ca168edac79882856d48e760c9801926b564312" alt=""
- Add reverse proxy configuration in site Apache VHost configuration file
<VirtualHost *:80>
...
ProxyPassMatch ^/.*$ http://localhost:3000
ProxyPassReverse ^/.*$ http://localhost:3000
...
</VirtualHost>
<VirtualHost *:443>
...
ProxyPassMatch ^/.*$ http://localhost:3000
ProxyPassReverse ^/.*$ http://localhost:3000
...
</VirtualHost>
data:image/s3,"s3://crabby-images/df2c3/df2c3c5eef6425a35baf52866775b78ec6b28b92" alt=""
data:image/s3,"s3://crabby-images/b463e/b463ebba7a05e421ccdb2da34af7e6836dfc637c" alt=""
- Restart Apache or reload Apache configuration
Now, when you access your server through a website domain, all requests will be forwarded by Apache to the NestJS application running on port 3000.