最近学习了一下dubbo的集成使用,之所以对这个产生兴趣,是因为公司的系统有秒杀的高并发业务,采用了多服务器分布式部署的方式,但是各个服务器之间的调用是在代码里采用http请求的方式。虽然这种方式能达到效果,但是代码冗长,处理起来很不方便,总之就是觉得low,所以决定学习一下dubbo。
学习dubbo之前,我们先要了解一下zookeeper,分布式服务的调度中心。
zookeeper下载安装:
1 、下载地址为http://mirrors.cnnic.cn/apache/zookeeper,自行选择相应的版本进行下载;
2、安装不作具体说明,安装完成之后,找到安装文件夹下的conf/zoo_sample.cfg,将其重命名为zoo.cfg,然后编辑该文件,注意下图中标注的四个参数配置;
3、运行bin/zkServer.cmd启动zookeeper。
下面开始介绍dubbo:
Dubbo的项目结构大致可以分为三部分:dubbo-api、dubbo-provider和dubbo-consumer,具体见截图。
首先在pom中引入dubbo和zookeeper的依赖。
接下来,我们先来看看api中的内容:
Api中定义了接口,然后在配置文件中引用服务配置,其实就是consumer的相关配置,在consumer中可以直接引用。
再来看看provider,这里面主要是实现api中定义的接口,然后告诉zookeeper,并向zookeeper暴露自己的端口号。
最后看consumer,这是对外提供访问的工程。直接调用provider里面的实现类方法。
一个简单的dubbo应用项目就构建完了,需要注意的是,我之前使用的spring boot版本比较低,与dubbo不能很好地兼容,导致项目不能正常的启动,后来提升了一下spring boot的版本就好了。
Dubbo自身有提供一个管理后台,直接取官网上下载代码,然后扔到tomcat中运行即可。