UNIX网络编程卷1 服务器程序设计范式4 预先派生子进程,以线程互斥锁上锁方式保护accept

时间:2021-12-19 18:26:30

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie


1.文件上锁文件系统操作,比较耗时
2.线程上锁,不仅适用于同一进程内各线程之间的上锁,也适用于不同进程之间的上锁。
3.在不同进程之间使用线程上锁要求:
1)互斥锁变量必须存放在由所有进程共享的内存区中
2)必须告知线程函数库这是在不同进程之间共享的互斥锁


/* include my_lock_init */
#include	"unpthread.h"
#include	<sys/mman.h>


static pthread_mutex_t	*mptr;	/* actual mutex will be in shared memory */


void
my_lock_init(char *pathname)
{
	int		fd;
	pthread_mutexattr_t	mattr;


	fd = Open("/dev/zero", O_RDWR, 0);


	//1.使用 mmap 函数将 /dev/zero 映射到内存中
	mptr = Mmap(0, sizeof(pthread_mutex_t), PROT_READ | PROT_WRITE,
				MAP_SHARED, fd, 0);


	//关闭描述符,因为该描述符已被内存映射了
	Close(fd);


	//2.调用一些 Pthread 库函数以告诉该函数库:这是一个位于共享内存区中的互斥锁,
	//将用于不同进程之间的上锁
	Pthread_mutexattr_init(&mattr); //首先为一个互斥锁以默认属性初始化一个 pthread_mutexattr_t 结构
	Pthread_mutexattr_setpshared(&mattr, PTHREAD_PROCESS_SHARED); //然后赋予该结构 PTHREAD_PROCESS_SHARED 的属性,使它可以在多个进程内使用
	Pthread_mutex_init(mptr, &mattr); // 最后调用 pthread_mutex_init 函数以这些属性初始化共享内存区中的互斥锁
}
/* end my_lock_init */


/* include my_lock_wait */
void
my_lock_wait()
{
	Pthread_mutex_lock(mptr);
}


void
my_lock_release()
{
	Pthread_mutex_unlock(mptr);
}
/* end my_lock_wait */