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

本文共 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://zesel.baihongyu.com/

你可能感兴趣的文章
js script放在head和body里面的区别
查看>>
android通用適配器
查看>>
java获取指定路径下的指定文件/java.io.File.listFiles(FilenameFilter filter)
查看>>
ecshop商品子分类点击下拉,子分类空时,直接跳转功能
查看>>
解决IE11无法下载文件的问题
查看>>
并发抢购
查看>>
操他妈的,jquery1.4以上不能用toggle()轮流切换函数
查看>>
全端project师必备技能汇总
查看>>
2015年第1周六
查看>>
what difference between libfm and libffm
查看>>
error while loading shared libraries: xxx.so.x" 错误的原因和解决办法
查看>>
mac开启22port
查看>>
广州Uber优步司机奖励政策(1月18日~1月24日)
查看>>
(笔记)Mysql命令insert into:向表中插入数据(记录)
查看>>
欢聚时代一面
查看>>
利用java concurrent 包实现日志写数据库的并发处理
查看>>
ADB高级应用
查看>>
HDU3572_Task Schedule(网络流最大流)
查看>>
Tcl 简单介绍及特性
查看>>
c#中单元测试
查看>>