今天我们通过两个实例,带大家读懂nginx反向代理
打开浏览器,在地址栏输入地址www.test.com,跳转到百度首页。
(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
(3)重启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 没办法监听本地不存在的ip地址。
解决方法是在/etc/sysctl.conf 中加入如下内核参数配置
echo 'net.ipv4.ip_nonlocal_bind = 1' >>/etc/sysctl.conf
sysctl -p
使用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
(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端口已正常启动
(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
使用nginx反向代理功能实现了访问两个tomcat服务的需求