详细介绍请看nginx代理部署Vue与React项目,在这儿主要介绍多个站点的配置php
有时候想在一台服务器上为不一样的域名/不一样的二级域名运行不一样的站点。好比www.webA.com做为官网前台,www.webB.com/admin.webA.com做为后台管理系统。能够把你的服务器IP分别解析到两个域名上,而后反向代理不一样的站点,站点的服务名必须与域名对应。html
第一步:新建webServer文件夹nginx
1 mkdir /usr/local/nginx/webServer
第二步:进入webServer目录web
1 cd webServer
第三步:新建站点A配置文件vim
1 vim webA.conf
在站点A中写入以下配置信息:服务器
1 server { 2 listen 80; 3 server_name www.webA.com; 4 5 location / { 6 root html1; 7 index index.php index.html index.htm; 8 } 9 }
第四步:新建站点B配置文件spa
1 vim admin.conf
在站点B中写入以下配置信息:代理
1 upstream demostream { 2 server 127.0.0.1:9090 weight = 4; 3 } 4 5 server { 6 listen 80; 7 server_name admin.webA.com,www.webB.com; 8 9 #charset koi8 - r; 10 #access_log logs / host.access.log main; 11 12 location / { 13 proxy_pass http://demostream/dist/; 14 proxy_set_header Host $host; 15 proxy_set_header X- Real - IP $remote_addr; 16 proxy_set_header X - Forwarded - For $proxy_add_x_forwarded_for; 17 proxy_set_header X - NginX - Proxy true; 18 proxy_set_header Connection "upgrade"; 19 proxy_set_header Upgrade $http_upgrade; 20 } 21 }
第五步:配置nginx主配置文件code
1 vim /usr/local/nginx/conf/nginx.conf
在nginx配置文件http块中,加入下面一句server
1 include /usr/local/nginx/webServer/*.conf; #表示包含咱们刚才创建的配置文件
第六步:检查nginx配置文件是否正确
1 ./nginx -t
第七步:重启nginx
1 ./nginx -s reload
第八步:nginx只容许域名访问,禁止ip访问
新加的server(注意是新增,并非在原有的server基础上修改)
server { listen 80 default; server_name _; return 403; }
第九步:配置域名
站点的服务名必须与域名对应,即server_name就是相应的二级域名;同时须要在hosts文件中添加对应的配置
1 vim /etc/hosts
添加以下配置信息:
1 127.0.0.1 www.webA.com 2 127.0.0.1 admin.webA.com 3 127.0.0.1 www.webB.com
使用hostname+定义的主机名是hosts文件生效
1 hostname testHost
输入hostname可查看定义的主机名。
绑定域名解析,添加记录->绑定服务器的公网IP便可,以下所示,记录值输入公网IP便可。