Nginx

定义

Nginx是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理服务器。其特点是占有内存少,并发能力强,易于开发,部署方便。Nginx 支持多语言通用服务器。

正向代理

正向代理,就是代理服务器代理了客户端,去和目标服务器进行交互,例如翻墙。

反向代理

反向代理,就是代理服务器代理了目标服务器,去和客户端进行交互。

负载均衡

实际生产环境中,反向代理服务器代理的目标服务器可能不止一个。比如开发好的某个应用部署在一台 Tomcat 服务器上,而 Tomcat 的并发上限不优化情况下,默认只有两百左右,这时候为了解决高并发的问题,就只能选择更替服务器或者搭建多台服务器通过反向代理与负载均衡的技术解决并发问题。

「负载均衡」 (Load Balance)是由**「多台服务器以对称的方式组成一个服务器集群」,每台服务器都具有等价的地位,都可以单独对外提供服务而无须其他服务器的辅助。经过某种负载分管技术,将外部发送来的 「中央请求均匀分配」到对称结构中的「某一台服务器」**上。

负载均衡策略

轮询

轮询去访问机器,把不正常的机器剔除,每个请求会按时间顺序被逐一分配到不同的后端服务器。

least_conn最小连接

把请求转发给连接数较少的后端服务器,轮询算法是把请求平均的转发给各个后端,使他们负载大致相同。而每个请求不同,请求的资源和时间都不同,还是会导致有些机器还是负载过大,这种情况,least_conn就是处理这种情况的调度策略。

ip_hash

按照客户端IP地址的分配方式,可以确保相同客户端的请求一直发送到相同的服务器。这样每个访客都固定访问一个后端服务器。

Nginx、Apache两者比较

1.Nginx 配置简洁, Apache 复杂 ;Nginx 静态处理性能比 Apache 高 3倍以上 ;

2.Apache 对 PHP 支持比较简单,Nginx 需要配合其他后端用;Apache 的组件比 Nginx 多 ;

3.apache是同步多进程模型,一个连接对应一个进程;Nginx是异步的,多个连接(万级别)可以对应一个进程;

4.Nginx处理静态文件好,耗费内存少;动态请求由apache去做,Nginx只适合静态和反向;

5.Nginx适合做前端服务器,负载性能很好;Nginx本身就是一个反向代理服务器 ,且支持负载均衡。

相关推荐
Justin_1920 小时前
Linux-Shell编程之sed和awk
linux·运维·服务器
Akshsjsjenjd20 小时前
深入理解 Shell 循环与函数:语法、示例及综合应用
linux·运维·自动化·shell
半桔21 小时前
【Linux手册】消息队列从原理到模式:底层逻辑、接口实战与责任链模式的设计艺术
java·linux·运维·服务器
Adorable老犀牛21 小时前
可遇不可求的自动化运维工具 | 2 | 实施阶段一:基础准备
运维·git·vscode·python·node.js·自动化
衍余未了1 天前
k8s镜像推送到阿里云,使用ctr推送镜像到阿里云
linux·运维·服务器
yiqiqukanhaiba1 天前
Linux编程笔记1-概念&数据类型&输入输出
linux·运维·服务器
乌萨奇也要立志学C++1 天前
【Linux】进程概念(一):从冯诺依曼体系到 PCB 的进程核心解析
linux·运维·服务器
游九尘1 天前
服务器都是用的iis, 前端部署后报跨域,不是用同一个服务器 是前端项目的服务器做Nginx转发,还是后端项目的服务器做Nginx转发?
服务器·前端·nginx
三坛海会大神5551 天前
nginx中配置https详解:配置SSL/TLS证书
nginx·https·ssl
huangyuchi.1 天前
【Linux系统】初见线程,概念与控制
linux·运维·服务器·页表·linux线程概念·linux线程控制·分页式存储管理