4_nginx 配置实例-反向代理

👉写在前面:所谓反向代理,简单理解就是隐藏服务端的具体细节,通过访问 nginx 进行实现。


4_nginx 配置实例-反向代理

反向代理实例 1

1、实现效果

打开浏览器,在浏览器地址栏输入地址 www.123.com,跳转到 liunx 系统 tomcat 主页面中 。

2、准备工作

(1)下载 tomcat

官网:https://tomcat.apache.org/download-70.cgi

在这里插入图片描述

(2) liunx 系统安装 tomcat

将 tomcat 安装文件放到 liunx 系统中,

在这里插入图片描述

解压,

tar -xvfapache-tomcat-7.0.106.tar.gz 

在这里插入图片描述

进入 tomcat 的 bin 目录中,

./startup.sh

启动 tomcat 服务器
在这里插入图片描述

(3)对外开放访问的端口

我这里使用的是 Centos 6, 和 Centos 7不一样,Centos 7如何开放端口,更多细节可以参考上一篇文章 :Nginx 安装

vim /etc/sysconfig/iptables

开放 8080 端口,

# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -m state –state ESTABLISHED,RELATED -j ACCEPT
-A INPUT -p icmp -j ACCEPT
-A INPUT -i lo -j ACCEPT
 
-A INPUT -m state –state NEW -m tcp -p tcp –dport 22 -j ACCEPT
-A INPUT -m state –state NEW -m tcp -p tcp –dport 80 -j ACCEPT
-A INPUT -m state –state NEW -m tcp -p tcp –dport 8080 -j ACCEPT

-A INPUT -j REJECT –reject-with icmp-host-prohibited
-A FORWARD -j REJECT –reject-with icmp-host-prohibited
COMMIT

保存退出!!

重启防火墙

 service iptables restart
(4)在 windows 系统中通过浏览器访问 tomcat 服务器

在这里插入图片描述

3、访问过程的分析

在这里插入图片描述

4、具体配置

第一步:在 windows 系统的 host 文件进行域名和 ip 对应关系的配置

在这里插入图片描述

末尾添加,将 www.123.com 映射到 192.168.77.130

这里的 ip 是 linux 的地址

192.168.77.130   www.123.com

配置完成之后,我们便可以通过 www.123.com:8080 访问到第一步出现的 Tomcat 初始界面。那么如何只需要输入 www.123.com 便可以跳转到 Tomcat 初始界面呢?便用到 nginx 的反向代理。

第二步: 在 nginx 进行请求转发的配置(反向代理配置)

文件地址:/usr/local/nginx/conf

两处改变:nginx 地址 + 转发地址

在这里插入图片描述

5、最终测试

切换到 /usr/local/nginx/sbin/重新启动 nginx

./nginx -s reload

访问:www.123.com,

如上配置,我们监听 80 端口,访问域名为 www.123.com,不加端口号时默认为 80 端口,故访问该域名时会跳转到 127.0.0.1:8080 路径上。在浏览器端输入 www.123.com 结果如下:

在这里插入图片描述

反向代理实例 2

1、实现效果

使用 nginx 反向代理,根据访问的路径跳转到不同端口的服务中,

nginx 监听端口为 9001

  • 访问 http://192.168.17.129:9001/edu/ 直接跳转到 127.0.0.1:8080
  • 访问 http:// 192.168.17.129:9001/vod/ 直接跳转到 127.0.0.1:8081

2、准备工作

(1)准备两个 tomcat 服务器,一个 8080 端口,一个 8081 端口

这个地方,需要将 其中代表 8081 的服务器进行修改,进入到 /Tomcat8081/apache-tomcat-7.0.106/conf

vim server.xml

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

(2)创建文件夹和测试页面

说明:tomcat 加载是加载的 webapps 中的东西,所以放在该文件夹下 。

/Tomcat8080/apache-tomcat-7.0.106/webapps中,新建 edu 文件夹,并在该文件夹下新建文件 a.html,

内容如下:

<h1>8080</h1>

/Tomcat8081/apache-tomcat-7.0.106/webapps中,新建 vod 文件夹,并在该文件夹下新建文件 a.html,

内容如下:

<h1>8081</h1>

3、具体配置

(1)找到 nginx 配置文件,进行反向代理配置

三处改变:监听端口 + nginx地址 + 转发地址

在这里插入图片描述

(2)开放对外访问的端口号 9001 8080 8081

4、最终测试

重启 nginx ,

./nginx -s reload

在这里插入图片描述
在这里插入图片描述

location 指令说明

该指令用于匹配 URL。

语法如下:
在这里插入图片描述

1、= :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配成功,就停止继续向下搜索并立即处理该请求。

2、~:用于表示 uri 包含正则表达式,并且区分大小写。

3、~*:用于表示 uri 包含正则表达式,并且不区分大小写。

4、^~:用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location 块中的正则 uri 和请求字符串做匹配。

**注意:*如果 uri 包含正则表达式,则必须要有 ~ 或者 ~ 标识。

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值