1. 目的
- 通过nginx实现代理,前端HTML5只需要对接一个http端口,即可与后台多个二级http服务进行对接,方法是在nginx中通过不同的路径代理不同的二级http服务。
- 静态页面依然使用nginx一级服务器返回。
2.Nginx服务器配置
配置nginx,访问路径为button1时转发到3002端口,访问路径为button2时转发到3003端口。
server { listen 8081; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main;location / { root html;index index.html index.htm; } location /button1 { proxy_pass http://127.0.0.1:3002; }location /button2 { proxy_pass http://127.0.0.1:3003; }
3. ngnix静态网页编写
ngnix中静态文件目录
index.html文件代码
4. 二级服务器搭建
使用nodejs搭建两个http服务器,分别监听3002、3003端口,代码如下:
// 1. 加载http核心模块let http = require("http");// 2. 使用http.createServer()方法创建一个web服务器,通过server接收let server = http.createServer();// 3. 服务器要做的事:提供服务,发送、接收、处理请求,并发送响应server.on("request", function (req, res) { // 这里的回调事件根据需要编写即可,这里给出简单示例 // 3.1 收到请求时,打印请求的路径 console.log(`收到客户端的请求了,请求路径是${req.url}`); // 3.2 设置响应头中的Content-Type为plain普通文本模式,否则中文无法正常展示 res.setHeader("Content-Type", "text/plain; charset=utf-8"); let url = req.url; // 3.3 根据不同的url展示不同内容 if (url == "/") { // res.write--在页面内写入内容 res.write("首页"); } else if (url == "/login") { res.write("登录"); }});// 4.绑定端口号;server.listen(3002, function () { console.log("服务器启动成功,可以通过http:127.0.0.1:3002/来进行访问");});
服务器文件目录:
在命令行运行两个服务
5. 测试验证
浏览器打开显示效果如下,该页面使用ngnix返回html/index.html文件
点击第1个按钮,消息转发到3002服务,点击第2个按钮消息转发到3003服务
6. proxy_pass设置
proxy_pass代理地址端口后无任何字符,转发后地址:代理地址+访问URL目录部分
proxy_pass代理地址端口后有目录(包括 / ),转发后地址:代理地址+访问URL目录部分去除location匹配目录(示例中的"v1"或"v1/")
代理地址为 http://127.0.0.1:3002
按钮(http://127.0.0.1:8081/button1/login.php)URL目录地址为:button1/test/login.php
因此以下没有加/ 的访问地址为:http://127.0.0.1:3002/button1/login.php
location /button1 { proxy_pass http://127.0.0.1:3002; }
以下加/的访问地址为: http://127.0.0.1:3002/login.php
location /button1 { proxy_pass http://127.0.0.1:3002/;}
实际测试如下: