nginx 学习笔记

nginx 学习

1.1 什么是ngaix

是一个高性能HTTP和反向代理服务器,特点是占有内存少,并发能力强。

ngaix 是转为性能优化而开发,性能是其最重要的考量,实现上非常注重效率,能经受高负载的考验。

1.2 反向代理

  • 正向代理

使用代理服务器访问网址。

  • 反向代理

反向代理,对客户端代理无感知,此时代理服务器和目标服务器对外就是一个服务器

1.3 负载均衡

增加服务器的数量,将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,也就是负载均衡

1.4 动静分离

加快网站解析速度,将动态页面与静态页面由不同的服务器来解析

服务器查看端口

firewall-cmd --list-all

服务器开放端口

firewall-cmd --add-service

开启8081端口

firewall-cmd --add-port=8081/tcp --permanent

重启防火墙

firewall-cmd --reload

2 nginx 配置文件

2.1 全局快

从配置文件开始到events 块之间的内容,主要会设置一些影响nginx服务器整体运行,主要包括配置运行Nginx服务器的用户 ,允许生成的worker process 数,进程pid存放的路径,日志等

比如

worker_processes 1;

worker_processes 值越大,可以支持的并发处理数量就越多

2.2 events 块

events 块涉及的指令主要影响Nginx服务器与用户的网络连接,常用的设置包括是否开启对多 work process的网络连接进行序列化,是否允许同时接受多个网络连接,每个word process可以同时支持的最大连接数。

比如

worker_connections 1024;支持的最大连接数

2.3 http块

http块包括http全局快,server块

  • http块

http全局快配置的指令包括文件引入,MIME-TYPE定义,日志定义,连接超时时间,单链接请求数上限

  • server块

3 nginx反向代理

location = / {
    # 仅仅匹配请求 /
    [ configuration A ]
}

location / {
    # 匹配所有以 / 开头的请求。
    # 但是如果有更长的同类型的表达式,则选择更长的表达式。
    # 如果有正则表达式可以匹配,则优先匹配正则表达式。
    [ configuration B ]
}
location /documents/ {
    # 匹配所有以 /documents/ 开头的请求。
    # 但是如果有更长的同类型的表达式,则选择更长的表达式。
    # 如果有正则表达式可以匹配,则优先匹配正则表达式。
    [ configuration C ]
}
location ^~ /images/ {
    # 匹配所有以 /images/ 开头的表达式,如果匹配成功,则停止匹配查找。
    # 所以,即便有符合的正则表达式location,也不会被使用
    [ configuration D ]
}
location ~* \.(gif|jpg|jpeg)$ {
    # 匹配所有以 gif jpg jpeg结尾的请求。
    # 但是 以 /images/开头的请求,将使用 Configuration D
    [ configuration E ]
}

实现效果从80端口直接跳到使用8080端口。

可以使用nginx反向代理,根据访问路径跳转到不同端口的服务中

主要修改的是server_name,y以及location中需要增加proxy_pass

访问 http://ayugudu.top:80/web/ 直接跳转到 http://ayugudu.top:8080/

访问 http:// ayugudu.top:80/wx/ 直接跳转到 http://ayugudu.top:8081/

server
    {
      
        listen 80;
        server_name http://ayugudu.top/;
       
        
        location ~ /wx/ {
            root   login.html;
            index  login.html;
			proxy_pass http://ayugudu.top:8081;
			proxy_redirect default;
        }
    
       location ~ /web/ {
            root   login.html;
            index  login.html;
			proxy_pass http://ayugudu.top:8080;
			proxy_redirect default;
        }

4 nginx 动静分离

动静分离是把动态跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat 处理动态页面

实现方式

  • 一中是将静态文件独立成单独的域名,放在独立的服务器上,通过nginx转发到静态资源文件
  • 另外一种方法时将动态与静态文件混合在一起发布,通过nginx来分开。

location指定不同的后缀名实现不同的请求转发,通过expires参数设置,使浏览器缓存过期时间,减少与服务器之间的请求和流量。比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,有修改则直接从服务器重新下载。

root实例:

location ^~ /t/ {
     root /www/root/html/;
}

如果一个请求的URI是/t/a.html时,web服务器将会返回服务器上的/www/root/html/t/a.html的文件。

alias实例:

location ^~ /t/ {
 alias /www/root/html/new_t/;
}

如果一个请求的URI是/t/a.html时,web服务器将会返回服务器上的/www/root/html/new_t/a.html的文件。注意这里是new_t,因为alias会把location后面配置的路径丢弃掉,把当前匹配到的目录指向到指定

5 nginx 负载均衡

增加服务器的数量,然后将请求分发到各个服务器上,将原先请求分发到多个服务器上,将负载分发到不同的服务器,也就是负载均衡。

  • 实现将请求分发给不同的服务器
http {
     upstream myserver{
           ip_hash;
           server  localhost:8080 weight=1;
           server  localhost:8081 weight=1;
     }
     
     server {
       location / {
         proxy_pass http://myserver;
         proxy_connect_timeout 10;
       }
     
     }
}

nginx 提供了几种分配方式:

  • 轮询(默认)

每个请求按时间顺序逐一分配到不同的后端服务器,如果服务器挂掉,会自定剔除

  • weight

weight 代表权重,默认为1,权重越高被分配的客户端越多

    upstream myserver{
          
           server  localhost:8080 weight=1;
           server  localhost:8081 weight=1;
     }
  • ip_hash

每个请求按访问的ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题

    upstream myserver{
           ip_hash;
           server  localhost:8080 ;
           server  localhost:8081 ;
     }
  • fair

按后端服务器的响应时间来分配请求,响应时间短的优先分配。

   upstream myserver{
           
           server  localhost:8080 ;
           server  localhost:8081 ;
           fair;
     }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值