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

Posted java版web项目

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了从头开始搭建一个dubbo+zookeeper平台相关的知识,希望对你有一定的参考价值。


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

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

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

  •   其次,当服务越来越多之后,我们需要做哪些服务治理?

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

  •   最后,是dubbo的架构图

       从头开始搭建一个dubbo+zookeeper平台
  注册中心的选择

从头开始搭建一个dubbo+zookeeper平台
  dubbo支持多种类型的注册中心:

  •   Multicast注册中心

  •   Zookeeper注册中心

  •   Redis注册中心

  •   Simple注册中心

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


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

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

mvn clean install,执行前需要安装java环境,maven环境,执行成功后会生成一个jar文件。

执行 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工程,注意以下几点:

包依赖,引入如下三个主要的包就可以了,主要是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();

}
  •  接口实现 

@Servicepublic 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消费者

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

<?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>
  •    接口注解定义以及接口调用    

@Controllerpublic 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环境以及实现了一个hello world的服务接口,要想使用好dubbo还有好多提供的最佳实践,比如服务治理:

  • 本地存根

  • 本地伪装

  • 结果缓存

  • 多版本

  • 服务降级

  • ......

     

 本文引用:

  1. http://dubbo.io/User+Guide-zh.htm#UserGuide-zh-%E5%A4%9A%E6%B3%A8%E5%86%8C%E4%B8%AD%E5%BF%83

  2. http://blog.csdn.net/yinwenjie/article/details/50113139

  3. https://github.com/DeemOpen/zkui

4000G java高级架构师进阶视频下载

 今日头条号:搜索 "JavaLeader"  (欢迎大家关注支持,头条更精彩)

 java资源分享总群(六) :238600498       java招聘信息共享群:489895481

 java微信技术群:微信搜索1257572500加好友,拉入群内。

专注互联网热点信息,java干货,行业最新技术视频分享,我们的宗旨就是做全网最全最大的java视频教免费平台。我们有适合不同阶段人群的干货。我们的平台聚焦了几万的java高级程序员和架构师。欢迎长按关注

以上是关于从头开始搭建一个dubbo+zookeeper平台的主要内容,如果未能解决你的问题,请参考以下文章

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

zookeeper环境及dubbo-admin管理平台搭建

dubbo框架Demo之dubbo-admin管理平台和zookeeper注册中心搭建

dubbo系列dubbo+zookeeper+dubboadmin分布式服务框架搭建(windows平台)

Dubbo+Zookeeper平台的搭建

dubbo学习之快速搭建dubbo平台和zookeeper伪集群