Nginx源代码分析—进程间通信机制

从nginx的进程模型能够知道。master进程和worker进程须要通信,nginx中通信的方式有套接字、共享内存、信号。对于master进程,从外部接受信号,master进程主要就是监控、接受外部信号,将有必要的信号传递给worker进程,master进程大部分时间都是堵塞在sigsuspend()函数调用上。Worker进程屏蔽了全部的外部信号,那么Master进程就通过套接字和worker进程通信,worker进程改动全局变量,使得worker进程接受到了master进程的命令(进程间的套接字被epoll监控)。

共享内存是存放父子进程中都须要的全局变量,比方当前系统接受到的连接,正在处理的连接数目等。

既然使用了共享内存,那么就须要考虑同步,nginx中的同步使用了原子操作、文件锁、信号量(这里信号量的值为1,也就是相当于一个相互排斥锁)。虽说实现了这三种。可是对外都是使用了ngx_shmtx_t变量,这个变量成为一个相互排斥锁。使用上述三种同步方式实现了一种对外的相互排斥锁,接下来看看实现方式:

首先声明一点,在nginx中都是非堵塞的,所以在获取锁的时候也希望是非堵塞的

对于共享内存,使用shmgt &mmap(能够实现文件到内存的映射。也能够不使用文件的方式来实现映射)来实现,共享内存中存放的变量有已经建立成功的TCP连接数、已经处理过的TCP连接数等共6类。共享内存的初始化在Main中实现。共享内存中数据的初始化在ngx_event_module_init函数中实现

上述几种锁的属性设计到堵塞&非堵塞 导致睡眠&不导致睡眠,至于堵塞和非堵塞就是看是否能立即得到调用的结果,依据前提条件选择不同的锁,比方这里用原子操作实现的自旋锁就是堵塞锁。就是假设没有获取锁,那么就连续不断的尝试一段时间,假设是想占有一个被短时间占用的资源的话。能够使用这样的堵塞锁,,假设占用的时间过长,不适合使用堵塞锁,会占用过多的CPU资源。睡眠锁就是在获取锁不成功会导致进程睡眠。缺点是一旦睡眠须要还有一个进程来唤醒,逻辑复杂同一时候CPU的切换消耗时间。

用户能够从锁的使用时间长短角度来选择使用哪一种锁,当锁的使用时间非常短,可使用自旋锁。假设锁使用时间长,使用睡眠锁。堵塞锁就是在一段时间上不停的获取锁直到锁获取成功。

信号量和文件锁都是睡眠锁,信号量使用的sem_wait,文件锁使用fcntl(),只是在死啊用的时候要么成功。要么睡眠。

信号量sem_init能够用于线程间也能够用于进程间。实现相互排斥锁的方法:信号量为0。嗲用sem_post加1。不会有堵塞,调用sem_wait将信号量间1,假设信号量不大于0。就堵塞当前进程(进程进入睡眠),直到其它进程将信号量的值为正数后,这时才干继续通过信号量减1而使得当前进程继续进行。Sem_post解锁,sem_wait实现加锁。

对于稳健锁。ngx_trylock_fd实现不会堵塞,不会使得进程睡眠的相互排斥锁,ngx_lock_fd提供的相互排斥锁在锁已经被的进程拿到时将会导致当前进程进入睡眠状态。

基于原子操作,信号量文件锁。Ngxin封装了一个相互排斥锁。

原子变量锁优先级高于文件锁。

假设不支持原子操作。会使用文件锁实现ngx_shmtx_t相互排斥锁,使用文件锁来提供堵塞、非堵塞的相互排斥锁。

支持原子操作却不支持信号量

支持原子操作的同一时候。操作系统也支持信号量

后两种的差别在于,支持信号量仅仅会影响进程ngx_shmtx_lock方法持有锁的方式,不支持信号量时,和自旋锁一样,支持信号量。自旋锁在堵塞一段时间后没有获取锁,那么信号量导致进程进入睡眠状态,仅仅有等到别的进程释放这个锁才会被激活

在不使用信号量时,nginx相互排斥锁和自旋锁相似,而在使用信号量后将会使用可能让进程进入睡眠,不建议使用带信号量的ngx_shmtx_lock取锁方法。

事实上做了这么多的封装也是为了系统可移植

nginx源代码分析--进程间通信机制 & 同步机制的更多相关文章

  1. MySQL系列:innodb源代码分析之线程并发同步机制

    innodb是一个多线程并发的存储引擎,内部的读写都是用多线程来实现的,所以innodb内部实现了一个比較高效的并发同步机制. innodb并没有直接使用系统提供的锁(latch)同步结构,而是对其进 ...

  2. 新秀nginx源代码分析数据结构篇(四)红黑树ngx_rbtree_t

    新秀nginx源代码分析数据结构篇(四)红黑树ngx_rbtree_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csd ...

  3. 新秀nginx源代码分析数据结构篇(两) 双链表ngx_queue_t

    nginx源代码分析数据结构篇(两) 双链表ngx_queue_t Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csdn. ...

  4. Nginx源代码分析—业务流程

    Nginx源代码分析-业务流程 到此为止,我们如果ngx_init_cycle已经结束.我们临时无论他做了什么,我们从他做的效果进入. 从常理上来讲,假设一个请求到达,那么我们须要接受这个请求,那么就 ...

  5. 从源代码分析Android-Universal-Image-Loader的缓存处理机制

    讲到缓存,平时流水线上的码农一定觉得这是一个高大上的东西.看过网上各种讲缓存原理的文章,总感觉那些文章讲的就是玩具,能用吗?这次我将带你一起看过UIL这个国内外大牛都追捧的图片缓存类库的缓存处理机制. ...

  6. 分析.Net里线程同步机制

    我 们知道并行编程模型两种:一种是基于消息式的,第二种是基于共享内存式的. 前段时间项目中遇到了第二种 使用多线程开发并行程序共享资源的问题 ,今天以实际案例出发对.net里的共享内存式的线程同步机制 ...

  7. nginx源代码分析--高性能server开发 常见的流程模型

    1.高性能server 对于高性能server对于.处理速度和占用空间小是典型特性.特别是当server经验C10K问题的时候(网络server在处理数以万计的client连接时.往往出现效率低下甚至 ...

  8. 内核同步机制-RCU同步机制

    转自:https://blog.csdn.net/nevil/article/details/7718375 转自http://www.360doc.com/content/09/0805/00/36 ...

  9. nginx源代码分析之内存池实现原理

    建议看本文档时结合nginx源代码. 1.1   什么是内存池?为什么要引入内存池? 内存池实质上是接替OS进行内存管理.应用程序申请内存时不再与OS打交道.而是从内存池中申请内存或者释放内存到内存池 ...

随机推荐

  1. W3C标准冒泡、捕获机制

    (一) 捕获和冒泡如何相互影响 我们来做几个任务吧! 有一个前提,#parent为标签,#child为子标签,他们是嵌套关系支线任务1 //捕获模式 document.getElementById(' ...

  2. checked、disabled在原生、jquery、vue下不同写法

          以下是原生和jquery <!DOCTYPE html> <html> <head> <meta http-equiv="Content ...

  3. GO 协程 通道实例以及验证SnowFlake算法

    最近项目中使用了SnowFlake算法产生ID,并在实际运行环境下会产生重复ID,所以写了一个Go的程序进行验证,顺便也练习一下Go的协程与通道. 至于GO的协程和通道的基础知识请自行百度. 代码如下 ...

  4. Android App 开机启动画面和开机自动启动APP程序设置

    1.当前比较成熟一点的应用基本上都会在进入应用之显示一个启动界面 如腾讯微博 2.准备元素  需要开机启动的图片一张 3.新建Activity AlphaAnimation动画:控制对象alpha水平 ...

  5. Java code List Map, HashMap, JSON parser snippet

    package com.newegg.ec.solr.eventsalestoreservice.tuple; import kafka.message.MessageAndMetadata; pub ...

  6. 点云处理软件Pointscene

    转载于PCL中国:点云处理软件Pointscene 软件官网:https://pointscene.com/ 笔者评:        Pointscene是目前的点云处理软件之一,其主要是操作简单直观 ...

  7. [读书笔记]-技术学习-Redis

    1:Redis概览 Remote Dictionary Server 远程字典服务 Redis是基于内存的存储 在一台普通的笔记本上,Redis每秒的读取速度可以达到10万 内存读取数据,断电的时候数 ...

  8. fileupload 上传控件

    <div> <asp:FileUpload ID="FileUpload1" runat="server" /> <asp:But ...

  9. 【剑指Offer】61、序列化二叉树

      题目描述:   请实现两个函数,分别用来序列化和反序列化二叉树.   解题思路:   序列化是指将结构化的对象转化为字节流以便在网络上传输或写到磁盘进行永久存储的过程.反序列化是指将字节流转回结构 ...

  10. kernel panic必备知识

    获得vmcore Kernel dump 是什么 Kdump – 捕捉kernel dump的工具 Kdump的工作原理 Kdump的配置 Dump分析的工具crash(1) 准备环境 根据vmcor ...