2017-12-16 13:25:59 +01:00
|
|
|
---
|
|
|
|
id: reverse-proxy
|
|
|
|
title: "Reverse Proxy Setup"
|
|
|
|
---
|
2017-06-24 09:26:10 +02:00
|
|
|
|
|
|
|
## Apache
|
|
|
|
|
|
|
|
Apache and mod_proxy should not decode/encode slashes and leave them as they are:
|
|
|
|
|
|
|
|
````
|
|
|
|
<VirtualHost *:80>
|
|
|
|
AllowEncodedSlashes NoDecode
|
|
|
|
ProxyPass /npm http://127.0.0.1:4873 nocanon
|
|
|
|
ProxyPassReverse /npm http://127.0.0.1:4873
|
|
|
|
</VirtualHost>
|
|
|
|
````
|
|
|
|
|
2017-06-24 10:11:08 +02:00
|
|
|
### Configuration with SSL
|
|
|
|
|
|
|
|
config.yaml
|
2017-12-16 13:25:59 +01:00
|
|
|
|
2017-06-24 10:11:08 +02:00
|
|
|
```yaml
|
|
|
|
url_prefix: https://npm.your.domain.com
|
|
|
|
```
|
2017-12-16 13:25:59 +01:00
|
|
|
|
2017-06-24 10:11:08 +02:00
|
|
|
Apache virtual server configuration
|
2017-12-16 13:25:59 +01:00
|
|
|
|
2017-06-24 10:11:08 +02:00
|
|
|
````
|
|
|
|
apacheconfig
|
|
|
|
<IfModule mod_ssl.c>
|
|
|
|
<VirtualHost *:443>
|
|
|
|
ServerName npm.your.domain.com
|
|
|
|
SSLEngine on
|
|
|
|
SSLCertificateFile /etc/letsencrypt/live/npm.your.domain.com/fullchain.pem
|
|
|
|
SSLCertificateKeyFile /etc/letsencrypt/live/npm.your.domain.com/privkey.pem
|
|
|
|
SSLProxyEngine On
|
|
|
|
ProxyRequests Off
|
|
|
|
ProxyPreserveHost On
|
|
|
|
AllowEncodedSlashes NoDecode
|
2017-08-07 08:44:21 -03:00
|
|
|
ProxyPass / http://127.0.0.1:4873 nocanon
|
|
|
|
ProxyPassReverse / http://127.0.0.1:4873
|
2017-06-24 10:11:08 +02:00
|
|
|
</VirtualHost>
|
|
|
|
</IfModule>
|
|
|
|
````
|
|
|
|
|
|
|
|
## Nginx
|
2017-12-16 13:25:59 +01:00
|
|
|
|
2017-06-24 09:26:10 +02:00
|
|
|
|
|
|
|
````
|
|
|
|
server {
|
|
|
|
listen 80 default_server;
|
|
|
|
location / {
|
|
|
|
proxy_pass http://127.0.0.1:4873/;
|
|
|
|
proxy_set_header Host $host;
|
|
|
|
}
|
|
|
|
}
|
2017-06-24 10:11:08 +02:00
|
|
|
````
|
|
|
|
|
|
|
|
## Run behind reverse proxy with different domain and port
|
|
|
|
|
|
|
|
If you run verdaccio behind reverse proxy, you may noticed all resource file served as relaticve path, like `http://127.0.0.1:4873/-/static`
|
|
|
|
|
|
|
|
To resolve this issue, you should send real domain and port to verdaccio with `Host` heade
|
|
|
|
|
|
|
|
Nginx configure should look like this:
|
|
|
|
|
|
|
|
```nginx
|
|
|
|
location / {
|
|
|
|
proxy_pass http://127.0.0.1:4873/;
|
|
|
|
proxy_set_header Host $host:$server_port;
|
|
|
|
proxy_set_header X-Forwarded-For $remote_addr;
|
2017-07-29 00:23:03 +01:00
|
|
|
proxy_set_header X-Forwarded-Proto $scheme;
|
2017-06-24 10:11:08 +02:00
|
|
|
}
|
|
|
|
```
|
|
|
|
For this case, `url_prefix` should NOT set in verdaccio config
|
|
|
|
|
|
|
|
---
|
|
|
|
or a sub-directory installation:
|
|
|
|
|
|
|
|
```nginx
|
|
|
|
location ~ ^/verdaccio/(.*)$ {
|
|
|
|
proxy_pass http://127.0.0.1:4873/$1;
|
|
|
|
proxy_set_header Host $host:$server_port;
|
|
|
|
proxy_set_header X-Forwarded-For $remote_addr;
|
2017-07-29 00:23:03 +01:00
|
|
|
proxy_set_header X-Forwarded-Proto $scheme;
|
2017-06-24 10:11:08 +02:00
|
|
|
}
|
2017-06-24 09:26:10 +02:00
|
|
|
```
|
2017-06-24 10:11:08 +02:00
|
|
|
For this case, `url_prefix` should set to `/verdaccio/`
|
|
|
|
|
|
|
|
> Note: There is a Slash after install path (`https://your-domain:port/vardaccio/`)!
|