二维码

9.8 生产环境注意事项 - 数据结构 - 机器学习

1322 人阅读 | 时间:2021年01月15日 01:17
9.8 生产环境注意事项 - 数据结构 - 机器学习 #daohang ul li t,.reed .riqi,a.shangg,a.xiatt,a.shangg:hover,a.xiatt:hover,a.shang,a.xiat,a.shang:hover,a.xiat:hover,.reed-pinglun-anniu,span.now-page,#daohangs-around,#caidan-tubiao,#daohangs,#daohangs li,#btnPost{background-color:#D10B04;} .dinglanyou1 h3{border-bottom:3px solid #D10B04;} #dibuer{border-top:2px solid #D10B04;}.cebianlan .rongqi h3{border-bottom:1px solid #D10B04;} #edtSearch{border:1px solid #D10B04;} #daohang .zuo ul li{border-right:1px solid #;} #daohang ul li t a{border-top:1px solid #;border-right:1px solid #D10B04;} #daohang ul li t a:hover{border-right:1px solid #;} #daohang .you ul li a:hover,#daohang .zuo ul li a:hover,.reed-pinglun-anniu:hover{background-color:#;} a:hover,.reed h6 a:hover,#dibuer a:hover,.reed .riqiding,.cebianlan .rongqi li a:hover,#pinglun-liebiao ul.fubens li.depth-1 dl dd span.shu a,#pinglun-liebiao ul.fubens li.depth-1 dl dd span.huifuliuyan a:hover,.reed-biaoti h6 span{color:#D10B04;} .reed .kan a{color:#0A0AF5;}.reed .kan a:hover{color:#D10101;} @media screen and (max-width:1492px){a.shang,a.xiat{background:none;} a.xiat:hover,a.shang:hover{background-color:#f9f9f9;background-image:none;text-decoration:none;}} var _hmt = _hmt || [];(function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?b19db5ba3b437a9e8698d2bc8fc64334"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s);})(); var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?b19db5ba3b437a9e8698d2bc8fc64334"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?2d748c9763cfc72fb7d1ccab29f0770d"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?f6d451f3f1be23f3abf240c64c469c1b"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })();

当前位置:首页 » 区块链精品文章 » 正文

(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646201", container: s }); })();
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646162", container: s }); })();

9.8 生产环境注意事项

1150 人参与  2018年09月29日 16:03  分类 : 区块链精品文章  评论

区块链分布式结构的特点,使得对其进行安装部署时相较于单点系统要复杂得多,需要从多个角度进行仔细考量和论证。这里总结一些在生产环境中进行应用时需要注意的地方。

1.节点角色差异

Fabric网络中各个节点可以拥有不同的角色。不同角色的众多节点负责整个网络功能中不同环节的工作负载,呈现出了差异化的处理特性。

Ordering服务需要处理整个网络中所有的交易消息,是全网的关键组件,Orderer节点采用Kafka集群进行 排序,本地维护了网络中所有通道的区块链结构,往往大量吞吐区块文件。因此,对于Orderer节点来讲需要加强内存、存储、网络IO方面的配置,并且采 用集群的方式提高其可靠性。

Peer节点除了处理区块和背书交易(Endorser)之外,还需要对账本状态进行更新(Committer),对身 份进行验证。同时,对于每个通道来说,加入通道的节点都需要维护一个针对该通道的账本结构(存放在数据库中)和区块链结构(存放在文件系统)。因 此,Peer节点则在计算、内存等方面需要进行强化配置,Endorser还可以在签名计算方面进行加权。对于打开文件句柄较多的节点(如配置使用 CouchDB作为状态数据库),可能还需要对系统的ulimit等参数进行调整。

而对于链码容器来说,自身不需要维护太多状态信息,但是需要执行计算操作,因此需要提高较好的计算能力支持。

一般来讲,链码容器常常跟Peer节点处在同一服务器上,建议为主服务预留2GB以上的空闲内存,并且一般每个链码容器分配256 MB运行内存和1/10的CPU核资源(根据链码逻辑进行调整)。

2.日志级别

日志级别越低,输出日志内容越详细,出现问题后越方便进行调试。但输出过多的日志会拖慢系统的吞吐性能,严重时甚至能降低几个数量级。

因此,在生产环境中必须要仔细调整日志级别。对于关键路径上的系统,通常要配置不低于Warning级别的日志输出;对于非关键路径上的系统,则可以采用不低于Info级别的日志输出。

Fabric在日志级别上,支持对不同组件提供不同的级别。推荐将全局配置为warning级别,gRPC组件由于需要处理大量交互消息,可以配置为更高的error级别。

如果要追踪区块链网络中的状态变化,可以通过事件监听等方式,降低对网络处理的压力。

3.链码升级

Fabric目前已经支持了链码升级特性,升级时会调用链码中的Init方法。通过合适地设计链码,对其进行升级操作可以保护旧版本链码所关联的状态数据不被破坏。

但是要注意,目前升级操作并不需要整个网络的共识,因此对部分节点上链码版本升级后,未被升级的节点上仍然会运行旧版本的链码。

从数据一致性上考虑,在对某链码代码进行升级前,推荐先将所有该链码的容器停止,并从Peer上备份并移除旧链码部署文件。之后先在个别Peer节点上部署新链码,对原有数据进行测试,成功后再在其他节点上进行升级操作。

另外,在一开始编写链码过程中,就需要考虑链码升级操作,通过传入Init参数指定特定的升级方法来保护原有数据。

4.组织结构

组织代表了维护网络的独立成员身份。一般来说,组成联盟链的各个成员,每个都拥有代表自己身份的组织。一个组织可以进一步包括多个资源实体,这些资源实体彼此具有较强的信任度,并且对外都呈现为同一组织身份。

由于Gossip协议目前在MSP范围内进行传播,因此,一般建议将组织与MSP一一对应,即每个组织拥有自己专属的MSP。当一个组织拥有多个MSP时,不同成员之间的交互可能会带来障碍;当多个组织同属于一个MSP时,可能会发生不希望的跨组织数据泄露。

另外,一个组织可以包括多个成员身份,多个Peer可以通过使用同一成员身份来提高可用性。

5.证书管理

Fabric网络中,CA负责证书的管理。用户虽然可以通过cryptogen工具提前分配好各组织的身份证书,但对于加入到网络中的用户,以及未来支持的交易证书,都需要Fabric CA来进行统一管理。

Fabric CA占据网络中安全和隐私的最核心位置,因此需要加强安全方面的防护。CA不应该暴露在公共网络域中,并且只能由有限个具备权限的用户访问。

另外,根证书往往要进行离线保护处理,减少接触和泄露的可能性。通常使用中间层证书来完成实体证书的签发。同时,绝对不能直接用根证书作为组织管理员的身份证书。

本章小结

本章详细讲解了围绕Fabric部署的相关话题,包括如何本地编译、安装并进行各种组件的配置,以及如何启动 Fabric网络。同时,也介绍了基于容器方式如何快速获取相关镜像和启动网络。此外,还介绍了关于链码操作、多通道操作的相关客户端命令,以及除了命令 行客户端之外的各种语言实现的SDK。最后,对生产环境中部署Fabric网络的有关事项进行了讨论。

通过本章内容的学习和实践,相信读者不仅掌握了如何根据需求来安装部署Fabric网络,同时也对Fabric网络的工作过程有了更深入的理解。


来源:我是码农,转载请保留出处和链接!

本文链接:http://www.54manong.com/?id=924

(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646208", container: s }); })();
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646147", container: s }); })();
window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdPic":"","bdStyle":"0","bdSize":"16"},"share":{},"image":{"viewList":["qzone","tsina","tqq","renren","weixin"],"viewText":"分享到:","viewSize":"16"},"selectShare":{"bdContainerClass":null,"bdSelectMiniList":["qzone","tsina","tqq","renren","weixin"]}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];
区块链是什么  

微信号:qq444848023    QQ号:444848023

加入【我是码农】QQ群:864689844(加群验证:我是码农)

<< 上一篇 下一篇 >>
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646186", container: s }); })();
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646175", container: s }); })();
搜索

网站分类

标签列表

最近发表

    (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https'){ bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else{ bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();

全站首页 | 数据结构 | 区块链| 大数据 | 机器学习 | 物联网和云计算 | 面试笔试

var cnzz_protocol = (("https:" == document.location.protocol) ? "https://" : "http://");document.write(unescape("%3Cspan id='cnzz_stat_icon_1276413723'%3E%3C/span%3E%3Cscript src='" + cnzz_protocol + "s23.cnzz.com/z_stat.php%3Fid%3D1276413723%26show%3Dpic1' type='text/javascript'%3E%3C/script%3E"));本站资源大部分来自互联网,版权归原作者所有!

jQuery(document).ready(function($){ /* prepend menu icon */ $('#daohangs-around').prepend('
'); /* toggle nav */ $("#caidan-tubiao").on("click", function(){ $("#daohangs").slideToggle(); $(this).toggleClass("active"); }); });

©著作权归作者所有:来自ZhiKuGroup博客作者没文化的原创作品,如需转载,请注明出处,否则将追究法律责任 来源:ZhiKuGroup博客,欢迎分享。

评论专区
  • 昵 称必填
  • 邮 箱选填
  • 网 址选填
◎已有 0 人评论
搜索
作者介绍
30天热门
×
×
本站会员尊享VIP特权,现在就加入我们吧!登录注册×
»
会员登录
新用户注册
×
会员注册
已有账号登录
×