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

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


      注册中心的选择


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

    这里我们选择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操作,同时也提供了安全认证,按照如下几步就可以完成安装。

    下面是创建dubbo服务以及使用dubbo服务的过程:

       dubbo提供者,创建一个java工程,注意以下几点:

    <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";  }}

    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();    }  }}

     <??><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消费者

    <??><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还有好多提供的最佳实践,比如服务治理:

    • 本地存根
    • 本地伪装
    • 结果缓存
    • 多版本
    • 服务降级
    • 管理提供者
    • 管理消费者
    • 接口注解定义以及接口调用
    • 指定消费者的名称,这个可以随意,不需要与提供者做任务相关联的匹配。
    • 指定协定类型,zookeeper地址。
    • 指定引用的服务接口,注意这里的id就与服务提供者定义的ref值相同。
    • 消费者配置文件,它的配置相对提供者要简单很多:
    • dubbo:service的定义配合了dubbo:annotation,ref="productService",是指定的一个id,实际的实现类通过注解扫描来完成的,并没有在配置文件中指定实现类,后面的消费者配置文件中会有所体现。
    • dubbo:application中,可以指定logger的实现接口。
    • dubbo:protocol中,可以指定是否启动访问日志,这个对有时排查线上问题非常有帮助。
    • 服务配置文件,这里需要指出的是:
    • 加载配置文件
    • 调用context.start()
    • 执行一个不退出程序的操作,这里有很多种做法。
    • 服务启动函数
    • 接口实现
    • 定义接口,这里为了演示,简单定义了一个返回产品名称的接口。
    • 包依赖,引入如下三个主要的包就可以了,主要是spring,dubbo以及zkclient
    • 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安装运行正常。
    • Multicast注册中心
    • Zookeeper注册中心
    • Redis注册中心
    • Simple注册中心
    • 最后,是dubbo的架构图
    • 其次,当服务越来越多之后,我们需要做哪些服务治理?
    • 首先,看下一般网站架构随着业务的发展,逻辑越来越复杂,数据量越来越大,交互越来越多之后的常规方案演进历程。
  • 核心技术:Maven,Springmvc mybatis shiro, Druid, Restful, Dubbo, ZooKeeper,Redis,FastDFS,ActiveMQ,Nginx 
    1.     项目核心代码结构截图

    项目模块依赖

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

    2.    项目依赖介绍

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

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

    3.  项目功能部分截图:

    zookeeper、dubbo服务启动

    dubbo管控台

    REST服务平台

时间: 2024-10-20 03:31:33

从头开始搭建一个dubbo+zookeeper平台 【转】的相关文章

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

本篇主要是来分享从头开始搭建一个dubbo+zookeeper平台的过程,其中会简要介绍下dubbo服务的作用. 首先,看下一般网站架构随着业务的发展,逻辑越来越复杂,数据量越来越大,交互越来越多之后的常规方案演进历程. 其次,当服务越来越多之后,我们需要做哪些服务治理? 最后,是dubbo的架构图   注册中心的选择   dubbo支持多种类型的注册中心: Multicast注册中心 Zookeeper注册中心 Redis注册中心 Simple注册中心 这里我们选择zookeeper,其实类型

从头开始搭建一个mybatis+postgresql平台

     最近有个项目的数据库使用postgresql,使用原生态的mybatis操作数据,原生态的没什么不好,只不过国内有个tk.mybatis的工具帮助我们做了很多实用的事情,大多数情况下我们需要在原生态mybatis上加工的想法它基本上都已经有很好的实现,这篇将分享安装postgresql,配置tk.mybatis的详细步骤以及在这过程中可能遇到的一些小问题. 安装postgresql,执行下面的命令就可以安装了: apt-get update && apt-get install

第一次搭建springboot+dubbo+zookeeper项目小结

第一次用IDEA搭建springboot+dubbo+zookeeper项目中碰到了一些问题,现在记录下来, 第一步:项目准备工作 工具IDEA,先下载安装zookeeper和dubbo   Zookeeper下载地址:https://zookeeper.apache.org/releases.html,我下载最新的release 3.5.7 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是

搭建一个网站论坛平台

修改主机名 Hostname openstack-001 Hostname Login 修改本地域名解析 Vi /etc/hosts 最后一行添加 192.168.1.56 openstack-001 Clear Ping openstack-001 Ls /opt/ 查看 配置文件 Vi dvd.repo 列出仓库内容 关闭防火墙 Iptables -F Iptables -X Iptables -L查看 修改SELINUX 修改SELINUX 修改enforcing改为disabled 设置

ubuntu从头开始搭建hadoop伪分布式环境

13年学习过一段时间的hadoop,但是工作中用到的地方比较少,有些生疏,加上现在hadoop版本也已经比较新了,所以空闲时间想继续学习一下,找到这篇文章,从头开始搭建一个hadoop环境,转过来备忘 Hadoop developers usually test their scripts and code on a pseudo-distributed environment(also known as a single node setup), which is a virtual mach

用dubbo+zookeeper+spring搭建一个简单的http接口程序

dubbo是一个分布式服务框架,是阿里巴巴开发的一个解决RPC远程调用优化的核心框架,包含负载均衡算法,能提高分布式系统的性能. zookeeper是hadoop的一个子项目,主要用来解决分布式系统的数据一致性.状态同步.服务集群管理.配置同步等一系列的问题.本文使用zookeeper作为dubbo的服务注册中心. 技术细节方面: dubbo:http://www.dubbo.io zookeeper:http://www.ibm.com/developerworks/cn/opensource

Dubbo入门---搭建一个最简单的Demo框架

Dubbo背景和简介 Dubbo开始于电商系统,因此在这里先从电商系统的演变讲起. 单一应用框架(ORM) 当网站流量很小时,只需一个应用,将所有功能如下单支付等都部署在一起,以减少部署节点和成本. 缺点:单一的系统架构,使得在开发过程中,占用的资源越来越多,而且随着流量的增加越来越难以维护 垂直应用框架(MVC) 垂直应用架构解决了单一应用架构所面临的扩容问题,流量能够分散到各个子系统当中,且系统的体积可控,一定程度上降低了开发人员之间协同以及维护的成本,提升了开发效率. 缺点:但是在垂直架构

spring mvc+ELK从头开始搭建日志平台

spring mvc+ELK从头开始搭建日志平台 最近由于之前协助前公司做了点力所能及的事情,居然收到了一份贵重的端午礼物,是给我女儿的一个乐高积木,整个有7大包物件,我花了接近一天的时间一砖一瓦的组织起来,虽然很辛苦但是能够从过程中体验到乐趣.这次将分享从头搭建分布式日志系统,主要是在spring mvc上结合ELK套件实现(之前有些工作由于分工不同由不同的同事来完成,我只是在已经配置好的环境下做开发而已),包含如下这些技术点: spring mvc logback logstash elas

从头开始搭建分布式日志平台的docker环境

上篇(spring mvc+ELK从头开始搭建日志平台)分享了从头开始搭建基于spring mvc+redis+logback+logstash+elasticsearch+kibana的分布式日志平台,是在windows平台下操作的,这篇主要是将这些软件环境全部在linux+docker折腾一遍. 我们的目的是需要在docker中安装像resis,elk这些软件环境,由于我是windows平台,搜索一把找到了boot2docker,但在安装时提示需要用dockermachine来安装,dock