从头开始搭建一个dubbo+zookeeper平台

本篇主要是来分享从头开始搭建一个dubbo+zookeeper平台的过程,其中会简要介绍下dubbo服务的做用。java

  • 首先,看下通常网站架构随着业务的发展,逻辑愈来愈复杂,数据量愈来愈大,交互愈来愈多以后的常规方案演进历程。

从头开始搭建一个dubbo+zookeeper平台

 

  • 其次,当服务愈来愈多以后,咱们须要作哪些服务治理?

从头开始搭建一个dubbo+zookeeper平台

 

  • 最后,是dubbo的架构图

从头开始搭建一个dubbo+zookeeper平台

 

注册中心的选择redis

从头开始搭建一个dubbo+zookeeper平台

 

dubbo支持多种类型的注册中心:spring

  • Multicast注册中心
  • Zookeeper注册中心
  • Redis注册中心
  • Simple注册中心

这里咱们选择zookeeper,其实类型的优势缺点可详细查看文档。docker

1:zookeeper的安装,仍是采用docker这一招鲜的run命令来安装zookeeper缓存

docker run -dit --name zookeeper --hostname zookeeper-host -v /data:/data -p 2181:2181 jplock/zookeeper:latest

2:安装zkui,能够参考zkui的项目地址来安装,它提供了一个管理界面,能够针对zookeepr的节点值进行CRUD操做,同时也提供了安全认证,按照以下几步就能够完成安装。安全

  • mvn clean install,执行前须要安装java环境,maven环境,执行成功后会生成一个jar文件。
  • 将config.cfg复制到上一步生成的jar文件所在目录,而后修改配置文件中的zookeeper地址。
  • 执行 jar. ( nohup java -jar zkui-2.0-SNAPSHOT-jar-with-dependencies.jar & ),注意后面的那个&,是指不退出的意思。
  • 测试,http://localhost:9090,如能看到以下页面则表明zookeeper安装运行正常。

从头开始搭建一个dubbo+zookeeper平台

 

从头开始搭建一个dubbo+zookeeper平台

 

下面是建立dubbo服务以及使用dubbo服务的过程:架构

从头开始搭建一个dubbo+zookeeper平台

 

dubbo提供者,建立一个java工程,注意如下几点:app

  • 包依赖,引入以下三个主要的包就能够了,主要是spring,dubbo以及zkclient
<dependency>
 <groupId>org.springframework</groupId>
 <artifactId>spring-context</artifactId>
 <version>${spring-framework.version}</version>
 </dependency>
 <dependency>
 <groupId>com.alibaba</groupId>
 <artifactId>dubbo</artifactId>
 <version>2.4.10</version>
 <exclusions>
 <exclusion>
 <artifactId>spring</artifactId>
 <groupId>org.springframework</groupId>
 </exclusion>
 </exclusions>
 </dependency>
 <dependency>
 <groupId>com.101tec</groupId>
 <artifactId>zkclient</artifactId>
 <version>0.3</version>
 </dependency>
  • 定义接口,这里为了演示,简单定义了一个返回产品名称的接口。
public interface IProduct {
 String getProductName();
}
  • 接口实现
@Service
public class ProductService implements IProduct{
 public String getProductName() {
 
 return "jim";
 }
}
  • 服务启动函数
  • 加载配置文件
  • 调用context.start()
  • 执行一个不退出程序的操做,这里有不少种作法。
public class App {
 private final static Logger logger = LoggerFactory.getLogger(App.class);
 public static void main(String[] args) {
 ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
 "classpath*:applicationContext.xml");
 context.start();
 logger.info("dubbo service begin to start");
 try {
 System.in.read();
 } catch (IOException e) {
 // TODO Auto-generated catch block
 e.printStackTrace();
 }
 }
}
  • 服务配置文件,这里须要指出的是:
  • dubbo:service的定义配合了dubbo:annotation,ref="productService",是指定的一个id,实际的实现类经过注解扫描来完成的,并无在配置文件中指定实现类,后面的消费者配置文件中会有所体现。
  • dubbo:application中,能够指定logger的实现接口。
  • dubbo:protocol中,能够指定是否启动访问日志,这个对有时排查线上问题很是有帮助。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
 xmlns:context="http://www.springframework.org/schema/context"
 xmlns:util="http://www.springframework.org/schema/util"
 xmlns:aop="http://www.springframework.org/schema/aop"
 xsi:schemaLocation="http://www.springframework.org/schema/beans 
 http://www.springframework.org/schema/beans/spring-beans.xsd 
 http://code.alibabatech.com/schema/dubbo 
 http://code.alibabatech.com/schema/dubbo/dubbo.xsd
 http://www.springframework.org/schema/context
 http://www.springframework.org/schema/context/spring-context.xsd
 http://www.springframework.org/schema/util
 http://www.springframework.org/schema/util/spring-util.xsd"
 >
 <context:property-placeholder location="classpath*:config.properties"/>
 <dubbo:application name="jim" logger="slf4j" />
 <dubbo:registry protocol="zookeeper" address="192.168.21.128:2181" />
 <dubbo:protocol accesslog="true" name="dubbo" port="20880" />
 <dubbo:annotation package="jim" />
 <dubbo:service interface="jim.IProduct" ref="productService"/>
 <context:component-scan base-package="jim" />
 <import resource="redis-context.xml"/>
</beans>

dubbo消费者maven

从头开始搭建一个dubbo+zookeeper平台

 

  • 消费者配置文件,它的配置相对提供者要简单不少:
  • 指定消费者的名称,这个能够随意,不须要与提供者作任务相关联的匹配。
  • 指定协定类型,zookeeper地址。
  • 指定引用的服务接口,注意这里的id就与服务提供者定义的ref值相同。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
 <dubbo:application name="consumer-of-jim-app" />
 <dubbo:registry protocol="zookeeper" address="192.168.21.128:2181"/>
 <dubbo:reference interface="jim.IProduct" id="productService" />
</beans>
  • 接口注解定义以及接口调用
@Controller
public class HomeController {
 private static final Logger logger = LoggerFactory.getLogger(HomeController.class);
 @Autowired
 private IProduct productService;
 @RequestMapping(value = "/", method = RequestMethod.GET)
 public String home(Locale locale, Model model) {
 logger.info("Welcome home! The client locale is {}.", locale);
 
 String productName=this.productService.getProductName();
 model.addAttribute("name", productName);
 return "home";
 }
}

dubbo admin函数

有一个UI工具能够针对dubbo服务进行管理,惋惜我没有在官方文档提供的连接中下载成功,随后从其它地方虽然下载完成了,但在安装部署方面暂时遇到了必定的问题,须要手续研究解决。

从头开始搭建一个dubbo+zookeeper平台

 

正常应该能够看到以下界面:

  • 管理提供者
  • 管理消费者

从头开始搭建一个dubbo+zookeeper平台

 

服务治理

从头开始搭建一个dubbo+zookeeper平台

 

通过上面的步骤后,就能够启动服务端以及客户端来验证了。上面只是简单的搭建了dubbo环境以及实现了一个hello world的服务接口,要想使用好dubbo还有好多提供的最佳实践,好比服务治理:

  • 本地存根
  • 本地假装
  • 结果缓存
  • 多版本
  • 服务降级
  • ......
相关文章
相关标签/搜索