数据结构— —队列企业级web服务器队列的应用

简介: 数据结构— —队列企业级web服务器队列的应用

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

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


具体实现方案:

完整代码:

nginx_queue.h

#ifndef _NGX_QUEUE_H_INCLUDED_
#define _NGX_QUEUE_H_INCLUDED_
typedef struct ngx_queue_s ngx_queue_t;
struct ngx_queue_s 
{
    ngx_queue_t *prev;
    ngx_queue_t *next;
};
#define ngx_queue_init(q)
(q)->prev = q;
(q)->next = q;
#define ngx_queue_empty(h)
(h == (h)->prev)
#define ngx_queue_insert_head(h, x)
(x)->next = (h)->next;
(x)->next->prev = x;
(x)->prev = h;
(h)->next = x;
#define ngx_queue_insert_after ngx_queue_insert_head
#define ngx_queue_insert_tail(h, x)
(x)->prev = (h)->prev;
(x)->prev->next = x;
(x)->next = h;
(h)->prev = x;
#define ngx_queue_head(h)
(h)->next;
#define ngx_queue_last(h)
(h)->prev
#define ngx_queue_sentinel(h)
(h)
#define ngx_queue_next(q)
(q)->next
#define ngx_queue_prev(q)
(q)->prev
#define ngx_queue_remove(x)
(x)->next->prev = (x)->prev;
(x)->prev->next = (x)->next
#define ngx_queue_data(q, type, link)
(type *) ((char *) q - offsetof(type, link))
#endif


Nginx_双向循环队列.cpp

#include <Windows.h>
#include <stdlib.h>
#include <iostream>
#include "nginx_queue.h"
#include <time.h>
using namespace std;
typedef struct ngx_cached_open_file_s 
{
    //其它属性省略...
    int fd;
    ngx_queue_t queue;
}ngx_cached_file_t;
typedef struct 
{
    //其它属性省略...
    ngx_queue_t expire_queue;
    //其它属性省略...
} ngx_open_file_cache_t;
int main(void)
{
    ngx_open_file_cache_t *cache = new ngx_open_file_cache_t;
    ngx_queue_t *q;
    ngx_queue_init(&cache->expire_queue);
    //1. 模拟文件模块,增加打开的文件到缓存中
    for(int i=0; i<10; i++)
    {
        ngx_cached_file_t *e = new ngx_cached_file_t;
        e->fd = i;
        ngx_queue_insert_head(&cache->expire_queue, &e->queue);
}
    //遍历队列
    for(q=cache->expire_queue.next;
    q!=ngx_queue_sentinel(&cache->expire_queue); 
    q=q->next)
    {
        printf("队列中的元素:%d\n", (ngx_queue_data(q,ngx_cached_file_t, queue))->fd);
    }
    //模拟缓存的文件到期,执行出列操作
    while(!ngx_queue_empty(&cache->expire_queue))
    {
        q=ngx_queue_last(&cache->expire_queue);
        ngx_cached_file_t *cached_file = ngx_queue_data(q,
        ngx_cached_file_t, queue);
        printf("出队列中的元素:%d\n", cached_file->fd);
        ngx_queue_remove(q);
        delete(cached_file);
    }
    system("pause");
    return 0;
}


相关文章
|
1天前
|
Apache Windows
windows 一键安装apache服务器 windows傻瓜式安装apache2 web服务器管理软件
windows 一键安装apache服务器 windows傻瓜式安装apache2 web服务器管理软件
|
1天前
|
Windows
win10家庭版安装iis 微软web服务器 windows安装IIS web服务器
win10家庭版安装iis 微软web服务器 windows安装IIS web服务器
|
1天前
|
弹性计算 安全 网络安全
带你读《从基础到应用云上安全航行指南》——干货长文快收藏!阿里云专家教你如何安全访问和管理ECS资源(3)
**《从基础到应用云上安全航行指南》——阿里云专家教你如何安全访问和管理ECS资源(3)** 在阿里云的广阔云海中,ECS(弹性计算服务)资源如同航行的船只,承载着我们的业务与数据。如何确保这些
|
2天前
|
存储 缓存 算法
【数据结构】栈和队列的模拟实现(两个方式实现)
【数据结构】栈和队列的模拟实现(两个方式实现)
|
2天前
|
Java 关系型数据库 MySQL
【JavaEE进阶】部署Web项目到Linux服务器
【JavaEE进阶】部署Web项目到Linux服务器
3.栈和队列(汇总版)
3.栈和队列(汇总版)
|
3天前
|
JavaScript Serverless 网络架构
Next.js与SSR:构建高性能服务器渲染应用
创建Next.js项目使用`create-next-app`,每个页面自动支持SSR。动态路由如`pages/posts/[id]`,在`getStaticPaths`和`getServerSideProps`中获取数据。利用静态优化和预渲染提升性能,动态导入减少初始加载时间。使用`next/image`优化图片,自定义服务器增加控制,集成第三方库如Redux。优化SEO,利用i18n支持多语言,使用Serverless模式和Web Workers。项目支持TypeScript,创建`_error.js`处理错误,部署到Vercel并使用工具进行性能监控和优化。
21 4
|
3天前
|
Serverless 持续交付 测试技术
无服务器应用架构转型
【6月更文挑战第2天】Serverless架构虽新,但其软件生命周期仍遵循传统模式,需确保交付质量。
|
5天前
|
XML 网络协议 Java
XML Web 服务技术解析:WSDL 与 SOAP 原理、应用案例一览
XML Web服务是基于WSDL、SOAP、RDF和RSS等标准的网络应用程序组件技术。WSDL描述服务接口和消息格式,SOAP用于结构化信息交换,RDF描述网络资源,RSS则用于发布网站更新。Web服务特点是自包含、自描述,基于开放协议,可重用且能连接现有软件。WSDL文档包含`types`、`message`、`portType`和`binding`元素,定义服务操作和协议。SOAP协议规定消息格式,通过HTTP等传输。
453 1
|
5天前
|
前端开发 JavaScript Java
Java语言在Web前端开发中的技术应用
Java语言在Web前端开发中的技术应用