nginx实现反向代理实例

目录

1 前言

1.1 演示内容

1.2 前提条件

2 修改nginx配置文件

3 nginx反向代理(2)

4 location指令说明


1 前言

1.1 演示内容

在服务器上访问nginx端口然后跳转到tomcat服务器

1.2 前提条件

前提条件:利用docker安装好nginx、tomcat、jdk8(tomcat运行需要jdk环境)

只演示docker安装tomcat:

默认拉取最新版tomcat

docker pull tomcat

也可以拉取官方指定版本:

docker pull tomcat:[tag]
# 如拉取 tomcat 8
docker pull tomcat:8

 使用tomcat容器创建镜像并运行

docker run -d -p 8080:8080 --name mytomcat tomcat
  • -d:以后台方式运行
  • -p 8080:8080:指定端口,映射形式为:主机端口(容器外部端口):docker 容器端口(tomcat的端口)
  • tomcat:镜像名称,与上述拉取名称一致
  • --name mytomcat:自定义容器名称
  • 如果是大写的 -P,则会给主机随机分配端口

 查看当前运行的容器

docker ps

docker ps -a 是查看全部 容器包括未运行成功的

如此看tomcat容器已经运行成功了,然后在用ip+端口访问:

 按理来说这样就可以直接访问成功了,但是却报了404,这是为什么呢?

这个是因为webapps文件夹内容为空,内容都在webapps.dist目录下

 只需要将webapps.dist的内容迁移到webapps下就行了:

2 修改nginx配置文件

 修改完之后记得重启nginx,然后直接用ip+80端口访问,就会直接跳转到tomcat页面,如下图:

3 nginx反向代理(2)

按照如上的方法再次启动一个tomcat容器 ,这样我们就有了2台tomcat容器(端口号分别为8080和8002),一台nginx了。演示按照nginx上不同的转发规则将其转发到不同的nginx上。

为了更好的演示效果将在每一台tomcat的webapps目录下分别添加两个静态页面a.html和b.html上添加一个页面,如:

单独访问容器tomcat时:

 访问容器tomcat2时:

然后在配置nginx

 直接访问nginx:http://192.168.10.154/one/a.html

 http://192.168.10.154/two/b.html

4 location指令说明

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

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

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

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

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

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值