new DMS

Client.jar

  1. zookeeper中获取可用的nameNode
  2. nameNode上获取可用的dataNode列表。
  3. 获取dataNode列表后,设置监听,任何一个dataNode节点发生变化,重新获取dataNode列表,初始化hash环(大map)。
  4. DataNode列表初始化hash环的大treeMap<long,ip>,并作虚拟节点。
  5. 存储数据时,把keyhash,去treeMap中取ip,通过ipnio传输,调用dataNode.jar
  6. 重新封装所有redis的方法,用nio做传输。

 

 

NameNode.jar

  1. 启动时,注册zookeeper服务,注册不上通过getData设置监听,不断注册。
  2. zookeeper上获取DataNode节点列表,封装列表元数据到redis,获取不到设置监听,继续获取。
  3. 存储管理信息、数据迁移信息、存储库信息、存储表信息

 

 

DataNode.jar

  1. 注册服务(n个)到zookeeper,注册不上通过getData设置监听,不断注册。为什么是n个?因为可能一台机器存在其他机器的备份。
  2. 通过ip创建redisPool
  3. 封装jedis的所有方法,写数据
  4. zookeeper中获取nameNode节点,通过nameNode节点获取DataNode备份信息,将数据同步

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码是一个方法,用于插入或更新`DMS_PLASMA`表的数据。让我们逐行分析代码的功能: 1. `public string InsertUpdateDMS_PLASMA(Param_PLASMA param_PLASMA)`: 这是一个公共方法,接受一个名为`param_PLASMA`的`Param_PLASMA`类型的参数,并返回一个`string`类型的结果。 2. `string strRet = "NG";`: 初始化一个名为`strRet`的字符串变量,并将其值设置为"NG"。 3. `DMS_PLASMA itemPLASMA = new DMS_PLASMA();`: 创建一个名为`itemPLASMA`的`DMS_PLASMA`对象。 4. `itemPLASMA.LENS_BATCH = param_PLASMA.Param_Batch;`: 将`param_PLASMA.Param_Batch`的值赋给`itemPLASMA.LENS_BATCH`属性。 5. `itemPLASMA.ADDDATE = DateTime.Now;`: 将当前时间赋给`itemPLASMA.ADDDATE`属性。 6. `var x = DbScoped.SugarScope.Storageable<DMS_PLASMA>(itemPLASMA).WhereColumns(it => new { it.LENS_BATCH }).ToStorage();`: 创建一个变量`x`,用于将`itemPLASMA`对象存储到数据库中。此处使用了`Storageable`方法来定义存储操作,并使用`WhereColumns`方法指定列条件。 7. `int iInsertRes = x.AsInsertable.ExecuteCommand();`: 执行插入操作,并将返回的影响行数赋值给变量`iInsertRes`。 8. `int iUpdateRes = x.AsUpdateable.ExecuteCommand();`: 执行更新操作,并将返回的影响行数赋值给变量`iUpdateRes`。 9. `if (iInsertRes + iUpdateRes == 1)`: 如果插入和更新的总影响行数等于1,进入下一步操作。 10. `strRet = "OK";`: 将`strRet`的值设置为"OK"。 11. `else`: 如果上述条件不满足,执行下一步操作。 12. `strRet = "插入或更新失败";`: 将`strRet`的值设置为"插入或更新失败"。 13. `return strRet;`: 返回`strRet`的值作为方法的结果。 总体来说,这段代码的作用是将传入的参数值插入或更新到`DMS_PLASMA`表中,并根据操作结果返回不同的字符串结果。如果插入或更新成功,则返回"OK";否则返回"插入或更新失败"。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值