Memcached源码解析之连接队列
来源:互联网 发布:自学软件测试靠谱吗 编辑:程序博客网 时间:2024/05/17 07:37
Memcached中Master线程和Worker线程之间通信连接信息时,是通过连接队列来通信的,即Master线程投递一个消息到Worker线程的连接队列中,Worker线程从连接队列中读取链接信息来执行连接操作,下面我们简单分析下Memcached的连接队列结构。
typedef struct conn_queue_item CQ_ITEM;//每个连接信息的封装struct conn_queue_item { int sfd;//accept之后的描述符 enum conn_states init_state;//连接的初始状态 int event_flags;//libevent标志 int read_buffer_size;//读取数据缓冲区大小 enum network_transport transport;//内部通信所用的协议 CQ_ITEM *next;//用于实现链表的指针};typedef struct conn_queue CQ;//连接队列的封装struct conn_queue { CQ_ITEM *head;//头指针,注意这里是单链表,不是双向链表 CQ_ITEM *tail;//尾部指针, pthread_mutex_t lock;//锁 pthread_cond_t cond;//条件变量};//连接队列初始化static void cq_init(CQ *cq) { pthread_mutex_init(&cq->lock, NULL);//初始化锁 pthread_cond_init(&cq->cond, NULL);//初始化条件变量 cq->head = NULL; cq->tail = NULL;}//获取一个连接static CQ_ITEM *cq_pop(CQ *cq) { CQ_ITEM *item; pthread_mutex_lock(&cq->lock);//执行加锁操作 item = cq->head;//获得头部指针指向的数据 if (NULL != item) { cq->head = item->next;//更新头指针信息 if (NULL == cq->head)//这里为空的话,则尾指针也为空,链表此时为空 cq->tail = NULL; } pthread_mutex_unlock(&cq->lock);//释放锁操作 return item;}//添加一个连接信息static void cq_push(CQ *cq, CQ_ITEM *item) { item->next = NULL; pthread_mutex_lock(&cq->lock);//执行加锁操作 if (NULL == cq->tail)//如果链表目前是空的 cq->head = item;//则头指针指向该结点 else cq->tail->next = item;//添加到尾部 cq->tail = item;//尾部指针后移 pthread_cond_signal(&cq->cond);//唤醒条件变量,如果有阻塞在该条件变量的线程,则会唤醒该线程 pthread_mutex_unlock(&cq->lock);}//创建连接队列static CQ_ITEM *cqi_new(void) { CQ_ITEM *item = NULL; pthread_mutex_lock(&cqi_freelist_lock);//加锁,保持数据同步 if (cqi_freelist) {//更新空闲链表信息 item = cqi_freelist; cqi_freelist = item->next; } pthread_mutex_unlock(&cqi_freelist_lock); if (NULL == item) {//如果空闲链表没有多余的链接 int i; //初始化64个空闲连接信息 item = malloc(sizeof(CQ_ITEM) * ITEMS_PER_ALLOC); if (NULL == item) return NULL; //将空闲的连接信息进行链接 for (i = 2; i < ITEMS_PER_ALLOC; i++) item[i - 1].next = &item[i]; pthread_mutex_lock(&cqi_freelist_lock); item[ITEMS_PER_ALLOC - 1].next = cqi_freelist;//加入到空闲链表中 cqi_freelist = &item[1]; pthread_mutex_unlock(&cqi_freelist_lock); } return item;}//释放item,也就是将item添加到空闲链表中static void cqi_free(CQ_ITEM *item) { pthread_mutex_lock(&cqi_freelist_lock); item->next = cqi_freelist; cqi_freelist = item; pthread_mutex_unlock(&cqi_freelist_lock);}空闲链表类似于一种连接池的实现,服务器开发中经常需要各种池操作,大家在实现类似池时,可以做参考。
0 0
- Memcached源码解析之连接队列
- Memcached源码分析之网络连接建立
- Memcached源码阅读之初始化参数解析
- Memcached源码解析之cas属性
- Memcached源码阅读之初始化参数解析
- Memcached源码解析
- Memcached源码分析 - Memcached源码分析之命令解析(2)
- Memcached源码分析:内容包括get过程、set操作、LRU操作、Hash表操作、连接队列等
- nodejs之memcached连接池
- memcached源码分析之hashtable
- memcached源码分析之hashtable
- Memcached源码分析之二
- Memcached源码分析之三
- memcached源码分析之四
- MEMCACHED源码之main初始化
- Memcached源码解析--多线程网络模型
- Memcached源码解析--多线程网络模型
- Memcached源码解析--多线程网络模型
- 基本招式--单例模式
- QueryMobile + PhoneGap 经验总结
- VMware9安装Ubuntu 12.10图文详细教程
- codeforces 405B Domino Effect (模拟题,中等难度,细心就能一遍AC)
- Codeforces 368B Sereja and Suffixes(map去重)
- Memcached源码解析之连接队列
- Android Service AIDL
- ajaxfileupload修复版
- cocos2d-x学习笔记(持续更新)
- Android与java的关系
- 跟我一起写makefile
- PL/SQL_触发器5(建立系统事件触发器)
- poj1029 False coin
- C++开平方与乘方