nginx和CDN应用

目录

1.代理的工作机制

2.代理服务器的概念

3.代理服务器的作用

4.常见的缓存代理应用

5.nginx缓存代理部署

[5.1 yum安装三台nginx](#5.1 yum安装三台nginx)

[5.2 准备测试界面](#5.2 准备测试界面)

[5.3 设置nginx缓存服务器配置](#5.3 设置nginx缓存服务器配置)

[5.4 网页测试](#5.4 网页测试)

6.CDN概念及作用

[6.1 CDN的工作过程](#6.1 CDN的工作过程)

[6.2 CDN是如何获取内容?](#6.2 CDN是如何获取内容?)


1.代理的工作机制

(1)代替客户机向网站请求数据,从而可以隐藏用户的真实IP地址。
(2)将获得的网页数据(静态Web元素)保存到缓存中并发送给客户机,以便下次请求相同的数据时快速响应。

2.代理服务器的概念

代理服务器是一个位于客户端和原始(资源)服务器之间的服务器,为了从原始服务器取得内容,客户端向代理服务器发送一个请求并指定目标原始服务器,然后代理服务器向原始服务器转交请求并将获得的内容返回给客户端。

缓存代理对于Web至关重要,尤其对于大型高负载Web站点。缓存可作为性能优化的一个重要手段,可以极大减轻后端服务器的负载。通常对于静态资源,即较少经常更新的资源,如图片,css或js等进行缓存,从而在每次刷新浏览器的时候,不用重新请求,而是从缓存里面读取,这样就可以减轻服务器的压力。

3.代理服务器的作用

资源获取:代替客户端实现从原始服务器的资源获取;
加速访问:代理服务器可能离原始服务器更近,从而起到一定的加速作用;
缓存作用:代理服务器保存从原始服务器所获取的资源,从而实现客户端快速的获取;
隐藏真实地址:代理服务器代替客户端去获取原始服务器资源,从而隐藏客户端真实信息。

4.常见的缓存代理应用

本地实现:squid、nginx、varnish
云环境远端实现:CDN

数据库缓存代理:Redis、Memcached

CDN在云场景中 使用比较多 大量广泛使用

Squid和varnish 传统应用 用得不多

性能上Squid和varnish比较好 但是nginx的管理更加方便

5.nginx缓存代理部署

准备三台服务器:192.168.9.114;192.168.9.115;192.168.9.116

5.1 yum安装三台nginx

所有虚拟机

复制代码
初始化操作
systemctl disable --now firewalld
setenforce 0
vim /etc/selinux/config
SELINUX=disabled
cd /etc/yum.repos.d
将nginx.repo拖入各服务器
yum install -y nginx
systemctl enable --now nginx

5.2 准备测试界面

192.168.9.115;

复制代码
cd /usr/share/nginx/html
--------------------------------------------------------------------

vim test.html
<html>
<body>
<h1>this is test web page</h1>
<img src="111.png">
</body>
</html>
---------------------------------------------------------------------

在该目录下上传111.png和222.png两张测试图片

网页测试:

192.168.9.116;

复制代码
cd /usr/share/nginx/html
--------------------------------------------------------------------

vim test.html
<html>
<body>
<h1>this is test2 web page</h1>
<img src="222.png">
</body>
</html>
---------------------------------------------------------------------

在该目录下上传111.png和222.png两张测试图片

网页测试:

192.168.9.115;192.168.9.116。关闭两台服务器长连接

systemctl restart nginx重启服务

5.3 设置nginx缓存服务器配置

192.168.9.114

复制代码
mkdir /data/nginx/cache -p
chown nginx:nginx /data/nginx/cache

vim /etc/nginx/nginx.conf
proxy_cache_path /data/nginx/cache levels=1 keys_zone=my_cache:    10m max_size=10g inactive=60m use_temp_path=off;   #31行添加

#####################################################
●path:强制参数,指定缓存文件的存放路径。
●levels:定义了缓存目录的层级。每层可以用1(最多16种选择,0-f)或2(最多256种选择,00-ff)表示,中间用 : 分隔。
proxy_cache_path /data/nginx/cache;  代表所有缓存只有一个目录,比如/data/nginx/cache/d7b6e5978e3f042f52e875005925e51b
proxy_cache_path /data/nginx/cache levels=1:2;  代表缓存是二层目录(有16*256=4096个目录),比如/data/nginx/cache/b/51/d7b6e5978e3f042f52e875005925e51b
●keys_zone:强制参数,定义共享内存区的名称和大小,该共享内存用于保存缓存项目的元数据(所有活动的key和缓存数据相关的信息),这样nginx可以快速判断一个request是否命中或者未命中缓存,1m可以存储8000个key,10m可以存储80000个key。
●inactive:删除指定时间内未被访问的缓存文件,默认10分钟。
●max_size:设置了缓存存储的上限,如果不指定,最大会用掉所有磁盘空间。
●use_temp_path:直接把临时文件放在缓存目录中。
#####################################################


upstream webservers {
         server 192.168.9.115:80;
         server 192.168.9.116:80;
 }
  ###定义服务器池
复制代码
vim /etc/nginx/conf.d/default.conf
删除原本8.9两行

    server {
        listen 80;
        server_name www.xy101.com;
        location / {
            proxy_cache my_cache;               #指定用于页面缓存的共享内存,zone名称由proxy_cache_path指令定义
            proxy_cache_valid 200 60m;          #为不同的响应状态码设置不同的缓存时间,此为缓存状态码为200的请求,缓存时长为60分钟
            proxy_cache_key $request_uri;       #指定缓存文件的key为请求的URI
            add_header Nginx-Cache-Status $upstream_cache_status;      #把缓存状态设置为头部信息,响应给客户端
            proxy_pass http://webservers;     #设置代理转发的后端服务器的协议和地址
        }
    
systemctl restart nginx

5.4 网页测试

6.CDN概念及作用

CDN的全称是Content Delivery Network,即内容分发网络。其目的是通过在现有的Internet中增加一层新的CACHE(缓存)层,将网站的内容发布到最接近用户的网络"边缘"的节点,使用户可以就近取得所需的内容(就近原则),提高用户访问网站的响应速度。从技术上全面解决由于网络带宽小、用户访问量大、网点分布不均等原因,提高用户访问网站的响应速度。

CDN的优势:

(1)CDN节点解决了跨运营商和跨地域访问的问题,访问延时大大降低;
(2)大部分请求在CDN边缘节点完成,CDN起到了分流作用,减轻了源站的负载。

6.1 CDN的工作过程

6.2 CDN是如何获取内容?

1.让用户直接访问资源,如果CDN有资源则可以命中缓存并直接响应返回给用户;如果没有命中到缓存,则会将请求发送给上游源站点服务器获取资源,并同步到CDN的缓存中

2.对于热点资源,则要预先做缓存预热,再让用户访问资源,即可直接命中CDN中的缓存直接响应返回给用户

相关推荐
倔强的石头_19 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神2 天前
三、用户与权限管理
数据库·mysql
大树883 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质3 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
小宇宙Zz3 天前
Maven依赖冲突
java·服务器·maven
Inhand陈工3 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智3 天前
ARP代理--工作原理
运维·网络·arp·arp代理