文档章节

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

 梵蒂冈考虑过
发布于 2016/08/13 10:21
字数 1415
阅读 80
收藏 16
点赞 3
评论 1
  •  

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

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

         

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

          

    •   最后,是dubbo的架构图

          
      注册中心的选择


      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
     


      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服务以及使用dubbo服务的过程:

       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) {    ClassPath= new ClassPath"classpath*:applicationContext.);    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中,可以指定是否启动访问日志,这个对有时排查线上问题非常有帮助。
    <??><beans ="http://www.springframework.org/schema/beans"  ="http://www.w3.org/2001/ ="http://code.alibabatech.com/schema/dubbo"  ="http://www.springframework.org/schema/context"  ="http://www.springframework.org/schema/util"  ="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./></beans>
     

             
       dubbo消费者

        

    •    消费者配置文件,它的配置相对提供者要简单很多:
      • 指定消费者的名称,这个可以随意,不需要与提供者做任务相关联的匹配。
      • 指定协定类型,zookeeper地址。
      • 指定引用的服务接口,注意这里的id就与服务提供者定义的ref值相同。
    <??><beans ="http://www.springframework.org/schema/beans"  ="http://www.w3.org/2001/  ="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环境以及实现了一个hello world的服务接口,要想使用好dubbo还有好多提供的最佳实践,比如服务治理:

    • 本地存根
    • 本地伪装
    • 结果缓存
    • 多版本
    • 服务降级
  • 核心技术:Maven,Springmvc mybatis shiro, Druid, Restful, Dubbo, ZooKeeper,Redis,FastDFS,ActiveMQ,Nginx 
    1.     项目核心代码结构截图

    分布式框架介绍 - kafkaee - kafkaee的博客

  •  

       项目模块依赖分布式框架介绍 - kafkaee - kafkaee的博客

    特别提醒:开发人员在开发的时候可以将自己的业务REST服务化或者Dubbo服务化

    2.    项目依赖介绍

       2.1 后台管理系统、Rest服务系统、Scheculer定时调度系统依赖如下图:
     

    分布式框架介绍 - kafkaee - kafkaee的博客

           2.2 Dubbo独立服务项目依赖如下图:

     分布式框架介绍 - kafkaee - kafkaee的博客

    3.  项目功能部分截图:

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客
     

    zookeeper、dubbo服务启动 

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客
     

    dubbo管控台 

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     REST服务平台

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

    分布式框架介绍 - kafkaee - kafkaee的博客

     

  •  

© 著作权归作者所有

共有 人打赏支持
粉丝 26
博文 53
码字总数 105771
作品 0
深圳
加载中

评论(1)

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

本篇主要是来分享从头开始搭建一个dubbo+zookeeper平台的过程,其中会简要介绍下dubbo服务的作用。 首先,看下一般网站架构随着业务的发展,逻辑越来越复杂,数据量越来越大,交互越来越多之...

如何让他和 ⋅ 2016/08/11 ⋅ 1

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

本篇主要是来分享从头开始搭建一个dubbo+zookeeper平台的过程,其中会简要介绍下dubbo服务的作用。 首先,看下一般网站架构随着业务的发展,逻辑越来越复杂,数据量越来越大,交互越来越多之...

如何让他和 ⋅ 2016/08/07 ⋅ 0

Spring boot整合jsp出现 No message available

我单独创建一个Springboot项目整合jsp没有问题,但是采用dubbo+zookeeper的时候就出现了No message available。这个是在一个project下新建的model。 # 页面默认前缀目录 spring.mvc.view.pr...

小鸟也疯狂 ⋅ 2016/12/27 ⋅ 1

使用yml配置SpringBoot整合Dubbo

最近听闻公司的项目打算进行重构,大佬们商量准备使用近年大火的SpringCloud,所以在开始学习Springcloud前,先来复习下之前项目中使用到的Dubbo+Zookeeper。之前的项目很老使用的Spring+St...

小马尾大木头 ⋅ 01/09 ⋅ 0

Linux下服务器的配置及项目部署

@wangrikui 你好,想跟你请教个问题:就是关于Linux下服务器配置完成后(dubbo+zookeeper),怎么把javaweb项目放到服务器上面去呢,以前没弄过服务器方面的东西,网上也查了许多资料,没有一...

弑神域城kill ⋅ 2016/04/05 ⋅ 2

当启动顺序不对时,service调用报空指针异常

在做当用dubbo+zookeeper做分布式的时候,发现一个问题。 两个项目,一个为provider,另一个为consumer,当先启动consumer,后启动provider的时候,调用正常。 而当先启动provider,后启动c...

Jager蓝 ⋅ 05/23 ⋅ 0

推荐几个自己写的Java后端相关的范例项目(转载)

http://wosyingjun.iteye.com/blog/2312553 这里推荐几个自己写的范例项目,主要采用SSM(Spring+SpringMVC+Mybatis)框架,分布式架构采用的是(dubbo+zookeeper)。范例项目的好处是简单易...

指尖的舞者 ⋅ 2016/09/27 ⋅ 0

安全与便捷兼得:新华三移动IT助推税务泽潇湘

如今,信息化发展水平已经成为衡量一个国家综合国力和竞争力的重要标志,利用信息技术发展电子政务也已成为实现国家治理体系和治理能力现代化目标的重要条件。李克强总理在2015年3月的政府工...

玄学酱 ⋅ 05/17 ⋅ 0

dubbo+zookeeper

zookeeper 安装 单击模式 集群模式 dubbo demo Consumer registry 配置 Pom配置 运行配置 Provider 同Consumer 链接 Zookeeper 安装 Zookeeper 官网 官网 Dubbo 教程...

细节探索者 ⋅ 05/04 ⋅ 0

Kernel.org 重建基础架构

在遭黑客攻击后,Kernel.org至今仍未上线。期间系统管理者发布了多次状态更新。最新的更新称,他们正辛苦的从头开始重新搭建Kernel.org的基础架构,新的架构将不再允许shell访问git库,他们正...

红薯 ⋅ 2011/09/25 ⋅ 10

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Netweaver和SAP云平台的quota管理

Netweaver 以需要为一个用户上下文(User Context)能够在SAP extended memory区域中分配内存尺寸创建quota为例。 对于Dialog工作进程,使用事务码修改参数 ztta/roll_extension_dia. 对于非D...

JerryWang_SAP ⋅ 23分钟前 ⋅ 0

IDEA提示编码速度

焦点移动 将焦点冲代码编辑窗口移动到菜单栏:Alt+菜单栏带下划线字母 将焦点从工具窗口移动到代码编辑窗口 Esc或Shift+Esc 将焦点从代码编辑移动到最近使用的工具窗口 F12 模板提示 Ctrl+J...

bithup ⋅ 32分钟前 ⋅ 0

180623-SpringBoot之logback配置文件

SpringBoot配置logback 项目的日志配置属于比较常见的case了,之前接触和使用的都是Spring结合xml的方式,引入几个依赖,然后写个 logback.xml 配置文件即可,那么在SpringBoot中可以怎么做?...

小灰灰Blog ⋅ 55分钟前 ⋅ 0

冒泡排序

原理:比较两个相邻的元素,将值大的元素交换至右端。 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。然后比较第...

人觉非常君 ⋅ 今天 ⋅ 0

Vagrant setup

安装软件 brew cask install virtualboxbrew cask install vagrant 创建project mkdir -p mst/vmcd mst/vmvagrant init hashicorp/precise64vagrant up hashicorp/precise64是一个box......

遥借东风 ⋅ 今天 ⋅ 0

python3.6 安装pyhook_3

我的是在win下的,忙了半天老是安装不了, pip install 也不行。 那么可以看出自己的版本是32bit 一脸懵逼 没办法 只好下载32版本的来安装 我一直以为 是 对应32 位的 。 下面是 小例子 http...

之渊 ⋅ 今天 ⋅ 0

004、location正则表达式

1、location的作用 location指令的作用是根据用户请求的URI来执行不同的应用,也就是根据用户请求的网站URL进行匹配,匹配成功即进行相关的操作。 2、location的语法 = 开头表示精确匹配 ^~...

北岩 ⋅ 今天 ⋅ 0

CentOS7 静默安装 Oracle 12c

环境 CentOS7.5 最小安装 数据库软件 linuxx64_12201_database.zip 操作系统配置 关闭 SELinux sed -i '/^SELINUX=/cSELINUX=disabled' /etc/selinux/config 关闭防火墙 systemctl disable ......

Colben ⋅ 今天 ⋅ 0

Yii2中findAll()的正确使用姿势/返回为空的处理办法

从一次错误的操作开始 $buildingObject = Building::findAll("status=1"); 1 这个调用看着没有任何毛病,但是在使用时返回的结果却是一个空数组。再回过头来看看数据表中: 按照套路来讲,查...

dragon_tech ⋅ 今天 ⋅ 0

如何优雅的编程——C语言界面的一点小建议

我们鼓励在编程时应有清晰的哲学思维,而不是给予硬性规则。我并不希望你们能认可所有的东西,因为它们只是观点,观点会随着时间的变化而变化。可是,如果不是直到现在把它们写在纸上,长久以...

柳猫 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部