博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
nginx内部锁的实现
阅读量:5815 次
发布时间:2019-06-18

本文共 591 字,大约阅读时间需要 1 分钟。

多进程或者多线程的程序,涉及到对共享资源的修改,都需要使用到锁。最常见的情况(也一般是然并卵的情况)是对一个全局变量进行++操作,比如有个全局变量i,如果多个线程同时执行i++,教科书已经提到,是会出问题的。因为i++并不是一个原子操作,汇编之后会是三个操作:

movl    i(%rip), %eax    addl    $1, %eax    movl    %eax, i(%rip)

这时候就需要锁了(当然,这里的情况,你也可以嵌入汇编的方式使用的方式来避免使用锁,不过,在多核情况下,你仍然需要加上)。Nginx 是一个多进程的服务,并且引入了线程池,不可避免也需要用到锁。

Nginx内部锁的种类

读写锁

相关的代码在src/core/ngx_rwlock.[hc]

自旋锁

相关的代码在src/core/ngx_spinlock.c

基于共享内存的互斥锁

相关的代码在src/core/ngx_shmtx.[hc]。之所以需要这个,是因为Nginx中存在多个进程,在某些操作时,比如对监听的fd执行accept()操作,需要互斥进行。而由于跨了多个进程,只能将用于实现lock的内存放在共享内存。

锁的实现

看下ngx_spinlock()ngx_shmtx_lock()的代码,会发现都使用了ngx_atomic_cmp_set()这个函数。

未完待续。。

转载地址:http://uvxbx.baihongyu.com/

你可能感兴趣的文章
青花瓷抓包详细步骤
查看>>
...
查看>>
maven常遇到的问题
查看>>
Zabbix监控网络设备
查看>>
【Spring学习笔记】之【4.4 资源之Resource通配符路径】
查看>>
Unicode 与 UTF-8
查看>>
nginx在windows下安装
查看>>
Bootstrap 3.2.0 源码试读 2014/08/07
查看>>
rabbitmq 在centos下的安装(实战)
查看>>
Spring中装配集合
查看>>
CSS字体中英文名称对照表 CSS常用中文字体英文名称对照表
查看>>
Fastreport.Net用户手册:报表选项
查看>>
Spring Boot教程--Actuator监控介绍
查看>>
Linux学习134 Unit 2
查看>>
shell编程基础(二)
查看>>
LS1012A工控主板基于NXP公司
查看>>
无VLAN配置的交换机的工作原理
查看>>
5、Linux文件和目录管理
查看>>
CSS选择器
查看>>
腾讯云安全专家 Killer 告诉你,企业上云怎么做更安全
查看>>