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

大同建设局网站网站建设与管理视频教程

大同建设局网站,网站建设与管理视频教程,室内装修网站,寻找富阳网站建设转载前言#xff1a;网络上很多教程没有描述zookeeper和dubbo到底是什么关系、分别扮演了什么角色等信息#xff0c;都是说一些似是而非的话#xff0c;这里终于找到一篇文章#xff0c;比较生动地描述了注册中心和微服务框架之间的关系#xff0c;以及他们之间的合作分工…转载前言网络上很多教程没有描述zookeeper和dubbo到底是什么关系、分别扮演了什么角色等信息都是说一些似是而非的话这里终于找到一篇文章比较生动地描述了注册中心和微服务框架之间的关系以及他们之间的合作分工。 下面附上我读完之后的理解 dubbo是一个远程调用服务的分布式框架可以实现远程通讯、动态配置、地址路由等等功能。 比如在入门demo里的暴露服务使得远程调用的协议可以使用dobbo协议(dubbo://x.x.x.x)或者其它协议可以配置zookeeper集群地址实现软负载均衡并配置均衡方式等。 在不搭配注册中心的时候它也是可以实现服务端和调用端的通信的这种方式是点对点通信的所谓“没有中间商”。但是如果配置服务发布和调用端过多特别是集群的方式提供服务的时候就会暴露许多的问题增加节点需要修改配置文件、服务端机器宕机后不能被感知等。 它可以通过集成注册中心来动态地治理服务发布和服务调用。相当于把服务注册和发布推送的功能分摊给了(zookeeper)注册中心。 原帖地址https://www.javazhiyin.com/28425.html#m 介绍 微服务是最近比较火的概念而微服务框架目前主流的有Dubbo和Spring Cloud两者都是为了解决微服务遇到的各种问题而产生的即遇到的问题是一样的但是解决的策略却有所不同所以这2个框架经常拿来比较。没用过Dubbo的小伙伴也不用担心其实Dubbo还是比较简单的看完本文你也能掌握一个大概重要的不是代码而是思想。 Dubbo实现服务调用是通过RPC的方式即客户端和服务端共用一个接口(将接口打成一个jar包在客户端和服务端引入这个jar包)客户端面向接口写调用服务端面向接口写实现中间的网络通信交给框架去实现想深入了解的看推荐阅读。原文链接有代码GitHub地址 使用入门 服务提供者 定义服务接口 public interface DemoService {String sayHello(String name); } 在服务提供方实现接口 public class DemoServiceImpl implements DemoService {Overridepublic String sayHello(String name) {return Hello name;} } 用 Spring 配置声明暴露服务 provider.xml省略了beans标签的各种属性 ?xml version1.0 encodingUTF-8? beans!-- 当前项目在整个分布式架构里面的唯一名称用于计算依赖关系 --dubbo:application namehelloworld-app /!--dubbo这个服务所要暴露的服务地址所对应的注册中心N/A为不使用注册中心--dubbo:registry addressN/A/!--当前服务发布所依赖的协议webserovice、Thrift、Hessain、http--dubbo:protocol namedubbo port20880/!--服务发布的配置需要暴露的服务接口--dubbo:service interfacecom.st.DemoServicerefdemoService/!--bean的定义--bean iddemoService classcom.st.DemoServiceImpl//beans 加载 Spring 配置 public class Provider {public static void main(String[] args) throws Exception {ClassPathXmlApplicationContext context new ClassPathXmlApplicationContext(provider.xml);context.start();System.in.read(); // 按任意键退出} } 服务消费者 consumer.xml ?xml version1.0 encodingUTF-8? beans!-- 消费方应用名用于计算依赖关系不是匹配条件不要与提供方一样 --dubbo:application nameconsumer-of-helloworld-app/dubbo:registry addressN/A/!-- 生成远程服务代理可以和本地bean一样使用demoService --dubbo:reference iddemoService interfacecom.st.DemoServiceurldubbo://localhost:20880/com.st.DemoService//beans 加载Spring配置并调用远程服务 public class Consumer {public static void main(String[] args) throws Exception {ClassPathXmlApplicationContext context new ClassPathXmlApplicationContext(consumer.xml);context.start();// 获取远程服务代理DemoService demoService (DemoService)context.getBean(demoService);// 执行远程方法String hello demoService.sayHello(world);// Hello worldSystem.out.println( hello );} } 这就是典型的点对点的服务调用。当然我们为了高可用可以在consumer.xml中配置多个服务提供者并配置响应的负载均衡策略 配置多个服务调用者在comsumer.xml的标签的url属性中加入多个地址中间用分号隔开即可配置负载均衡策略在comsumer.xml的标签中增加loadbalance属性即可值可以为如下四种类型 RoundRobin LoadBalance随机按权重设置随机概率。RoundRobin LoadBalance轮询按公约后的权重设置轮询比率。LeastActive LoadBalance最少活跃调用数相同活跃数的随机活跃数指调用前后计数差。ConsistentHash LoadBalance一致性 Hash相同参数的请求总是发到同一提供者。dubbo:reference iddemoService interfacecom.st.DemoServiceurldubbo://192.168.11.1:20880/com.st.DemoService;dubbo://192.168.11.2:20880/com.st.DemoService;dubbo://192.168.11.3:20880/com.st.DemoServiceloadbalanceroundrobin/ 现在整体架构是如下图假设服务消费者为订单服务服务提供者为用户服务 这样会有什么问题呢 当服务提供者增加节点时需要修改配置文件当其中一个服务提供者宕机时服务消费者不能及时感知到还会往宕机的服务发送请求这个时候就得引入注册中心了 注册中心 Dubbo目前支持4种注册中心,multicast zookeeper redis simple 推荐使用Zookeeper注册中心本文就讲一下用zookeeper实现服务注册和发现敲黑板又一种zookeeper的用处大致流程如下 现在我们来看Dubbo官网对Dubbo的介绍图有没有和我们上面画的很相似 节点角色说明 节点角色说明Provider暴露服务的服务提供方Consumer调用远程服务的服务消费方Registry服务注册与发现的注册中心Monitor统计服务的调用次数和调用时间的监控中心Container服务运行容器调用关系说明 服务容器负责启动上面例子为Spring容器加载运行服务提供者。服务提供者在启动时向注册中心注册自己提供的服务。服务消费者在启动时向注册中心订阅自己所需的服务。注册中心返回服务提供者地址列表给消费者如果有变更注册中心将基于长连接推送变更数据给消费者。服务消费者从提供者地址列表中基于软负载均衡算法选一台提供者进行调用如果调用失败再选另一台调用。服务消费者和提供者在内存中累计调用次数和调用时间定时每分钟发送一次统计数据到监控中心。要使用注册中心只需要将provider.xml和consumer.xml更改为如下 !--dubbo:registry addressN/A/-- dubbo:registry protocolzookeeper address192.168.11.129:2181/ 如果zookeeper是一个集群则多个地址之间用逗号分隔即可 dubbo:registry protocolzookeeper address192.168.11.129:2181,192.168.11.137:2181,192.168.11.138:2181/ 把consumer.xml中配置的直连的方式去掉 !-- 生成远程服务代理可以和本地bean一样使用demoService -- !--dubbo:reference iddemoService interfacecom.st.DemoService--!--urldubbo://localhost:20880/com.st.DemoService/--dubbo:reference iddemoService interfacecom.st.DemoService/ 注册信息在zookeeper中如何保存 启动上面服务后我们观察zookeeper的根节点多了一个dubbo节点及其他图示如下 最后一个节点中192.168.1.104是小编的内网地址你可以任务和上面配置的localhost一个效果大家可以想一下我为什么把最后一个节点标成绿色的。没错最后一个节点是临时节点而其他节点是持久节点这样当服务宕机时这个节点就会自动消失不再提供服务服务消费者也不会再请求。如果部署多个DemoService则providers下面会有好几个节点一个节点保存一个DemoService的服务地址 其实一个zookeeper集群能被多个应用公用如小编Storm集群和Dubbo配置的就是一个zookeeper集群为什么呢因为不同的框架会在zookeeper上建不同的节点互不影响。如dubbo会创建一个/dubbo节点storm会创建一个/storm节点如图 zookeeper相关介绍 Zookeeper 是 Apacahe Hadoop 的子项目是一个树型的目录服务支持变更推送适合作为 Dubbo 服务的注册中心工业强度较高可用于生产环境并推荐使用。 流程说明 服务提供者启动时: 向 /dubbo/com.foo.BarService/providers 目录下写入自己的 URL 地址服务消费者启动时: 订阅 /dubbo/com.foo.BarService/providers 目录下的提供者 URL 地址。并向 /dubbo/com.foo.BarService/consumers 目录下写入自己的 URL 地址监控中心启动时: 订阅 /dubbo/com.foo.BarService 目录下的所有提供者和消费者 URL 地址。支持以下功能 当提供者出现断电等异常停机时注册中心能自动删除提供者信息当注册中心重启时能自动恢复注册数据以及订阅请求当会话过期时能自动恢复注册数据以及订阅请求当设置 dubbo:registry checkfalse / 时记录失败注册和订阅请求后台定时重试可通过 dubbo:registry usernameadmin password1234 / 设置 zookeeper 登录信息可通过 dubbo:registry groupdubbo / 设置 zookeeper 的根节点不设置将使用无根树支持 * 号通配符 dubbo:reference group* version* /可订阅服务的所有分组和所有版本的提供者Dubbo相关介绍 Dubbo是什么 Dubbo是一个分布式服务框架致力于提供高性能和透明化的RPC远程服务调用方案以及SOA服务治理方案。简单的说dubbo就是个服务框架如果没有分布式的需求其实是不需要用的只有在分布式的时候才有dubbo这样的分布式服务框架的需求并且本质上是个服务调用的东东说白了就是个远程服务调用的分布式框架告别Web Service模式中的WSdl以服务者与消费者的方式在dubbo上注册 其核心部分包含: 远程通讯: 提供对多种基于长连接的NIO框架抽象封装包括多种线程模型序列化以及“请求-响应”模式的信息交换方式。集群容错: 提供基于接口方法的透明远程过程调用包括多协议支持以及软负载均衡失败容错地址路由动态配置等集群支持。自动发现: 基于注册中心目录服务使服务消费方能动态的查找服务提供方使地址透明使服务提供方可以平滑增加或减少机器。Dubbo能做什么 透明化的远程方法调用就像调用本地方法一样调用远程方法只需简单配置没有任何API侵入。软负载均衡及容错机制可在内网替代F5等硬件负载均衡器降低成本减少单点。服务自动注册与发现不再需要写死服务提供方地址注册中心基于接口名查询服务提供者的IP地址并且能够平滑添加或删除服务提供者。Dubbo采用全Spring配置方式透明化接入应用对应用没有任何API侵入只需用Spring加载Dubbo的配置即可Dubbo基于Spring的Schema扩展进行加载。 转载于:https://www.cnblogs.com/iisme/p/10620125.html
http://wiki.neutronadmin.com/news/207196/

相关文章:

  • 怎样发掘网站建设的客户电子商务网站的开发方式有哪三种
  • 新农村建设 网站seo服务外包
  • 做网站第一步设计logo图片
  • 手机网站 标题长度凡客诚品是品牌吗
  • 建立公司网站河南专业网站建设
  • 开源做网站需要申请账号吗怎么做纪念网站
  • 吴中网站建设广州网站建设 领航科技
  • wordpress 评论 样式大庆网站建设优化
  • 西宁市城北区建设网站英山做网站多少钱
  • 建设部的网站手工制作花
  • 成都广告公司网站建设网站开发公司一站式服务
  • 做家装网站源码做网站起什么名字比较好
  • 购物网站设计流程图wordpress怎么搜索代码
  • 网站怎么自己做国外设计公司名字
  • 在线做qq空间的网站吗jsp mysql 开发网站开发
  • 广州 骏域网站建设 陶瓷免费wordpress网站
  • 黑龙江城乡建设厅网站辅导班广告去哪个网站做
  • 免费的行情网站app入口知名网站建设是哪家
  • 网站建设需要什么内容一个专门做标题的网站
  • 北京广告公司招聘信息深圳网络推广seo软件
  • 网站怎么做seo网络服务器可提供的常见服务有什么服务
  • 网站哪个公司做的比较好的多用户网上商城
  • 饮食网站模板陇南市建设局官方网站
  • 做网站用旧域名好不好黄冈网站推广都有哪些渠道
  • 最新网站建设合同网站建设销售兼职合同
  • 增城定制型网站建设手机网站 php
  • wordpress escattrseo优化排名是什么
  • 象山县住房和城乡建设局网站广州网页设计html
  • 网站后台怎么建设网站建设推广服务合同范本
  • 怎么制作个人门户网站北京城乡建设部网站首页