vlambda博客
学习文章列表

学习Nginx反向代理

Nginx反向代理实例 1

1、实现效果

2、准备工作

(1)在Linux系统安装nginx

1)创建用于运行Nginx的用户
useradd -M -s /sbin/nologin nginx
2)下载nginx软件包
wget http://nginx.org/download/nginx-1.18.0.tar.gz
3)解压
tar -xf nginx-1.18.0.tar.gz -C /usr/src
4)configure
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --with-http_ssl_module
参数说明:
--user=nginx:指定nginx程序运行用户
--group=nginx:指定nginx程序运行用户组
--prefix=/usr/local/nginx:指定安装路径
--with-http_ssl_module:开启nginx的SSL模块来支持HTTPS访问
5)编译安装
make -j 4 && make install
6)给nginx命令做个软链接,以便PATH能找到
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
7)本次实验nginx版本
[root@qll251 ~]# nginx -v
nginx version: nginx/1.18.0

(2)编辑nginx配置文件

vim /usr/local/nginx/conf/nginx.conf

  • server_name:监听访问的域名;
  • proxy_pass URL:把请求转发到指定URL

(3)重启nginx服务

学习Nginx反向代理

如果出现以上报错,说明Nginx未开启SSL模块,解决方案:

在安装编译时,需配置ssl支持
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --with-http_ssl_module

重启nginx服务:

nginx -s stop && nginx

(4)Windows hosts文件修改

在Windows的hosts文件中进行域名和ip对应关系的配置

学习Nginx反向代理

3、访问测试

学习Nginx反向代理

如果您在实验过程中遇到如下报错:

学习Nginx反向代理

解决方法是在/etc/sysctl.conf 中加入如下内核参数配置

echo 'net.ipv4.ip_nonlocal_bind = 1' >>/etc/sysctl.conf
sysctl -p

4、访问过程分析

学习Nginx反向代理

Nginx反向代理实例 2

1、实现效果

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

  • 本次nginx反向代理中使用9001端口

  • 访问http://10.43.187.251:9001/edu/,直接跳转转至127.0.0.1:8080

  • 访问http://10.43.187.251:9001/vod/,直接跳转转至127.0.0.1:8081

2、准备工作

(1)部署两个tomcat服务器

tomcat依赖java运行环境,因此先完成jdk环境变量的配置

1、下载jdk
wget http://big.gxkjbg.com:8080/201704/tools/jdk-linux-x64.tar.gz
tar -zxvf jdk-linux-x64.tar.gz -C /usr/src/
ls /usr/src/jdk1.8.0_131/

2、编辑环境变量
vim /etc/profile
export JAVA_HOME=/usr/src/jdk1.8.0_131
export JAVA_BIN=/usr/src/jdk1.8.0_131/bin
export PATH=${JAVA_BIN}:$PATH
export CLASSPATH=.:{JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar

3、使环境变量立即生效
source /etc/profile

4、检查java版本
[root@qll251 ~]# java -version
java version "1.8.0_131"
Java(TM) SE Runtime Environment (build 1.8.0_131-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.131-b11, mixed mode)
[root@qll251 ~]#

(2)启动2个tomcat服务

1、下载免安装版Tomcat
wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.54/bin/apache-tomcat-8.5.54.tar.gz

2、创建两个文件夹
mkdir /usr/src/tomcat8080
mkdir /usr/src/tomcat8081

3、解压
tar -zxvf apache-tomcat-8.5.54.tar.gz -C /usr/src/tomcat8080
tar -zxvf apache-tomcat-8.5.54.tar.gz -C /usr/src/tomcat8081

4、启动tomcat1
[root@qll251 ~]# cd /usr/src/tomcat8080
[root@qll251 tomcat8080]# ./apache-tomcat-8.5.54/bin/startup.sh

5、启动tomcat2

由于tomcat1使用8080默认端口,防止端口冲突,我们修改下tomcat2端口:
[root@qll251 ~]# cd /usr/src/tomcat8081
[root@qll251 tomcat8081]# vim apache-tomcat-8.5.54/conf/server.xml
22 <Server port="8015" shutdown="SHUTDOWN">
69 <Connector port="8081" protocol="HTTP/1.1"

启动tomcat2:
[root@qll251 tomcat8081]# ./apache-tomcat-8.5.54/bin/startup.sh

(3)检测tomcat端口已正常启动

学习Nginx反向代理

(4)创建测试访问页面

1、在tomcat1中创建a.thml文件
[root@qll251 ~]# cd /usr/src/tomcat8080
[root@qll251 tomcat8080]# cd apache-tomcat-8.5.54/webapps/
[root@qll251 webapps]# mkdir edu
[root@qll251 webapps]# echo "<h1>8080!</h1>" > edu/a.thml

2、在tomcat2中创建a.thml文件
[root@qll251 ~]# cd /usr/src/tomcat8081
[root@qll251 tomcat8081]# cd apache-tomcat-8.5.54/webapps/
[root@qll251 webapps]# mkdir vod
[root@qll251 webapps]# echo "<h1>8081!</h1>" > vod/a.thml

(5)编辑nginx配置文件

vim /usr/local/nginx/conf/nginx.conf

3、最终测试

使用nginx反向代理功能实现了访问两个tomcat服务的需求