线程锁、进程锁、分布式锁_Linux网络编程

线程锁

1、互斥锁:互斥锁首先是一个睡眠锁,如下图当线程C没有获取到资源时,线程锁会结束线程B切换到线程C。

2、自旋锁:而自旋锁在未获取到资源时线程C循环等待,尝试获取锁,一直占用核心。

3、读写锁:若一个线程获取到读(写)操作,则其他线程的写(读)操作被禁止。

4、条件变量:当达到条件变量时,我们通过发送信号或者广播的方式唤醒其他的线程

4、信号量,

5、原子锁

问题一、什么时候使用互斥锁,什么时候使用自旋锁?

互斥锁:超过CPU切换时间,使用互斥锁

自旋锁:时间短,充分利用资源,避免线程的切换影响效率--niginx、skynet

进程锁

进程锁:解决一个机器中进程间进程资源分配问题。

关于进程锁,我们首先要了解一下进程锁的nginx实现。

提问:nginx监听器是在master进程还是worker进程?

答:worker进程。

提问:worker进程如何负载均衡处理连接或者请求?

答:worker进程间通过共享内存获取资源,LInux使用shmget mmap分配共享内存,可以通过给每个worker加锁的方式,这样worker或是在休眠等待资源或是在循环等待获取资源。

下面介绍一个自旋锁的代码实现;

cpp 复制代码
typedef struct{
	ngx_atomic_t lock;
	#if(NGX_HAVE_ATOMIC_OPS)//判断系统中是否有原子锁
	ngx_automic_t *lock;
	#if(NGX_HAVE_POSIX_SEM)//判断系统是否支持信号量
	ngx_automic_t *wait;
	ngx_uint_t semaphore;
	sem_t sem;
	#endif
	#else
		ngx_uint_t fd;
		u_char *name;
	#endif
		ngx_uint_t spin;//存储
}ngx_shmtx_t;

在一些源码和框架中自旋锁和互斥锁是可以同时使用的,通过设计首先使用自旋锁,超过一定的时间再使用互斥锁。

相关推荐
艾莉丝努力练剑17 小时前
【Linux网络】五种IO模型与非阻塞IO
linux·运维·服务器·开发语言·网络·tcp/ip
王小王-12317 小时前
基于 Hadoop 的心脏病分析可视化与风险预测系统
大数据·hadoop·分布式·心脏病预测系统·疾病预测·冠心病风险预测
lihao lihao17 小时前
Linux线程同步与互斥
linux·数据结构·算法
云飞云共享云桌面17 小时前
集中算力・统一数据・高效协同:SolidWorks 云桌面方案详解
运维·服务器·人工智能·安全·3d·电脑·制造
爱喝水的鱼丶17 小时前
SAP-ABAP:SAP表与视图权限管控方案:表维护权限、视图访问权限配置实操
运维·数据库·性能优化·sap·abap·权限·表和视图
能喵烧香1 天前
深度解析:Linux 与 Windows 超级权限账户的本质差异
linux·windows
江畔柳前堤1 天前
github实战指南01-账号配置与 SSH 密钥
运维·人工智能·深度学习·ssh·github·pyqt·信号处理
Moshow郑锴1 天前
Ubuntu 26.04 中文输入法 : fcitx5+Rime中州韵引擎
linux·运维·ubuntu
qq_163135751 天前
Linux 【04-more命令超详细教程】
linux
sevencheng7981 天前
【ADB】adb命令行常用按键模拟代码
linux·adb·模拟按键,返回键,音量键