Nginx(Nginx介绍、代理方式、安装Nginx、操作Nginx(启动、停止、重启、测试)、Nginx的使用(虚拟主机的配置、配置服务的反向代理、负载均衡))

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 负载均衡策略
  1. 轮询(默认)
    每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。
  2. 指定权重
    指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。
upstream backserver {
server 192.168.0.14 weight=10;
server 192.168.0.15 weight=10;
}
  1. 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服务器的页面
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值