Nginx学习笔记

Nginx简介

Nginx 是⼀个⾼性能的HTTP和反向代理web服务器,核⼼特点是占有内存少,并发能⼒强

Nginx应用场景

1)Http服务器(Web服务器)性能⾮常⾼,⾮常注重效率,能够经受⾼负载的考验。

2)反向代理服务器

  正向代理: 在浏览器中配置代理服务器的相关信息,通过代理服务器访问⽬标⽹站,代理服务器收到⽬标⽹站的响应之后,会把响应信息返回给我们⾃⼰的浏览器客户端。

  反向代理:浏览器客户端发送请求到反向代理服务器(⽐如Nginx),由反向代理服务器选择原始服务器提供服务获取结果响应,最终再返回给客户端浏览器。

3)负载均衡服务器。负载均衡,当⼀个请求到来的时候(结合上图),Nginx反向代理服务器根据请求去找到⼀个原始服务器来处理当前请求,那么这叫做反向代理。那么,如果⽬标服务器有多台(⽐如上图中的tomcat1,tomcat2,tomcat3...),找哪⼀个⽬标服务器来处理当前请求呢,这样⼀个寻找确定的过程就叫做负载均衡。

4)动静分离

 

 

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

然后访问服务器的80端⼝(nginx默认监听80端⼝)

 

Nginx主要命令

./nginx 启动nginx

./nginx -s stop 终⽌nginx(当然也可以找到nginx进程号,然后使⽤kill -9 杀掉nginx进程)

./nginx -s reload (重新加载nginx.conf配置⽂件)

Nginx核⼼配置⽂件解读

Nginx的核⼼配置⽂件conf/nginx.conf包含三块内容:全局块、events块、http块

全局块:从配置⽂件开始到events块之间的内容,此处的配置影响nginx服务器整体的运⾏,⽐如worker进程的数量、错误⽇志的位置等

events块:events块主要影响nginx服务器与⽤户的⽹络连接,⽐如worker_connections 1024,标识每个workderprocess⽀持的最⼤连接数为1024

http块:http块是配置最频繁的部分,虚拟主机的配置,监听端⼝的配置,请求转发、反向代理、负载均衡等

Nginx应⽤场景之反向代理

需求⼀完成:部署tomcat,保持默认监听8080端⼝,修改nginx配置,并重新加载。

重新加载nginx配置 ./nginx -s reload  测试:

需求⼆完成:再部署⼀台tomcat,保持默认监听8081端⼝,修改nginx配置,并重新加载

这⾥主要就是多location的使⽤,这⾥的nginx中server/location就好⽐tomcat中的Host/Context。

location 语法如下:location [=|~|~*|^~] /uri/ { … }

在nginx配置⽂件中,location主要有这⼏种形式:

1)正则匹配 location ~ /lgl { }

2)不区分⼤⼩写的正则匹配 location ~* /lgl { }

3)匹配路径的前缀 location ^~ /lgl { }

4)精确匹配 location = /lgl { }

5)普通路径前缀匹配 location /lgl { }

优先级

4 > 3 > 2 > 1 > 5

Nginx应⽤场景之负载均衡

Nginx负载均衡策略

轮询: 默认策略,每个请求按时间顺序逐⼀分配到不同的服务器,如果某⼀个服务器下线,能⾃动剔除。

upstream lglServer{
  server 111.229.248.243:8080;
  server 111.229.248.243:8082;
}
location /abc {
  proxy_pass http://lglServer/;
}

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问题

upstream lagouServer{
    ip_hash;
    server 111.229.248.243:8080;
    server 111.229.248.243:8082;
}

Nginx应⽤场景之动静分离

 

Nginx配置:

posted on 2020-10-09 16:09  lvguoliang(学无止境)  阅读(134)  评论(0)    收藏  举报