由浅入深学习nginx

news/2024/7/7 21:42:22 标签: nginx

nginx(高性能的http和反向代理服务器)的优点:
(1)占有内存少
(2)并发能力强(支持5万个)
(3)专为性能优化而开发
nginx主要可以实现的功能有这么几个,反向代理,负载均衡和动静分离以及高可用这几个功能。

nginx文件配置的说明:

三部分组成
(1)全局块
#从配置文件开始到events块之间的内容,主要会设置一些影响nginx服务器整体运行的配置指令,主要包括
运行nginx服务器的用户,允许生成的worker process数,锦程PID存放路径,日志存放路径和类型以及
配置文件的引入

# 全局块
#user  nobody;


# 表示nginx服务器并发处理服务的关键配置,worker_process值越大,可以支持的并发处理量也越多
# 但是会受到硬件,软件等设备的制约
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;

(2)events块

# 主要影响nginx服务器与用户的网络连接,常用的设置包括是否开启对work process下的
# 网络连接进行序列化,是否允许同事接收多个网络连接,选取哪种事件驱动模型来处理连接
# 请求,每个word process可以同时支持的最大连接数
events {
    worker_connections  1024;
}

(3)http块

反向代理

1.正向代理
在这里插入图片描述
2.反向代理
1.客户端不需要做任何配置就可以访问,我们只需要将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器获取数据后,再返回给客户端。此时反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器ip地址
在这里插入图片描述
(1)反向代理实例1
实现效果: 浏览器中输入www.123.com,通过nginx定位到192.168.17.129:80,然后再转发到127.0.0.1:8000,对外暴露的是192.168.17.129:80,域名www.123.com在windows的host文件进行配置。

http {
    include       mime.types;
    default_type  application/octet-stream;

    #access_log  logs/access.log  main;

    sendfile        on;

    #gzip  on;
    # sever和虚拟机有密切关系,包括全局sever块和location块
    server {
        # 监听的端口号是8080端口号
        listen       8080;
        # 监听的主机名称是localhost
        server_name  192.168.17.128;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
        # 在访问192.168.17.128的时候会通过location给你进行转接
        location / {
            root   D:/vue3管理系统/admin/dist/;
            # 当访问到192.168.17.1288080的时候,就会给咱们转发到http://127.0.0.1:8080
            proxy_pass http://127.0.0.1:8080;
            index  index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
       
        #\.php$相当于是个路径正则校验,当你访问的路径中有\.php$,然后做一些请求的跳转
        # 或者是相关的操作
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}
    }

}

(2)反向代理实例2
实现效果:使用nginx反向代理,根据访问的路径跳转到不同端口的服务中,nginx监听端口为9001
(1)访问http://127.0.0.1:9001/edu/的时候直接跳转到127.0.0.1:8081
(2)访问http://127.0…0.1:9001/vod/的时候直接跳转到127.0.0.1:8082

server {
       listen       9001;
       server_name  192.168.17.129;
    #    ~  这个符号表示咱们用的是正则校验,
    # 当路径中有edu,就给转发到http://localhost:8081
       location ~ /edu/ {
            proxy_pass http://localhost:8081;
       }
    #    当路径中有vod,就给转发到http://localhost:8002
       location ~ /vod/ {
            proxy_pass http://localhost:8002;
       }
}

负载均衡(也可以叫请求均衡)

#实现效果:(1)在浏览器地址栏中输入地址http://192.168.17.129/edu/a.html,负载均衡效果 平均8080和8081端口中

在这里插入图片描述

http {
    # 已进行负载均衡的ip列表
    # myserver是起的名字
    upstream myserver {
        # 分配策略
        # (1)轮询
        # 默认策略:每个请求按时间顺序注意分配到不同的后端服务器,服务器当季会自动剔除服务器

        #  (2)weight
        # weight代表权重,权重约个奥被分配的客户端越多
        server 192.168.17.128:8080 weight = 1;
        server 192.168.17.128:8180 weight = 1;
        # (3)ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个
        # 后端服务器,可以解决session的问题(第一次访问的是哪台服务器,以后就访问哪台服务器)

        # ip_hash
        # server 192.168.17.128:8080 ;
        # server 192.168.17.128:8180 ;

        # (4)fair第三方
        # 按照后端服务器的响应时间分配请求,响应时间端的优先分配

        # server 192.168.17.128:8080 ;
        # server 192.168.17.128:8180 ;
        # fair;
    }
    server {
        # 监听的端口号是8080端口号
        listen       8080;
        # 监听的主机名称是localhost
        server_name  192.168.17.128;
        # 在访问192.168.17.128的时候会通过location给你进行转接
        location / {
            root   html;
            # 当访问到192.168.17.1288080的时候,就会给咱们转发到					#http://127.0.0.1:8080	
            proxy_pass http://myserver;
            index  index.html index.htm;
        }

}

动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器解析,加快解析的进度,降低单个服务器的压力。
通过location指定不同的后缀名实现不同的请求转发。通过expires参数设置,可以使浏览器缓存过期时间,减少与服务器之前的请求与流量。具体Expires定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。此种方法非常适合不经常变动的资源。我这里设置3d,表示在这三天之内访问这个url,发送一个请求,比对服务器该文件最后时间有没有变化,则不会从服务器抓取,返回状态码304.如有修改,则直接从服务器重新下载,返回状态码200+。


# 三部分组成
# (1)全局块
# 从配置文件开始到events块之间的内容,主要会设置一些影响nginx服务器整体运行的配置指令,主要包括
# 运行nginx服务器的用户,允许生成的worker process数,锦程PID存放路径,日志存放路径和类型以及
# 配置文件的引入


# (2)events块
# (3)http块


# 全局块
#user  nobody;


# 表示nginx服务器并发处理服务的关键配置,worker_process值越大,可以支持的并发处理量也越多
# 但是会受到硬件,软件等设备的制约
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;



# 主要影响nginx服务器与用户的网络连接,常用的设置包括是否开启对work process下的
# 网络连接进行序列化,是否允许同事接收多个网络连接,选取哪种事件驱动模型来处理连接
# 请求,每个word process可以同时支持的最大连接数
events {
    worker_connections  1024;
}

# 实现效果
# (1)在浏览器地址栏中输入地址http://192.168.17.129/edu/a.html,负载均衡效果
# 平均80808081端口中
# (


http {
    }
    server {
        # 监听的端口号是8080端口号
        listen       8080;
        # 监听的主机名称是localhost
        server_name  192.168.17.128;
        # 在访问192.168.17.128的时候会通过location给你进行转接
        location /www/ {
            root   /data/;
            index  index.html index.htm;
        }
        # 访问路径http://192.168.17.128/image/01.jpg
        location /image/ {
            root   /data/;
            autoindex on;
        }
}

高可用
在这里插入图片描述
如何实现:
在这里插入图片描述


http://www.niftyadmin.cn/n/5102743.html

相关文章

动态规划解股票类型

文章目录 单只股票买卖多次买卖单只股票最多两次买卖股票最多买k次含冷静期含手续费 单只股票买卖 买卖股票的最佳时机 关键思路:找到一个值,他与之后的最大值之差最大。 用minprice记录最小的值,用maxprofit记录最大的收益。 想清楚一个点…

使用Python找到相似图片的方法

使用Python找到相似图片的方法 作者:安静到无声 个人主页 摘要:在日常生活中,我们可能会遇到需要查找相似图片的情况。例如,我们可能有一张图片,并希望找到文件夹中与该图片相似的其他图片。本文将介绍如何使用Pytho…

Unity Mono和.Net平台浮点算法的区别

static void TestFloat(){{//float speed2.0f/20;float speed 0.1f;float distance 2.0f;long needTime (long)(distance / speed);Log.Debug($"needTime{needTime}"); #if UNITY_EDITORif (needTime ! 19) #elseif (needTime ! 20)//.Net服务器和安卓手机 #endif…

CAP理论及BASE思想等

今天说些和分布式系统中的一些概念、理论相关的东西,切入点是CAP。 CAP CAP理论是由Brewer远在2000年的PODC会议上提出来的。CAP指的是:Consistency、Availability和Partition?Tolerance,下面简述此三者: 1、Consistency&…

34 机器学习(二):数据准备|knn

文章目录 数据准备数据下载数据切割转换器估计器 kNN正常的流程网格多折交叉训练原理讲解距离度量欧式距离(Euclidean Distance)曼哈顿距离(Manhattan Distance)切比雪夫距离 (Chebyshev Distance)还有一些自定义的距离 就请读者自行研究 再识K-近邻算法API选择n邻居的思辨总结…

离线语音与IoT结合:智能家居发展新增长点

离线语音控制和物联网(IoT)相结合在家居中具有广泛的应用和许多优势。离线语音控制是指在设备在本地进行语音识别和处理,而不需要依赖云服务器进行处理。IoT是指借助网络,通过手机APP、小程序远程控制家居设备。 启英泰伦基于AI语…

AdvancedCombine/高级组合,Futures/转义闭包转换为未来发布者 的详细使用

1. 创建详细使用的高级组合 View AdvancedCombineBootcamp.swift import SwiftUI import Combine/// 数据服务 class AdvancedCombineDataService{// Published var basicPublisher: String "first publish"// CurrentValueSubject 通用函数// let currentValuePub…

MySql 数据库基础概念,基本简单操作及数据类型介绍

文章目录 数据库基础为什么需要数据库?创建数据库mysql架构SQL语句分类编码集修改数据库属性数据库备份 表的基本操作存在时更新,不存在时插入 数据类型日期类型enum和set 数据库基础 以特定的格式保存文件,叫做数据库,这是狭义上…