在高并发 HTTP 反向代理服务器 Nginx 中,存在着一个跟性能息息相关的模块 - 文件缓存。

                              

经常访问到的文件会被 nginx 从磁盘缓存到内存,这样可以极大的提高 Nginx 的并发能力,不过因为内存的限制,当缓存的文件数达到一定程度的时候就会采取淘汰机制,优先淘汰进入时间比较久或是最近访问很少(LRU)的队列文件。

具体实现方案:

1. 使用双向循环队列保存缓存的文件节点,这样可以实现多种淘汰策略:

比如:如果采用淘汰进入时间比较久的策略,就可以使用队列的特性,先进先出

如果要采用按照 LRU,就遍历链表,找到节点删除。

源码实现:

nginx_queue.h

 1 #ifndef _NGX_QUEUE_H_INCLUDED_
2 #define _NGX_QUEUE_H_INCLUDED_
3 typedef struct ngx_queue_s ngx_queue_t;
4
5 struct ngx_queue_s
6 {
7 ngx_queue_t* prev;
8 ngx_queue_t* next;
9 };
10
11 #define ngx_queue_init(q)    \
12 (q)->prev = q;   \
13 (q)->next = q
14 #define ngx_queue_empty(h)    \
15 (h == (h)->prev)
16 #define ngx_queue_insert_head(h, x)\
17 (x)->next = (h)->next;     \
18 (x)->next->prev = x;      \
19 (x)->prev = h;          \
20 (h)->next = x
21 #define ngx_queue_insert_after ngx_queue_insert_head
22 #define ngx_queue_insert_tail(h, x)\
23 (x)->prev = (h)->prev;      \
24 (x)->prev->next = x;       \
25 (x)->next = h;          \
26 (h)->prev = x
27 #define ngx_queue_head(h) \
28 (h)->next
29 #define ngx_queue_last(h) \
30 (h)->prev
31 #define ngx_queue_sentinel(h) \
32 (h)
33 #define ngx_queue_next(q) \
34 (q)->next
35 #define ngx_queue_prev(q) \
36 (q)->prev
37 #define ngx_queue_remove(x) \
38 (x)->next->prev = (x)->prev; \
39 (x)->prev->next = (x)->next
40 #define ngx_queue_data(q, type, link)
41 (type*)((char*)q - offsetof(type, link))
42 #endif

Nginx_双向循环队列.cpp

 1 #include <Windows.h>
2 #include <stdlib.h>
3 #include <iostream>
4 #include "nginx_queue.h"
5 #include <time.h>
6
7 using namespace std;
8
9 typedef struct ngx_cached_open_file_s
10 {
11 //其它属性省略...
12 int fd;
13 ngx_queue_t queue;
14 }ngx_cached_file_t;
15
16 typedef struct
17 {
18 //其它属性省略...
19 ngx_queue_t expire_queue;
20 //其它属性省略...
21 } ngx_open_file_cache_t;
22
23 int main(void)
24 {
25 ngx_open_file_cache_t* cache = new ngx_open_file_cache_t;
26 ngx_queue_t* q;
27 ngx_queue_init(&cache->expire_queue);
28
29 //1. 模拟文件模块,增加打开的文件到缓存中
30 for (int i = 0; i < 10; i++)
31 {
32 ngx_cached_file_t* e = new ngx_cached_file_t;
33 e->fd = i;
34 ngx_queue_insert_head(&cache->expire_queue, &e->queue);
35 }
36
37 //遍历队列
38 for (q = cache->expire_queue.next;q != ngx_queue_sentinel(&cache->expire_queue); q = q->next)
39 {
40 printf("队列中的元素:%d\n", (ngx_queue_data(q, ngx_cached_file_t, queue))->fd);
41 }
42
43 //模拟缓存的文件到期,执行出列操作
44 while (!ngx_queue_empty(&cache->expire_queue))
45 {
46 q = ngx_queue_last(&cache->expire_queue);
47 ngx_cached_file_t* cached_file = ngx_queue_data(q, ngx_cached_file_t, queue);
48 printf("出队列中的元素:%d\n", cached_file->fd);
49 ngx_queue_remove(q);
50 delete(cached_file);
51 }
52 system("pause");
53 return 0;
54 }

==================================================================================================================

应用案例——高并发 WEB 服务器队列的应用的更多相关文章

  1. nginx简介(轻量级开源高并发web服务器:大陆使用者百度、京东、新浪、网易、腾讯、淘宝等)(并发量5w)(一般网站apache够用了,而且稳定)

    nginx简介(轻量级开源高并发web服务器:大陆使用者百度.京东.新浪.网易.腾讯.淘宝等)(并发量5w)(一般网站apache够用了,而且稳定) 一.总结 1.在连接高并发的情况下,Nginx是A ...

  2. C#不用union,而是有更好的方式实现 .net自定义错误页面实现 .net自定义错误页面实现升级篇 .net捕捉全局未处理异常的3种方式 一款很不错的FLASH时种插件 关于c#中委托使用小结 WEB网站常见受攻击方式及解决办法 判断URL是否存在 提升高并发量服务器性能解决思路

    C#不用union,而是有更好的方式实现   用过C/C++的人都知道有个union,特别好用,似乎char数组到short,int,float等的转换无所不能,也确实是能,并且用起来十分方便.那C# ...

  3. 转---高并发Web服务的演变——节约系统内存和CPU

    [问底]徐汉彬:高并发Web服务的演变——节约系统内存和CPU 发表于22小时前| 4223次阅读| 来源CSDN| 22 条评论| 作者徐汉彬 问底Web服务内存CPU并发徐汉彬 摘要:现在的Web ...

  4. 高并发web系统设计

    转载自:http://blog.csdn.net/qq_26562641/article/details/53170913 一.一般高并发web系统这里的一般指的是秒杀之类的电子商务系统,比如说小米抢 ...

  5. PHP-学习大规模高并发Web系统架构及开发推荐书籍

    以下书籍内容涵盖大型网站开发中几个关键点:高可用.高性能.分布式.易扩展.如果想对大规模高并发Web系统架构及开发有很系统的学习,可以阅读以下书籍,欢迎补充! 一.<Linux企业集群—用商用硬 ...

  6. 高并发WEB网站优化方案

    一.什么是高并发在互联网时代,所讲的并发.高并发,通常是指并发访问,也就是在某个时间点,有多少个访问同时到来.比如,百度首页同时有1000个人访问,那么也就是并发为1000.通常一个系统的日PV在千万 ...

  7. 高并发Web服务的演变:节约系统内存和CPU

    一.越来越多的并发连接数 现在的Web系统面对的并发连接数在近几年呈现指数增长,高并发成为了一种常态,给Web系统带来不小的挑战.以最简单粗暴的方式解决,就是增加Web系统的机器和升级硬件配置.虽然现 ...

  8. 高并发 Web 服务的演变:节约系统内存和 CPU

    本文内容 越来越多的并发连接数 Web 前端优化,降低服务端压力 节约 Web 服务端的内存 节约 Web 服务器的 CPU 小结 一,越来越多的并发连接数 现在,Web 系统面对的并发连接数呈现指数 ...

  9. (转)高并发Web服务的演变——节约系统内存和CPU

    一.越来越多的并发连接数 现在的Web系统面对的并发连接数在近几年呈现指数增长,高并发成为了一种常态,给Web系统带来不小的挑战.以最简单粗暴的方式解决,就是增加Web系统的机器和升级硬件配置.虽然现 ...

随机推荐

  1. RTSP服务端开发概述

    一 概述 RTSP(Real Time Streaming Protocol),RFC2326,实时音视频流传输协议,是TCP/IP协议体系中的一个应用层协议.该协议定义了一对多应用程序如何有效地通过 ...

  2. python学习-pickle模块(序列化)

    简介 1 python-pickle模块 该pickle模块实现了用于序列化和反序列化Python对象结构的二进制协议. "Pickling"是将Python对象层次结构转换为字节 ...

  3. mybatis使用细节注意

    mybatis细节 增删改查ParameterType都可以不用写 解释这个属性是可选的,因为 MyBatis 可以通过类型处理器(TypeHandler)推断出具体传入语句的参数 mybatis 中 ...

  4. 在Guitar Pro中如何模拟电子管音响

    在这篇文章中,我们将使用Guitar Pro 7中的功能和工具,完成构建一个真实的电子管吉他音箱调音过程. 虽然Guitar Pro是用于创建吉他乐谱的工具,但在新版本中(主要是6和7)它也有一些模拟 ...

  5. ABBYY FineReader 15 如何为PDF文档添加页眉页脚

    页眉.页脚是文档页面顶部或底部重复出现的文本信息.很多用户会习惯在文档页面的顶部与底部区域添加页眉.页脚来展现页码.文档标题.作者姓名.品牌名称等附加信息.而ABBYY FineReader 15(W ...

  6. web自动化 下拉框、切换到新窗口

    一.下拉框 相信大家在手动测试web页面时,遇到过下拉框吧,那进行web自动化测试时,如何操作下拉框,且看下文 1.selenium中提供了方法,先导入Select方法 from selenium.w ...

  7. vue springboot利用easypoi实现简单导出

    vue springboot利用easypoi实现简单导出 前言 一.easypoi是什么? 二.使用步骤 1.传送门 2.前端vue 3.后端springboot 3.1编写实体类(我这里是dto, ...

  8. Windows下创建指定大小的文件

    前言 因为需要测试存储容量,所以需要能生成指定大小的文件. 执行 #语法:fsutil file createnew 路径和文件名 文件大小 fsutil file createnew D:\test ...

  9. F - LCS 题解(最长公共子序列记录路径)

    题目链接 题目大意 给你两个字符串,任意写出一个最长公共子序列 字符串长度小于3e3 题目思路 就是一个记录路径有一点要注意 找了好久的bug 不能直接\(dp[i][j]=dp[i-1][j-1]+ ...

  10. 基于dubbo-config api编写provider,api

    不管是XML配置还是注解方式,最终都会转换成java api对应的配置对象. provider: import com.alibaba.dubbo.config.ApplicationConfig;i ...