30 lines
1.3 KiB
Markdown
30 lines
1.3 KiB
Markdown
|
# Easy Reverse Proxy Config for Nginx
|
||
|
|
||
|
## Introduction
|
||
|
|
||
|
This guide will show you how to set up a reverse proxy for your web server using Nginx. A reverse proxy is a really handy tool that allows use to redirect traffic incoming to our server to a different location, for example to another web server, or to a different port.
|
||
|
|
||
|
I find this most useful for redirecting requests to different dockerised services, but it can be used for many other things too.
|
||
|
|
||
|
## Config
|
||
|
|
||
|
The config for a reverse proxy is really simple. Here's an example of a basic reverse proxy config:
|
||
|
|
||
|
```nginx
|
||
|
server {
|
||
|
listen 80;
|
||
|
server_name my-site.com
|
||
|
|
||
|
location / {
|
||
|
proxy_pass http://localhost:5000;
|
||
|
proxy_redirect off;
|
||
|
proxy_set_header Host $host;
|
||
|
proxy_set_header X-Real-IP $remote_addr;
|
||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||
|
proxy_set_header X-Forwarded-Host $server_name;
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
This config will redirect all traffic coming to `my-site.com` to `http://localhost:5000`. This method will also easily allow you to add SSL to your services, as you can use the `certbot` tool to generate SSL certificates for your domain. Certbot will automatically configure this basic reverse proxy config to use SSL.
|