现在假设有三台主机,他们的ip分别为:
A: 192.168.1.167
B: 192.168.1.168
C: 192.168.1.169
nginx作为代理服务器部署在主机 A 上面,B 和 C 作为两台应用服务器。现在想实现通过A访问B和C,有以下两种方式:
一、通过不同的listen实现对B和C的访问,实现方式如下:在nginx.conf中添加两个server
server {
listen 8081;
server_name test1;
location / {
proxy_pass http://192.168.1.168:9093;
}
}
server {
listen 8082;
server_name test2;
location / {
proxy_pass http://192.168.1.169:9093;
}
}
注意:1、在以上配置中,server_name可以任意取名
2、主机B的访问方式通过A监听端口8081来代理,访问方式:http://192.168.1.167:8081
3、主机C的访问方式通过A监听端口8082来代理,访问方式:http://192.168.1.167:8082
二、通过相同的listen,不同的server_name实现对B和C的访问,即通过不同的域名方式访问B和C,实现方式如下:
server {
listen 8080;
server_name www.test1.com;
location / {
proxy_pass http://192.168.1.168:9093;
}
}
server {
listen 8080;
server_name www.test2.com;
location / {
proxy_pass http://192.168.1.169:9093;
}
}
注意:1、在以上配置中,server_name表示B和C的域名
2、主机B和C的访问方式都通过A监听端口8080来代理
3、由于是测试,需要在测试端修改hosts文件,即在hosts文件中添加以下内容
192.168.1.168 www.test1.com
192.168.1.169 www.test2.com
4、访问方式:在修改了hosts文件的电脑上按以下方式分别访问B和C:
http://www.test1.com:8080
http://www.test2.com:8080
其中:
linux下hosts所在路径:/etc/hosts
windows下hosts所在路径:C:\Windows\System32\drivers\etc\hosts
server name 为虚拟服务器的识别路径。因此对于相同的listen不同的域名会通过请求头中的HOST字段,匹配到特定的server块,转发到对应的应用服务器中去。
基于域名的虚拟主机(name based virtual host),配置的方法就是多个虚拟主机绑定同一个端口,通过server_name区分。
基于的理论基础就是http协议中会带一个HOST头,web server通过这个头判断具体交给哪个虚拟主机响应。如果没有一个匹配,那么通常哪个在前哪个优先响应,这个叫默认虚拟主机,apache有个_default_属性可以强行指定某一个虚拟主机为默认虚拟主机。如下图
hosts文件指定IP与域名的对应关系(如:192.168.1.169 www.test2.com),对域名的访问会映射成对应的IP。这个ip就是nginx的公网IP 。然后server name 为虚拟服务器的识别路径。因此不同的域名会转发到对应的应用服务器中去。
接下来有时间会分析下 upstream、conf.d
参考:https://blog.csdn.net/sollor525/article/details/81360411
https://blog.csdn.net/cheng_kohui/article/details/82930464
https://segmentfault.com/q/1010000011245338/a-1020000011245502
http://www.nginx.cn/doc/standard/httpcore.html
————————————————
版权声明:本文为CSDN博主「thlzjfefe」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/thlzjfefe/article/details/84489311