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

做彩票网站怎么样台安人才网

做彩票网站怎么样,台安人才网,建网站是怎么造成的,工业设计公司发展方向CAP理论 关于CAP理论的介绍可以直接看这篇文章 CAP分别是什么#xff1f; 一致性#xff08;Consistency 一致性包括强一致性#xff0c;弱一致性#xff0c;最终一致性。 一致性其实是指数据的一致性#xff0c;为什么数据会不一致呢#xff1f; 如上面这张图…CAP理论 关于CAP理论的介绍可以直接看这篇文章 CAP分别是什么 一致性Consistency 一致性包括强一致性弱一致性最终一致性。 一致性其实是指数据的一致性为什么数据会不一致呢 如上面这张图我们服务是以集群的方式向外提供服务客户端并不会关心我这次请求到了那个节点。如果我第一次请求到了A节点做了更新数据的操作但是第二次我的请求被转发到B节点了。如果这个时候服务A和服务B的数据还没有进行同步这个时候数据就不一致了事实上我们也很难做到服务A的数据发生变化就可以立即传给B进行同步特别是在请求特别频繁的情况下。因此要根据实际场景去判断是否一定要保证强一致性。例如涉及金钱和库存的这种服务集群肯定是要保证强一致性的。又例如点赞量和播放量或者访问量这些并不需要实时一致保证最终一致即可。 可用性Availability 其实就是不管数据正不正确只要用户来请求就返回给用户数据。 在我们说一致性的时候如果去保证强一致性这个时候客户端如果请求到达了B是不能对外提供服务的因为一旦提供服务这个数据还是老的数据就产生了数据的不一致性。但是如果不提供服务的话那这个服务节点岂不是不可以用了吗那就是没有保障可用性呀。所以我们也可以看到一致性和可用性之间是需要做一定妥协的。 分区容错性Partition tolerance 1 分区 什么是分区分布式系统分布在多个子网络中。分布式系统的服务节点可能由于网络原因或者其它因素不能相互通信。这种情况就叫产生了分区。 2 什么是分区容忍 因为产生分区这种情况一般来说是无法避免的我们不能完全保证两个服务节点能够完全互通不产生任何异常。 总结下来就是在一个分布式系统中这个P分区是一定存在的。我们需要根据业务场景来做C和A的一些取舍。 常见组件保证的模式 Nacos 保证了AP CPZookeeper 保证了CPEureka 保证了AP Distro 一致性协议临时节点协议 原文链接 distro协议网上的资料比较少因为它是阿里“自创的协议“通过源码总结一下distro协议的关键点 distro协议是为了注册中心而创造出的协议 客户端与服务端有两个重要的交互服务注册与心跳发送 客户端以服务为维度向服务端注册注册后每隔一段时间向服务端发送一次心跳心跳包需要带上注册服务的全部信息在客户端看来服务端节点对等所以请求的节点是随机的 客户端请求失败则换一个节点重新发送请求 服务端节点都存储所有数据但每个节点只负责其中一部分服务在接收到客户端的“写“注册、心跳、下线等请求后服务端节点判断请求的服务是否为自己负责如果是则处理否则交由负责的节点处理 每个服务端节点主动发送健康检查到其他节点响应的节点被该节点视为健康节点 服务端在接收到客户端的服务心跳后如果该服务不存在则将该心跳请求当做注册请求来处理 服务端如果长时间未收到客户端心跳则下线该服务 负责的节点在接收到服务注册、服务心跳等写请求后将数据写入后即返回后台异步地将数据同步给其他节点 节点在收到读请求后直接从本机获取后返回无论数据是否为最新。 新节点同步机制 DistroProtocol#startDistroTask private void startDistroTask() {if (EnvUtil.getStandaloneMode()) {isInitialized true;return;}// 健康检查startVerifyTask();// 开始加载startLoadTask(); }平等机制 Nacos 的每个节点是平等的都可以处理写的请求 异步复制机制 DistroProtocol#sync public void sync(DistroKey distroKey, DataOperation action) {sync(distroKey, action, DistroConfig.getInstance().getSyncDelayMillis());}健康检查机制 DistroProtocol#startDistroTask private void startVerifyTask() {GlobalExecutor.schedulePartitionDataTimedSync(new DistroVerifyTimedTask(memberManager, distroComponentHolder,distroTaskEngineHolder.getExecuteWorkersManager()),DistroConfig.getInstance().getVerifyIntervalMillis()); }本地读机制(每个节点拥有全量的数据) 但是写处理是只有一部分数据也就是有个数据拆分分而治之的机制。 InstanceController#list /*** Get all instance of input service.** param request http request* return list of instance* throws Exception any error during list*/GetMapping(/list)Secured(action ActionTypes.READ)public Object list(HttpServletRequest request) throws Exception {}路由转发机制 DistroFilter#doFilter if (distroMapper.responsible(distroTag)) {filterChain.doFilter(req, resp);return;}Raft 一致性协议持久化节点协议 该协议主要是发起选举选举后如何同步数据。一个节点起来了以后会发起投票如果集群过半数据认可这个节点则这个节点为leader成为leader后与其它节点建立联系。 V1版本的选举与同步 try {if (stopWork) {return;}if (!peers.isReady()) {return;}RaftPeer local peers.local();local.leaderDueMs - GlobalExecutor.TICK_PERIOD_MS;if (local.leaderDueMs 0) {return;}// 来到这里以后已经和Master失联了// reset timeoutlocal.resetLeaderDue();local.resetHeartbeatDue();// 发起投票里面会向其它节点发起异步请求sendVote();} catch (Exception e) {Loggers.RAFT.warn([RAFT] error while master election {}, e);} // 过半 if (maxApproveCount majorityCount()) {RaftPeer peer peers.get(maxApprovePeer);peer.state RaftPeer.State.LEADER;if (!Objects.equals(leader, peer)) {leader peer;ApplicationUtils.publishEvent(new LeaderElectFinishedEvent(this, leader, local()));Loggers.RAFT.info({} has become the LEADER, leader.ip);} }// 处理心跳 try {if (stopWork) {return;}if (!peers.isReady()) {return;}RaftPeer local peers.local();local.heartbeatDueMs - GlobalExecutor.TICK_PERIOD_MS;if (local.heartbeatDueMs 0) {return;}local.resetHeartbeatDue();sendBeat();} catch (Exception e) {Loggers.RAFT.warn([RAFT] error while sending beat {}, e);}V2版本的选举与同步 涉及源码 com.alibaba.nacos.naming.consistency.DelegateConsistencyServiceImpl com.alibaba.nacos.naming.consistency.persistent.PersistentConsistencyServiceDelegateImpl#PersistentConsistencyServiceDelegateImpl com.alibaba.nacos.naming.consistency.persistent.impl.PersistentServiceProcessor#afterConstruct com.alibaba.nacos.core.distributed.raft.JRaftProtocol#addRequestProcessors com.alibaba.nacos.core.distributed.raft.JRaftServer#createMultiRaftGroup com.alipay.sofa.jraft.RaftGroupService#start(boolean) com.alipay.sofa.jraft.RaftServiceFactory#createAndInitRaftNode com.alipay.sofa.jraft.core.NodeImpl#init com.alipay.sofa.jraft.core.NodeImpl#electSelf com.alipay.sofa.jraft.core.NodeImpl#becomeLeader 同步 com.alipay.sofa.jraft.ReplicatorGroup#addReplicator(com.alipay.sofa.jraft.entity.PeerId) 部分源码 private BasePersistentServiceProcessor createNewPersistentServiceProcessor(ProtocolManager protocolManager,ClusterVersionJudgement versionJudgement) throws Exception {final BasePersistentServiceProcessor processor EnvUtil.getStandaloneMode() ? new StandalonePersistentServiceProcessor(versionJudgement): new PersistentServiceProcessor(protocolManager, versionJudgement);processor.afterConstruct();return processor;}PersistentServiceProcessor#afterConstruct Override public void afterConstruct() {super.afterConstruct();String raftGroup Constants.NAMING_PERSISTENT_SERVICE_GROUP;this.protocol.protocolMetaData().subscribe(raftGroup, MetadataKey.LEADER_META_DATA, o - {if (!(o instanceof ProtocolMetaData.ValueItem)) {return;}Object leader ((ProtocolMetaData.ValueItem) o).getData();hasLeader StringUtils.isNotBlank(String.valueOf(leader));Loggers.RAFT.info(Raft group {} has leader {}, raftGroup, leader);});this.protocol.addRequestProcessors(Collections.singletonList(this));// If you choose to use the new RAFT protocol directly, there will be no compatible logical executionif (EnvUtil.getProperty(Constants.NACOS_NAMING_USE_NEW_RAFT_FIRST, Boolean.class, false)) {NotifyCenter.registerSubscriber(notifier);waitLeader();startNotify true;} }JRaft public void init(RaftConfig config) {if (initialized.compareAndSet(false, true)) {this.raftConfig config;NotifyCenter.registerToSharePublisher(RaftEvent.class);this.raftServer.init(this.raftConfig);this.raftServer.start();// There is only one consumer to ensure that the internal consumption// is sequential and there is no concurrent competitionNotifyCenter.registerSubscriber(new SubscriberRaftEvent() {Overridepublic void onEvent(RaftEvent event) {Loggers.RAFT.info(This Raft event changes : {}, event);final String groupId event.getGroupId();MapString, MapString, Object value new HashMap();MapString, Object properties new HashMap();final String leader event.getLeader();final Long term event.getTerm();final ListString raftClusterInfo event.getRaftClusterInfo();final String errMsg event.getErrMsg();// Leader information needs to be selectively updated. If it is valid data,// the information in the protocol metadata is updated.MapUtil.putIfValNoEmpty(properties, MetadataKey.LEADER_META_DATA, leader);MapUtil.putIfValNoNull(properties, MetadataKey.TERM_META_DATA, term);MapUtil.putIfValNoEmpty(properties, MetadataKey.RAFT_GROUP_MEMBER, raftClusterInfo);MapUtil.putIfValNoEmpty(properties, MetadataKey.ERR_MSG, errMsg);value.put(groupId, properties);metaData.load(value);// The metadata information is injected into the metadata information of the nodeinjectProtocolMetaData(metaData);}Overridepublic Class? extends Event subscribeType() {return RaftEvent.class;}});} }
http://www.zqtcl.cn/news/611359/

相关文章:

  • 网站建设销售话建网站需要怎样做
  • 网站排名和什么有关网络推广协议合同范本
  • 湖州房产网站建设南通市城乡和住房建设局网站
  • 郴州建设工程集团招聘信息网站wordpress 橘子皮模板
  • win7搭建网站服务器成都网站建设需多少钱
  • 网站开发一般需要多久菜谱网站模版
  • 基于jsp的电子商务网站开发最好的网站建设公司哪家好
  • 个人网站图片郑州技术支持seo
  • 先做网站还是先做app广州互联网
  • 租用网站的服务器wordpress手机加搜索
  • 做彩票网站怎么样才能让百度收录自己的网站
  • 廊坊网站建设技术托管seo怎么优化关键词排名培训
  • 抛丸机网站怎么做手机网站打不开的解决方法
  • 上海做网站的公司多少钱冷水江网站
  • 百度网站流量查询宣传片制作公司费用
  • 安徽炒股配资网站开发搭建平台载体
  • 中华建设杂志网站记者黑龙江省建设集团有限公司网站首页
  • 成都络迈品牌网站建设网站建设的行业资讯、
  • 英语网站大全免费赤峰市建设厅官方网站
  • 宁波网站建设熊掌号成都网络关键词排名
  • 织梦网站改版需要怎么做平台设计软件
  • 企业展示型网站网站建设设计
  • 增城网站建设服务网站建设制作设计公司佛山
  • 微网站套餐自媒体网站源码模板dede
  • 企业网站改版升级成都便宜网站建设公司
  • 广州公共资源建设工程交易中心网站新塘做网站
  • 数码港 太原网站开发公司iis 建立子网站
  • 做一个自己的网站需要什么商标设计网站猪八戒
  • 傻瓜式网站建设软件保险预约
  • 网站 备案规定自己做简单网站