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

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

你可能感兴趣的文章
基于CenOS搭建VNC远程桌面服务
查看>>
正则表达式的基本知识点
查看>>
Using Python With Oracle Database 11g 精简版
查看>>
搭建openstack实战部署
查看>>
cisco ipsec *** 配置
查看>>
coursera专项课程——程序设计与算法简介
查看>>
Open***完美解决公司网络没有固定公网IP的问题
查看>>
配置ASA实现内网、DMZ和外网的访问
查看>>
DHCP的工作原理
查看>>
Linux 的五个重启命令及具体说明
查看>>
rsync linux同步到windows
查看>>
利用Perl检测系统中与系统用户相关的进程
查看>>
Nginx配置为简单的文件服务器
查看>>
电源故障导致的USB接口失效
查看>>
ORACLE查询优化
查看>>
RedHat6.1和CentOS7网络配置
查看>>
谢烟客---------Linux之bash脚本编程---if补充和for循环
查看>>
网站分层架构图解
查看>>
web目录权限设置(待完善)
查看>>
N皇后问题
查看>>