Nginx概念及应用

Nginx

一、反向代理

  1. 概念
    • 反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。同时,用户不需要知道目标服务器的地址,也无需在用户端做任何设定。反向代理服务器通常可以用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率。
  2. 特点
    • 反向代理服务器位于用户于目标服务器之间
    • 对于用户而言,以为代理服务器就是真实的服务器
    • 反向代理机制保护了真实的服务器信息
    • 反向代理一般称之为服务端代理
      在这里插入图片描述
  3. 步骤
    • 当用户发起请求时,该请求被代理服务器拦截
    • 代理服务器查询自己的配置文件,根据url地址获取真实的服务器信息
    • 由代理服务器根据真实的服务器信息,获取数据
    • 真实的服务器接收请求之后,将数据返回给代理服务器
    • 代理服务器接收到服务器数据之后,将数据回传给用户,本次代理结束

二、正向代理

  1. 概念

    • 正向代理,意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理服务器发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容给客户端。客户端才能使用正向代理。
  2. 特点:

    • 代理服务器位于用户与真实服务器之间的
    • 客户非常清楚自己访问的服务器到底是谁
    • 服务器不清楚访问自己的服务器到底是谁,以为只是代理服务器访问
    • 正向代理称之为客户端代理,保护了客户的信息
      在这里插入图片描述

三、Nginx

3.1 Nginx服务器介绍

  1. Nginx(engine x)是一个高性能的HTTP和反向代理的Web服务器,同时也提供了IMAP/POP3/SMTP服务。
  2. Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
  3. 其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
  4. Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
  5. 特点
    • 占用内存少 不超过2M
    • 并发能力强,5w/s tomcat:150-220个/s
    • 开发语言,c语言
3.1.1 nginx下载

在这里插入图片描述

3.1.2 nginx安装

启动:首先右键以管理员身份运行,之后程序闪退表示服务器启动正常
在这里插入图片描述

3.1.3检查Nginx服务启动项

在这里插入图片描述

nginx启动时,会启动2个进程项,其中一个

  1. 主进程:主要为用户提供反向代理服务,占用内存大
  2. 守护进程:防止主进程意外关闭的,占用内存小
3.1.4 启动正常测试

在这里插入图片描述

3.2 Nginx入门案例

3.2.1 配置文件说明
http{
    # 必须在http协议之内配置
    server{
        listen 80;
        server_name "监听的域名地址";
        location / {
            root  "反向代理的是一个目录";
        }
    }
    server{}
}
3.2.2 配置demo服务器案例
# 配置图片代理服务器  http://image.yuanle.com
server{
	listen 80;
	server_name image.yuanle.com;

	location / {
		root E:\IDEA-WORKSPACE\study\JT\jt\images;
	}
}
3.3.3 Nginx命令
  1. 目录:在nginx的根目录中执行

  2. 命令:

    • 启动命令:start nginx
    • 重启命令:nginx -s reload
    • 停止命令:nginx -s stop
3.3.4 hosts文件说明
  1. HOSTS文件是操作系统为了方便开发,在本地形成的一个域名与IP的映射的文件。但是该文件只对本机有效。
  2. 位置:C:\Windows\System32\drivers\etc\hosts
    在这里插入图片描述

四、Nginx高级用法

4.1 负载均衡概述

  1. 负载均衡,英文名称为Load Balance,其含义就是指将负载(工作任务)进行平衡、分摊到多个操作单元上进行运行,例如FTP服务器、Web服务器、企业核心应用服务器和其它主要任务服务器等,从而协同完成工作任务。
  2. 负载均衡构建在原有网络结构之上,它提供了一种透明且廉价有效的方法扩展服务器和网络设备的带宽、加强网络数据处理能力、增加吞吐量、提高网络的可用性和灵活性。

4.2 Nginx负载均衡策略

4.2.1 轮询策略

说明:按照nginx.conf中配置文件的顺序依次访问

server{
	listen 80;
	server_name manage.yuanle.com;

	location / {
		#代理真实服务器地址
		#proxy_pass http://localhost:8091;
		#映射到集群
		proxy_pass http://yuanleWindows;
	}
}
    #配置tomcat服务器集群  1. 默认 轮询策略
    upstream yuanleWindows{
	server 127.0.0.1:8081;
	server 127.0.0.1:8082;
	server 127.0.0.1:8083;
    }
4.2.2 权重策略

说明:由于公司的物理服务器可能性能有高有低,为了让高性能的服务器处理更多的数据,会采用权重策略。

upstream yuanleWindows{
	server 127.0.0.1:8081 weight=6;
	server 127.0.0.1:8082 weight=3;
	server 127.0.0.1:8083 weight=1;
}
4.2.3 IP Hash 策略

说明:如果需要将服务器与IP地址进行绑定时,使用该策略

upstream yuanleWindows{
    ip_hash
	server 127.0.0.1:8081 weight=6;
	server 127.0.0.1:8082 weight=3;
	server 127.0.0.1:8083 weight=1;
}

在这里插入图片描述

4.3 Nginx属性说明

4.3.1 down属性

说明:如果服务器宕机,或者该服务器不想为用户继续提供服务,则可以采用shutdown属性进行标识.
nginx访问规则: 如果nginx访问的服务器不能正常的响应,则等待超时之后,访问新的服务器.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
	upstream yuanleWindows {
		#ip_hash;
		server 127.0.0.1:8081 down;
		server 127.0.0.1:8082;
		server 127.0.0.1:8083;
	}
4.3.2 backup属性

说明:backup表示备用机.正常情况下,该服务器不会为用户提供服务.但是当服务器宕机,或者服务器正忙时,才会访问该服务器.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
	upstream yuanleWindows {
		#ip_hash;
		server 127.0.0.1:8081 down;
		server 127.0.0.1:8082 down;
		server 127.0.0.1:8083 backup;
	}
4.3.3 tomcat服务器高可用机制

高可用: 当服务器发生故障时,通过某种机制可以自动的实现故障的迁移,从而使得用户不受任何的影响.

#配置tomcat服务器集群  1.默认 轮询策略  2.权重策略  3.ip_hash策略
	upstream yuanleWindows {
		#ip_hash;     down 标识宕机     backup 备用机
		#max_fails=1  		表示最大的失败次数
		#fail_timeout=60s	如果访问不通,则在60秒内,不会再次访问故障机
		server 127.0.0.1:8081 max_fails=1 fail_timeout=60s;
		server 127.0.0.1:8082 max_fails=1 fail_timeout=60s;
		server 127.0.0.1:8083 max_fails=1 fail_timeout=60s;
	}
1  		表示最大的失败次数
		#fail_timeout=60s	如果访问不通,则在60秒内,不会再次访问故障机
		server 127.0.0.1:8081 max_fails=1 fail_timeout=60s;
		server 127.0.0.1:8082 max_fails=1 fail_timeout=60s;
		server 127.0.0.1:8083 max_fails=1 fail_timeout=60s;
	}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值