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

淮安淮阴网站建设汽车之家app下载

淮安淮阴网站建设,汽车之家app下载,昆山普立斯特做的有网站,锦州企业网站建设前言 SubscriptionGroupManager 继承了ConfigManager配置管理组件#xff0c;拥有将内存数据持久化到磁盘文件subscriptionGroup.json的能力。它主要负责维护所有消费组在内存中的订阅数据。 源码版本#xff1a;4.9.3 源码架构图 核心数据结构 主要的数据结构比较简单拥有将内存数据持久化到磁盘文件subscriptionGroup.json的能力。它主要负责维护所有消费组在内存中的订阅数据。 源码版本4.9.3 源码架构图 核心数据结构 主要的数据结构比较简单维护了Map消费组名称, 订阅组配置的映射关系。 // 订阅组管理组件 public class SubscriptionGroupManager extends ConfigManager {private static final InternalLogger log InternalLoggerFactory.getLogger(LoggerName.BROKER_LOGGER_NAME);// Map消费组名称订阅组配置private final ConcurrentMapString, SubscriptionGroupConfig subscriptionGroupTable new ConcurrentHashMapString, SubscriptionGroupConfig(1024);// 内存数据版本号private final DataVersion dataVersion new DataVersion(); } 深入看下SubscriptionGroupConfig 的数据结构。 public class SubscriptionGroupConfig {// 消费组名称private String groupName;// 是否开启消费private boolean consumeEnable true;// 是否允许消费最早消息private boolean consumeFromMinEnable true;// 是否允许广播消费private boolean consumeBroadcastEnable true;// 重试队列数private int retryQueueNums 1;// 重试最大次数private int retryMaxTimes 16;// brokerIdprivate long brokerId MixAll.MASTER_ID;// 当产生慢消费时选择第几个brokerprivate long whichBrokerWhenConsumeSlowly 1;// 是否通知消费者ids变化private boolean notifyConsumerIdsChangedEnable true; } 核心数据行为 数据行为主要都是对上面提到的数据结构的维护代码 注释如下 // 订阅组管理组件 public class SubscriptionGroupManager extends ConfigManager {public SubscriptionGroupManager() {this.init();}public SubscriptionGroupManager(BrokerController brokerController) {this.brokerController brokerController;this.init();}private void init() {{// 初始化系统消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.TOOLS_CONSUMER_GROUP);this.subscriptionGroupTable.put(MixAll.TOOLS_CONSUMER_GROUP, subscriptionGroupConfig);}{// 初始化过滤服务消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.FILTERSRV_CONSUMER_GROUP);this.subscriptionGroupTable.put(MixAll.FILTERSRV_CONSUMER_GROUP, subscriptionGroupConfig);}{// 初始化自测消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.SELF_TEST_CONSUMER_GROUP);this.subscriptionGroupTable.put(MixAll.SELF_TEST_CONSUMER_GROUP, subscriptionGroupConfig);}{// 初始化http代理消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.ONS_HTTP_PROXY_GROUP);subscriptionGroupConfig.setConsumeBroadcastEnable(true);this.subscriptionGroupTable.put(MixAll.ONS_HTTP_PROXY_GROUP, subscriptionGroupConfig);}{// 初始化ONS_API_PULL消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.CID_ONSAPI_PULL_GROUP);subscriptionGroupConfig.setConsumeBroadcastEnable(true); // 激活广播模式this.subscriptionGroupTable.put(MixAll.CID_ONSAPI_PULL_GROUP, subscriptionGroupConfig);}{// 初始化ONS_API_PERMISSION消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.CID_ONSAPI_PERMISSION_GROUP);subscriptionGroupConfig.setConsumeBroadcastEnable(true);this.subscriptionGroupTable.put(MixAll.CID_ONSAPI_PERMISSION_GROUP, subscriptionGroupConfig);}{// 初始化ONS_API_OWNER消费组SubscriptionGroupConfig subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(MixAll.CID_ONSAPI_OWNER_GROUP);subscriptionGroupConfig.setConsumeBroadcastEnable(true);this.subscriptionGroupTable.put(MixAll.CID_ONSAPI_OWNER_GROUP, subscriptionGroupConfig);}}// 更新订阅配置且更新内存数据版本号public void updateSubscriptionGroupConfig(final SubscriptionGroupConfig config) {SubscriptionGroupConfig old this.subscriptionGroupTable.put(config.getGroupName(), config);if (old ! null) {log.info(update subscription group config, old: {} new: {}, old, config);} else {log.info(create new subscription group, {}, config);}this.dataVersion.nextVersion();this.persist();}// 失效消费组public void disableConsume(final String groupName) {SubscriptionGroupConfig old this.subscriptionGroupTable.get(groupName);if (old ! null) {old.setConsumeEnable(false);this.dataVersion.nextVersion();}}// 查找指定消费组的订阅配置public SubscriptionGroupConfig findSubscriptionGroupConfig(final String group) {SubscriptionGroupConfig subscriptionGroupConfig this.subscriptionGroupTable.get(group);if (null subscriptionGroupConfig) {if (brokerController.getBrokerConfig().isAutoCreateSubscriptionGroup() || MixAll.isSysConsumerGroup(group)) {subscriptionGroupConfig new SubscriptionGroupConfig();subscriptionGroupConfig.setGroupName(group);SubscriptionGroupConfig preConfig this.subscriptionGroupTable.putIfAbsent(group, subscriptionGroupConfig);if (null preConfig) {log.info(auto create a subscription group, {}, subscriptionGroupConfig.toString());}this.dataVersion.nextVersion();this.persist();}}return subscriptionGroupConfig;}// 将内存数据结构编码成字符串Overridepublic String encode() {return this.encode(false);}// 获取配置文件路径Overridepublic String configFilePath() {return BrokerPathConfigHelper.getSubscriptionGroupPath(this.brokerController.getMessageStoreConfig().getStorePathRootDir());}// 从字符串中恢复数据写回内存数据结构Overridepublic void decode(String jsonString) {if (jsonString ! null) {SubscriptionGroupManager obj RemotingSerializable.fromJson(jsonString, SubscriptionGroupManager.class);if (obj ! null) {this.subscriptionGroupTable.putAll(obj.subscriptionGroupTable);this.dataVersion.assignNewOne(obj.dataVersion);this.printLoadDataWhenFirstBoot(obj);}}}// 将内存数据结构编码成字符串public String encode(final boolean prettyFormat) {return RemotingSerializable.toJson(this, prettyFormat);}// 当第一次启动时打印加载数据时的日志private void printLoadDataWhenFirstBoot(final SubscriptionGroupManager sgm) {IteratorEntryString, SubscriptionGroupConfig it sgm.getSubscriptionGroupTable().entrySet().iterator();while (it.hasNext()) {EntryString, SubscriptionGroupConfig next it.next();log.info(load exist subscription group, {}, next.getValue().toString());}}public ConcurrentMapString, SubscriptionGroupConfig getSubscriptionGroupTable() {return subscriptionGroupTable;}public DataVersion getDataVersion() {return dataVersion;}// 删除指定消费组的订阅配置public void deleteSubscriptionGroupConfig(final String groupName) {SubscriptionGroupConfig old this.subscriptionGroupTable.remove(groupName);if (old ! null) {log.info(delete subscription group OK, subscription group:{}, old);this.dataVersion.nextVersion();this.persist();} else {log.warn(delete subscription group failed, subscription groupName: {} not exist, groupName);}} }
http://www.dnsts.com.cn/news/30644.html

相关文章:

  • 国内专业网站设计如何做公司网站优化
  • 杭州建站软件请人做网站要注意什么
  • 切图做网站过时了吗公司页面图片
  • 医疗网站模版旅游网站建设背景
  • 企业网站网页静态网站更新
  • 建国外网站买完域名后怎么做门户网站开发软件
  • 无锡企业网站制作网站申请微信登录
  • 购物网站要求pageadmin仿站教程
  • 网站设计怎么做ppt答辩旅游小程序哪家做得好
  • 麦壳云网站建设微信营销管理软件
  • Net网站开发招聘嘉兴企业网站建设公司
  • wordpress个人博客模板下载搜索引擎优化网站排名
  • 网站建设游戏教育培训机构有关的网站
  • 网站设计登录界面怎么做商城类网站主要分为哪些模块
  • 自己做网站难不难本地最新招聘信息
  • 建设网站制免费制作视频的软件有哪些
  • 动态ip建网站昆明好seo怎么做
  • 婚纱网站页面设计广告制作公司名字
  • 关于seo网站优化公司区域网站设计
  • wordpress 下载模板站wordpress 国内 慢
  • 做刷单哪个网站找小白seo网站关键词优化报价
  • 即墨做网站的高端html5网站建设织梦模板
  • wordpress外贸网站模板图片幻灯片插件 wordpress
  • 网站的工作简报怎么做西安加盟代理网站建设
  • c 转网站开发建站房的公司
  • c php做网站对比曲阳网站建设
  • 济南商城网站建设婚纱网网站建设目的及功能定位
  • 寿县网站建设网站手机端首页用什么软件做
  • 凡科建站快车官网网站开发收获
  • 网站建设 试题精品网站建设费用 都来磐石网络