当前位置:首页 > 技术文章 > 正文内容

Nginx之进程间通信-共享内存篇

arlanguage4个月前 (01-12)技术文章39

前面我们介绍了Nginx的多进程模型,多个worker进程间通信 主要是用共享内存来实现的。

今天我们就来学习下Nginx的共享内存。

那么进程该如何创建共享内存呢?

如果按照使用我们的malloc来分配内存的话,只会分配出进程的私有内存,并不能在多个worker进程间共享。Linux为我们封装了POSIX API 如 mmap, munmap。


Nginx已经为我们封装了一套统一的接口来使用共享内存:

文件名:ngx_cycle.h

typedef struct ngx_shm_zone_s  ngx_shm_zone_t;

typedef ngx_int_t (*ngx_shm_zone_init_pt) (ngx_shm_zone_t *zone, void *data);

struct ngx_shm_zone_s {
    void                     *data;  // 
    ngx_shm_t                 shm;   // 共享内存关键结构
    ngx_shm_zone_init_pt      init;  // 初始回调函数
    void                     *tag;   // 标签 一般设置为模块名 类似包名 防止shm.name重复
    void                     *sync;
    ngx_uint_t                noreuse;  /* unsigned  noreuse:1; */
};



文件名:ngx_shmem.h

typedef struct {
    u_char      *addr;  // 分配内存的起始地址
    size_t       size;  // 内存大小
    ngx_str_t    name;  // 共享内存名称
    ngx_log_t   *log;   // 日志
    ngx_uint_t   exists;   /* unsigned  exists:1;  */
} ngx_shm_t;

// 创建共享内存快
ngx_int_t ngx_shm_alloc(ngx_shm_t *shm);
// 释放共享内存快
void ngx_shm_free(ngx_shm_t *shm);


Nginx主要使用了共享内存的模块:


这里主要用到了2种数据结构:

红黑树:比如限速,流控,缓存等。 因为这些场景需要快速增加 删除节点。

单链表:这种场景只需要把信息串起来就可以了。


Nginx为了保证多个worker进程之间同步,防止多个进程同时写共享内存块,从而引入了自旋锁。


如果进程1持有了锁,那么进程2会不停地去访问这把锁。打个比喻的话,就类似一个坑已经被进程1蹲了,那么进程2来了就在门口一直敲门。正是由于这种机制,Nginx要求所有的模块都要快速使用共享内存,即:快速获得锁,快速释放锁。一旦出现有拿着锁 长时间不放的,就会严重降低性能。

我们来一起了解一下Nginx锁的相关数据结构

文件名:ngx_shmtx.h


typedef struct {
    ngx_atomic_t   lock;
} ngx_shmtx_sh_t;


typedef struct {
    ngx_atomic_t  *lock;    // 指向ngx_shmtx_sh_t的lock锁
    ngx_uint_t     spin;    // 自选次数
} ngx_shmtx_t;

// 创建互斥锁
ngx_int_t ngx_shmtx_create(ngx_shmtx_t *mtx, ngx_shmtx_sh_t *addr, u_char *name);
// 销毁互斥锁
void ngx_shmtx_destroy(ngx_shmtx_t *mtx);
// 无阻塞试图获取互斥锁
ngx_uint_t ngx_shmtx_trylock(ngx_shmtx_t *mtx);
// 阻塞方式获取锁
void ngx_shmtx_lock(ngx_shmtx_t *mtx);
// 释放互斥锁
void ngx_shmtx_unlock(ngx_shmtx_t *mtx);


Nginx锁的操作方法:


此外,Nginx还使用了Slab管理共享内存。 下篇继续

#程序员##Nginx#

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/801.html

标签: nginx 节点
分享给朋友:

“Nginx之进程间通信-共享内存篇” 的相关文章

隐藏Nginx服务的Banner 和 隐藏Nginx后端服务指定的header的状态

一、隐藏Nginx服务的Banner当Nginx服务器响应请求时,不隐藏它的版本信息和名称。这会暴露服务器的信息,使攻击者可以获取服务器软件版本和配置的信息,帮助攻击者发现潜在的漏洞或攻击路径。以下是一些潜在的危害:1. 暴露服务器信息:不隐藏 banner 可以让攻击者知道服务器正在使用 Ngin...

Linux非root用户安装及配置Nginx

该文章用到了2次root权限,其中有一次root权限是没有必要用的,小编会在文章中进行说明。一、安装前置依赖gcc编译器(第一次需要root权限)这里我没有研究非root用户安装(因为太麻烦了),后面我会单独出一篇文章,讲解非root用户安装gcc编译器。直接使用su - 切换到root用户下面,使...

面试常问知识点:Nginx设置代理的一个注意点

前几天,重启了下Nginx代理服务,发现报错了,以下是本次的思考。1:先解决问题查看Nginx错误日志:40 SSL_do_handshake() failed (SSL: error:14094410:SSL routines:ssl3_read_bytes:sslv3 alert handsha...

nginx支持跨域的方法 nginx配置支持跨域

在nginx的配置文件中添加允许跨域的响应头。参考nginx官方文档,添加响应头的方法如下:在conf文件的server作用域中添加如下响应头:server { listen 80; # 其他配置... # 允许跨域 add_header Access-Control-Allow-...

容器中Nginx高并发参数调优实战 nginx并发量过高怎么处理

在容器化的微服务架构中,Nginx作为反向代理和负载均衡器,常常需要承担高并发访问的压力。当并发连接数超过Nginx可处理的上限时,就会出现新连接被丢弃的情况。本文将详细介绍如何发现和定位这个问题,并通过调整内核参数和Nginx配置来解决。一、问题现象某Web服务在高并发场景下,偶尔会出现部分请求无...

平稳运行半年的系统宕机了,记录一次排错调优的全过程

(一)前言最近发生了一件很让人头疼的事情,已经上线半年且平稳运行半年系统在年后早高峰的使用时发生了濒临宕机的情况。访问速度特别慢,后台查到大量time_wait的连接,从代码层面到架构层面到网络层面排查了几天几夜,总算是有了结果。(二)架构、问题描述先简单描述一下这个系统的架构,公网域名对应的公网I...