要使用Nginx根据hostname进行反向代理,你需要在Nginx配置文件中设置server块,并使用server_name指令来匹配不同的hostname。然后,你可以使用location块和proxy_pass指令来定义反向代理的行为。
以下是一个基本的示例,展示了如何根据不同的hostname将请求反向代理到不同的后端服务器:
打开Nginx配置文件。通常位于/etc/nginx/nginx.conf或/etc/nginx/sites-available/目录下的某个文件。
在http块内添加server块,使用server_name指令匹配不同的hostname。例如:
http {
# ... 其他配置 ...
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://backend1.example.com;
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-Proto $scheme;
}
}
server {
listen 80;
server_name example.org;
location / {
proxy_pass http://backend2.example.org;
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-Proto $scheme;
}
}
# ... 其他配置 ...
}
在这个示例中,我们定义了两个server块,分别匹配example.com和example.org。每个server块都有一个location块,使用proxy_pass指令将请求反向代理到不同的后端服务器。
保存配置文件并退出编辑器。
检查Nginx配置文件的语法是否正确:
sudo nginx -t
sudo systemctl reload nginx
现在,当用户访问http://example.com时,请求将被反向代理到http://backend1.example.com。当用户访问http://example.org时,请求将被反向代理到http://backend2.example.org。