这是一张dubbo的调用图
调用关系说明如下:
1) 服务容器启动、加载和运行服务提供者; 2) 服务提供者在启动时,向注册中心注册自己提供的服务; 3) 服务消费者在启动时,向注册中心订阅自己所需的服务; 4) 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更给消费者; 5) 服务消费者从地址列表中,基于软负载均衡算法选一台服务提供者进行调用,如果调用失败再选另一台; 6) 服务消费者和服务提供者在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。 复制代码
节点角色说明
节点 | 角色说明 |
---|---|
Container | 服务运行容器 |
Provider | 暴露服务的服务提供者 |
Consumer | 调用远程服务的服务消费者 |
Registry | 服务注册与发现的注册中心 |
Monitor | 统计服务的调用此处和调用时间的监控中心 |
技术为业务而生,架构也为业务而出现 。随着业务的发展、用户量的增长,系统数量增多,调用依赖关系也变得复杂,为了确保系统高可用、高并发的要求,系统的架构也从单体时代慢慢迁移至服务SOA时代, 根据不同服务对系统资源的要求不同,我们可以更合理的配置系统资源,使系统资源利用率最大化 。
平台随着业务的发展 从 All in One 环境 就可以满足业务需求(以Java来说,可能只是一两个war包就解决了);发展到需 要拆分多个应用,并且采用MVC的方式 分离前后端,加快开发效率;在发展到服务越来越多,不得不将 一些核心或共用的服务拆分出来 ,提供实时流动监控计算等,其实发展到此阶段,如果服务拆分的足够精细,并且独立运行,这个时候至少可以 理解为SOA架构 了。
当迎来服务SOA时代,我们面临要解决的问题会很多,比如: 系统的复杂度上升、服务依赖关系、服务性能监控、全链路日志、容灾、断路器、限流等 。那么面对这些问题为什么还要做分布式服务呢? 因为在未来只有砥砺前行,才能走的更高更远 。不过看到这些问题不要气馁,先不管这些问题,让我们一步步来梳理下现存有什么问题,我们要完成什么目标,问题自然会迎刃而解。
根据现在团队的业务系统情况,首先我们要梳理出现存的问题是什么:
在去选择技术框架时,技术框架最基本要解决上面现存问题,同时我们也要确认出我们的期望,要达到的目标是什么:
还有最重要一点,这也是往往很多技术人员进入的误区, “对于技术,不要为了使用而使用,用最简单合适的技术实现解决问题才是正道”。架构是服务于业务的,能快速方便的满足业务需求的架构才是好的架构 。
Dubbo 采用全 Spring 配置方式,透明化接入应用,对应用没有任何 API 入侵,只需用 Spring 加载 Dubbo 配置即可。
官方推荐使用 Zookeeper 作为注册中心,因此本次测试使用 Zookeeper,将其放置在 ip 为 192.168.1.1 的虚拟机上。
# 解压和转移目录 tar -zxvf zookeeper-3.4.8.tar.gz -C /usr/ cd /usr mv zookeeper-3.4.8 zookeeper # 设置配置文件 cd /usr/zookeeper/conf cp zoo_sample.cfg zoo.cfg # 启动 zookeeper /usr/zookeeper/bin/zkServer.sh start # 查看 zookeeper 运行状态,如果出现 Mode: standalone 说明运行成功 /usr/zookeeper/bin/zkServer.sh status 复制代码
创建一个 Maven 项目(名为 dubbo-service 的 web 项目)。
pom.xml 配置:
web.xml 配置:
接口:
实现类:
applicationContext-dubbo.xml 配置:
//提供方应用信息,计算依赖关系 <dubbo:application name="hello-demo"/> //使用广播注册中心暴露服务地址 <dubbo:registry address="zookeeper://192.168.1.1:2181"/> //用dubbo协议在20880端口暴露服务 <dubbo:protocol name="dubbo" port="20880"/> //声明需要暴露服务的服务接口 <dubbo:service interface="com.light.dubbo.service.HelloService" ref="helloService"/> <bean id="helloService" class="com.light.dubbo.service.impl.HelloServiceImpl"/> 复制代码
创建一个 Maven 项目(名为 dubbo-consumer 的 web 项目)。
pom.xml 配置:
web.xml 配置:
将 dubbo-service 项目中的 HelloService 接口复制到该项目(dubbo-consumer)中。
控制层:
@Controller public class HelloController { @Autowired private HelloService helloService; @RequestMapping("hello") @ResponseBody public String hello(String name) { return this.helloService.sayHello(name); } } 复制代码
applicationContext-dubbo.xml 配置:
<dubbo:application name="hello-demo"/> <dubbo:registry address="zookeeper://192.168.2.14:2181"/> <dubbo:protocol name="dubbo" port="20880"/> <dubbo:reference interface="com.light.dubbo.service.HelloService"/> 复制代码
springmvc.xml 配置:
先启动服务提供者的项目(8080),再启动服务消费者的项目(8081)。打开浏览器访问 http://localhost:8081/hello?name=jack ,结果如下图:
可以通讯。启动 Dubbo 时,消费者会从 Zookeeper 拉取注册的生产者的地址接口等数据,缓存在本地。每次调用时,按照本地存储的地址进行调用。