我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Nginx学习1:通过访问路径代理不同二级http服务

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Nginx学习1:通过访问路径代理不同二级http服务

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/;}

实际测试如下:

 

 

来源地址:https://blog.csdn.net/zh8706/article/details/129782036

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Nginx学习1:通过访问路径代理不同二级http服务

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

目录