Nginx
一、Nginx 介绍
[1] Nginx 简介
Nginx (engine x) 是一个高性能的 HTTP 和反向代理服务。Nginx 是由伊戈尔·赛索耶夫为俄罗斯访问量第二的 Rambler.ru 站点(俄文:Рамблер)开发的,第一个公开版本 0.1.0发布于 2004 年 10 月 4 日。
Nginx 是一个很强大的高性能 Web 和反向代理服务,它具有很多非常优越的特性:在连接高并发的情况下,Nginx 是 Apache 服务不错的替代品:Nginx 在美国是做虚拟主机生意的老板们经常选择的软件平台之一。
[2] Nginx 作用
2.1http 协议代理
2.2搭建虚拟主机
2.3服务的反向代理
2.4在反向代理中配置集群的负载均衡
二、 代理方式
[1] 正向代理
正向代理,意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。
举例:游戏的加速器。游戏加速器就充当正向代理服务器这一角色。客户端把想要请求的地址信息发送给代理服务器,代理服务器就用客户端的请求信息访问原始的服务器。代理服务器接收到请求后再把数据返回给客户端。
正向代理服务器是面向客户端的。
[2]反向代理
反向代理(Reverse Proxy)方式是指以代理服务器来接受 internet 上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给 internet 上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
一个大型项目多种服务,比如百度、淘宝、京东等。
拿淘宝来说,访问www.taobao.com进入的是淘宝的主页
但是访问login.taobao.com则访问的是淘宝的登录服务
访问search.taobao.com则访问的是淘宝的搜索服务
也就是说,淘宝把不同的服务放到了不同的服务器上,客户端在访问服务时会被反向代理服务器拦截,根据客户端访问的服务去访问该服务对应的私网主机URL,再把请求到的内容发送给客户端。
反向代理服务器是面向服务器的。
[3]二者之间的区别
- 位置不同
正向代理,架设在客户机和目标主机之间;
反向代理,架设在服务器端; - 代理对象不同
正向代理,代理客户端,服务端不知道实际发起请求的客户端;
反向代理,代理服务端,客户端不知道实际提供服务的服务端;
三、安装Nginx
见文章:https://blog.csdn.net/weixin_44911308/article/details/105881092
四、操作Nginx
[1]启动 nginx
进入nginx下的sbin目录,执行./nginx
cd /usr/local/nginx/sbin/
./nginx
注意:执行./nginx 启动 nginx,这里可以-c 指定加载的 nginx 配置文件,如下:
./nginx -c /usr/local/nginx/conf/nginx.conf
如果不指定-c,nginx 在启动时默认加载 conf/nginx.conf 文件,此文件的地址也可以在编译安装 nginx 时指定./configure 的参数(–conf-path= 指向配置文件(nginx.conf)),我们安装参数指定的是在/usr/local/nginx/conf/下的nginx.conf文件。
[2]停止 nginx
进入nginx的sbin目录下
cd /usr/local/nginx/sbin
- 方式1:快速停止:
./nginx -s stop
此方式相当于先查出 nginx 进程 id 再使用 kill 命令强制杀掉进程。
- 方式2:完整停止(建议使用):
./nginx -s quit
此方式停止步骤是待 nginx 进程处理任务完毕进行停止。
[3]重启 nginx
- 方式 1:先停止再启动(建议使用):
对 nginx 进行重启相当于先停止 nginx 再启动 nginx,即先执行停止命令再执行启动命令。如下:
./nginx -s quit
./nginx
- 方式 2:重新加载配置文件:
当 nginx 的配置文件 nginx.conf 修改后,要想让配置生效需要重启 nginx,使用-s reload不用先停止 nginx 再启动 nginx 即可将配置信息在 nginx 中生效,如下:
./nginx -s reload
[4]测试
nginx 安装成功,启动 nginx,即可访问虚拟机上的 nginx
Nginx 默认的是侦听 80 端口
五、Nginx的使用
[1]虚拟主机介绍
虚拟主机是一种特殊的软硬件技术,它可以将网络上的每一台计算机分成多个虚拟主机,每个虚拟主机可以独立对外提供 www 服务,这样就可以实现一台主机对外提供多个web 服务,每个虚拟主机之间是独立的,互不影响的。
虚拟主机技术是互联网服务器采用的节省服务器硬件成本的技术,虚拟主机技术主要应用于 HTTP(Hypertext Transfer Protocol,超文本传输协议)服务,将一台服务器的某项或者全部服务内容逻辑划分为多个服务单位,对外表现为多个服务器,从而充分利用服务器硬件资源。
举例:阿里云服务器。一台物理主机上可以安装多个虚拟机。进行一系列配置后再把每一个虚拟机作为一个整体单位卖给用户。
[2]Nginx 的虚拟主机配置
见文章:Nginx配置虚拟主机的三种方式
[3]Nginx中配置服务的反向代理
注意:
- 该步骤是基于 [2]Nginx 的虚拟主机配置中的基于域名配置虚拟主机的基础之上的。
- 云服务器实现反向代理需要备案。
需求
安装两个 tomcat 服务,通过 nginx 反向代理。
nginx和tomcat应在两个linux虚拟机内,否则按照本例可能出现端口占用。
tomcat 安装到 192.168.70.143 环境中。端口为 3881与 3882
复制tomcat
配置tomcat
修改端口
如果没有其他的tomcat在运行的话,n-tomcat1仅需要修改8080端口即可。
两个tomcat的修改方法大致相同,这里只展示一个。
修改tomcat访问首页
测试
同时开启n-tomcat1和n-tomcat2
访问n-tomcat1
访问n-tomcat2
修改nginx/conf/nginx.conf文件
测试连接
用浏览器访问test.qiaotong.com
用浏览器访问test.qt.com
[4]在反向代理中配置负载均衡
1. 什么是负载均衡
负载均衡建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展
网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。
负载均衡,英文名称为 Load Balance,其意思就是分摊到多个操作单元上
进行执行,例如 Web 服务器、FTP 服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。
多个服务器中存放的是一个项目,用户在访问项目时,每次操作可能都会访问不同的服务器,但是访问的是同一个项目。
2.nginx 负载均衡策略
- 轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。 - 指定权重
指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。
upstream backserver {
server 192.168.0.14 weight=10;
server 192.168.0.15 weight=10;
}
- IP 绑定 ip_hash
每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题。
upstream backserver {
ip_hash;
server 192.168.0.14:88;
server 192.168.0.15:80;
}
还有其他负载均衡的策略,但要用到第三方工具,这里就不做介绍了。
3.nginx集群配置
节点说明:
在 http 节点里添加:
#定义负载均衡设备的 Ip 及设备状态
upstream myServer {
server 127.0.0.1:9090 down;
server 127.0.0.1:8080 weight=2;
server 127.0.0.1:6060;
server 127.0.0.1:7070 backup;
}
在需要使用负载的 Server 节点下添加
proxy_pass http://myServer;
upstream 每个设备的状态:
down 表示单前的 server 暂时不参与负载
weight 默认为 1.weight 越大,负载的权重就越大
fail_timeout:次失败后,暂停的时间 默认 10s
max_fails :允许请求失败的次数默认为 1.当超过最大次数时,返回
backup: 其它所有的非 backup 机器 down 或者忙的时候,请求 backup 机器。所以这台
机器压力会最轻。
需求
nginx 作为负载均衡服务器,用户请求先到达 nginx,再由 nginx 根据负载配置将请求转发至 tomcat 服务器。
一般nginx所在的虚拟机独立存在,这里为了方便,放到了一个虚拟机上
nginx 负载均衡服务器:192.168.85.128
tomcat1 服务器:192.168.85.128:8080
tomcat2 服务器:192.168.85.128:9090
默认的是 轮询策略
nginx.conf配置文件内容
user root;
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
upstream tomcat_server1{
server 192.168.85.128:8080;
server 192.168.85.128:9090;
}
#一个Server就是一个虚拟主机
server {
#监听的端口号
listen 80;
#虚拟主机的ip地址
server_name test.qiaotong.com;
#主要配置路由访问信息
location / {
#用于指定访问根目录时,访问虚拟主机的web目录
proxy_pass http://tomcat_server1;
#在不指定访问具体资源时,默认的展示资源的列表
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
重启nginx,访问test.qiaotong.com,返回的是test.qiaotong.com服务器的页面
点击刷新,则返回的则是test.qt.com服务器的页面