网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
Nginx适用场景
- Http服务器
性能非常高,非常注重效率,能够经受高负载的考验
支持50000个并发连接数,CPU和内存的占用也非常的低,10000个没有活动的连接才占用2.5M的内存 - 反向代理服务器
- 正向代理
在浏览器中配置代理服务器的相关信息,通过代理服务器访问目标网站,代理服务器收到目标网站的响应之后,会把响应信息返回给浏览器客户端
- 反向代理
浏览器客户端发送请求到反向代理服务器(⽐如Nginx),由反向代理服务器选择原始服务器提供服务获取结果响应,最终再返回给客户端浏览器
- 正向代理
- 负载均衡服务器
负载均衡,当⼀个请求到来的时候(结合上图),Nginx反向代理服务器根据请求去找到⼀个原始服务器来处理当前请求,那么这叫做反向代理。那么,如果⽬标服务器有多台(⽐如上图中的tomcat1,tomcat2,tomcat3…),找哪⼀个⽬标服务器来处理当前请求呢,这样⼀
个寻找确定的过程就叫做负载均衡。⽣活中也有很多这样的例⼦,⽐如,我们去银⾏,可以处理业务的窗⼝有多个,那么我们会被分配到哪个窗⼝呢到底,这样的⼀个过程就叫做负载均衡。负载均衡就是为了解决⾼负载的问题。 - 动静分离
Nginx的特点
- 跨平台:nginx可以在大多数类unix操作系统上编译运行,而且也有windows版本
- nginx的上手非常简单,配置也比较简单
- 高并发,性能好
- 稳定性好,宕机概率很低
Nginx的安装
# 上传nginx安装包到linux服务器,nginx安装包(.tar⽂件)下载地址:http://nginx.org
# 安装Nginx依赖,pcre、openssl、gcc、zlib(推荐使⽤yum源⾃动安装)
yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel
# 解包Nginx软件包
tar -xvf nginx-1.17.8.tar
# 进⼊解压之后的⽬录 nginx-1.17.8
cd nginx-1.17.8
# 命令⾏执⾏./configure
# 命令⾏执⾏ make
# 命令⾏执⾏ make install,完毕之后在/usr/local/下会产⽣⼀个nginx⽬录
# 进⼊sbin⽬录中,执⾏启动nginx命令
cd nginx/sbin
./nginx
Nginx主要命令
# 启动
./nginx
# 终⽌nginx(当然也可以找到nginx进程号,然后使⽤kill -9 杀掉nginx进程)
./nginx -s stop
# (重新加载nginx.conf配置⽂件
./nginx -s reload
Nginx核心配置文件解读
Nginx的核⼼配置⽂件conf/nginx.conf包含三块内容:全局块
、events块
、http块
- 全局块
从配置⽂件开始到events块之间的内容,此处的配置影响nginx服务器整体的运⾏,⽐如worker进程的数量、错误⽇志的位置等 - event
events块主要影响nginx服务器与⽤户的⽹络连接,⽐如worker_connections 1024,标识每个workderprocess⽀持的最⼤连接数为1024’ - http块
http块是配置最频繁的部分,虚拟主机的配置,监听端⼝的配置,请求转发、反向代理、负载均衡等
Nginx应用场景之反向代理
需求一
- 部署tomcat,保持默认监听8080端⼝
- 修改nginx配置,并重新加载
- 修改nginx配置
- 重载nginx配置
./nginx -s reload
- 测试,访问
http://127.0.0.0.1:90031
,返回tomcat的⻚⾯
需求⼆
- 再部署⼀台tomcat,保持默认监听8081端⼝
- 修改nginx配置,并重新加载
- 这⾥主要就是多location的使⽤,这⾥的nginx中server/location就好⽐tomcat中的Host/Context
location 语法如下:
location [=|~|~*|^~] /uri/ { … }
在nginx配置⽂件中,location主要有这⼏种形式:
1)正则匹配 location ~ /lagou { }
2)不区分⼤⼩写的正则匹配 location ~* /lagou { }
3)匹配路径的前缀 location ^~ /lagou { }
4)精确匹配 location = /lagou { }
5)普通路径前缀匹配 location /lagou { }
优先级:4 > 3 > 2 > 1 > 5
Nginx应用场景之负载均衡
Nginx负载均衡策略
轮询
默认策略,每个请求按时间顺序逐⼀分配到不同的服务器,如果某⼀个服务器下线,能⾃动剔除
upstream lagouServer{
server 111.229.248.243:8080;
server 111.229.248.243:8082;
}
location /abc {
proxy_pass http://lagouServer/;
}
weight
weight代表权重,默认每⼀个负载的服务器都为1,权重越⾼那么被分配的请求越多(⽤于服务器性能不均衡的场景)
upstream lagouServer{
server 111.229.248.243:8080 weight=1;
server 111.229.248.243:8082 weight=2;
}
ip_hash
每个请求按照ip的hash结果分配,每⼀个客户端的请求会固定分配到同⼀个⽬标服务器处理,可以解决session问题
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!