当前位置: 首页 > news >正文

郑州网站优化外包顾问网络整合营销公司

郑州网站优化外包顾问,网络整合营销公司,wordpress 没有中文,珠宝类网站建设可执行报告在Redis server启动过程中,实现了实例化和初始化 1、哨兵实例化过程,采用redis sentinel指令实例化还是redis server下的参数实例化--sentinel。 // 检查服务器是否以 Sentinel 模式启动 server.sentinel_mode checkForSentinelMode(argc,argv);/* Re…

在Redis server启动过程中,实现了实例化和初始化

1、哨兵实例化过程,采用redis sentinel指令实例化还是redis server下的参数实例化--sentinel。

// 检查服务器是否以 Sentinel 模式启动
server.sentinel_mode = checkForSentinelMode(argc,argv);/* Returns 1 if there is --sentinel among the arguments or if* argv[0] is exactly "redis-sentinel". */
int checkForSentinelMode(int argc, char **argv) {int j;if (strstr(argv[0],"redis-sentinel") != NULL) return 1;for (j = 1; j < argc; j++)if (!strcmp(argv[j],"--sentinel")) return 1;return 0;
}

 2、如果Redis实例以哨兵模式启动,执行初始化,此时又两个函数需要注意

// 如果服务器以 Sentinel 模式启动。需要执行以下两个初始化操作。if (server.sentinel_mode) {initSentinelConfig();initSentinel();}

initSentinelConfig函数负责初始化哨兵的配置端口号,供全局使用。

// 这个函数会用 Sentinel 所属的属性覆盖服务器默认的属性
void initSentinelConfig(void) {server.port = REDIS_SENTINEL_PORT;
}

2、initSentinel函数操作比较多,基本就是预分配一些配置需要的空间并且初始化默认值。

1、初始化server哨兵命令列表。

2、初始化主服务器信息字典。

3、初始化 TILT 模式的相关选项。

4、初始化脚本相关选项。

/* Perform the Sentinel mode initialization. */
// 以 Sentinel 模式初始化服务器
void initSentinel(void) {int j;/* Remove usual Redis commands from the command table, then just add* the SENTINEL command. */// 清空 Redis 服务器的命令表(该表用于普通模式)dictEmpty(server.commands,NULL);// 将 SENTINEL 模式所用的命令添加进命令表for (j = 0; j < sizeof(sentinelcmds)/sizeof(sentinelcmds[0]); j++) {int retval;struct redisCommand *cmd = sentinelcmds+j;retval = dictAdd(server.commands, sdsnew(cmd->name), cmd);redisAssert(retval == DICT_OK);}/* Initialize various data structures. *//* 初始化 Sentinel 的状态 */// 初始化纪元sentinel.current_epoch = 0;// 初始化保存主服务器信息的字典sentinel.masters = dictCreate(&instancesDictType,NULL);// 初始化 TILT 模式的相关选项sentinel.tilt = 0;sentinel.tilt_start_time = 0;sentinel.previous_time = mstime();// 初始化脚本相关选项sentinel.running_scripts = 0;sentinel.scripts_queue = listCreate();
}

3、启动哨兵实例。

sentinelIsRunning函数-->

sentinelGenerateInitialMonitorEvents函数-->

sentinelEvent函数-->

pubsubPublishMessage函数

发布订阅模式解决哨兵与master、slave节点、或者哨兵实例之间的通讯问题。实际就是通过

pubsubPublishMessage函数完成发布消息给redis客户端列表和订阅了该频道(channel)的实例(哨兵或者主节点)。

/* Publish a message ** 将 message 发送到所有订阅频道 channel 的客户端,* 以及所有订阅了和 channel 频道匹配的模式的客户端。*/
int pubsubPublishMessage(robj *channel, robj *message) {int receivers = 0;dictEntry *de;listNode *ln;listIter li;/* Send to clients listening for that channel */// 取出包含所有订阅频道 channel 的客户端的链表// 并将消息发送给它们de = dictFind(server.pubsub_channels,channel);if (de) {list *list = dictGetVal(de);listNode *ln;listIter li;// 遍历客户端链表,将 message 发送给它们listRewind(list,&li);while ((ln = listNext(&li)) != NULL) {redisClient *c = ln->value;// 回复客户端。// 示例:// 1) "message"// 2) "xxx"// 3) "hello"addReply(c,shared.mbulkhdr[3]);// "message" 字符串addReply(c,shared.messagebulk);// 消息的来源频道addReplyBulk(c,channel);// 消息内容addReplyBulk(c,message);// 接收客户端计数receivers++;}}/* Send to clients listening to matching channels */// 将消息也发送给那些和频道匹配的模式if (listLength(server.pubsub_patterns)) {// 遍历模式链表listRewind(server.pubsub_patterns,&li);channel = getDecodedObject(channel);while ((ln = listNext(&li)) != NULL) {// 取出 pubsubPatternpubsubPattern *pat = ln->value;// 如果 channel 和 pattern 匹配// 就给所有订阅该 pattern 的客户端发送消息if (stringmatchlen((char*)pat->pattern->ptr,sdslen(pat->pattern->ptr),(char*)channel->ptr,sdslen(channel->ptr),0)) {// 回复客户端// 示例:// 1) "pmessage"// 2) "*"// 3) "xxx"// 4) "hello"addReply(pat->client,shared.mbulkhdr[4]);addReply(pat->client,shared.pmessagebulk);addReplyBulk(pat->client,pat->pattern);addReplyBulk(pat->client,channel);addReplyBulk(pat->client,message);// 对接收消息的客户端进行计数receivers++;}}decrRefCount(channel);}// 返回计数return receivers;
}
http://www.hrbkazy.com/news/39970.html

相关文章:

  • nba最新排名官网网站seo入门基础教程书籍
  • 做网站首选九零后网络微信公众号软文怎么写
  • 网站如何和其他网站做友情链接泾县网站seo优化排名
  • 怎样建立自己购物网站百度应用商店下载
  • 做网站后期怎么维护女教师遭网课入侵直播录屏曝
  • b2c商城网站建设 工具深圳网络营销推广外包
  • 咸阳公司做网站做一个公司网站要多少钱
  • 网站的建设目标文档国内it培训机构排名
  • 建设银行卡授权网站管理宁波seo优化排名
  • 网站开发在无形资产中做个公司网站大概多少钱
  • 中国品牌建设促进会网站许昌网络推广外包
  • o2o网站建设方案 多少钱深圳推广优化公司
  • 外包做网站多少钱网络营销服务商
  • 网站背景如何做百度网站入口
  • 做视频的网站靠什么收入外贸seo公司
  • 做网站需要留什么淘宝权重查询
  • 茌平做网站推广如何做网站营销推广
  • 电脑版和手机版网站怎么做的做小程序要多少钱
  • 杭州网站建设排名百度如何收录网站
  • 我的网站突然找不到网页了百度广告联盟
  • 视频网站 如何做seoqq群排名优化软件官网
  • 设计师合作网站白山seo
  • 群辉 wordpress汉化seogw
  • 网站域名代备案网站日常维护有哪些
  • 佛山 做网站公司seo教程百度网盘
  • 阜阳恒亮做网站多少钱seo是搜索引擎营销吗
  • 网站建设制作设计seo优化南宁百度搜索引擎入口登录
  • 网站seo优化书籍交换友情链接平台
  • 网站程序盗版seo短视频网页入口引流
  • 龙岗优化网站建设巨量引擎广告投放平台