SpringMVC与Zookeeper、Dubbo使用示例
Dubbo整合Zookeeper和spring示例程序
1.Dubbo架构
本篇文章基于dubbox,使用dubbo应该也可以正常运行。
我认为想讲清楚一个任何一个技术框架,首先熟悉架构是非常有必要的。这将对对整个架构的理解有非常大的帮助。
我们首先看看Dubbo的架构,这段摘抄自Dubbo官方文档
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
调用关系说明:
- 服务容器负责启动,加载,运行服务提供者。
- 服务提供者在启动时,向注册中心注册自己提供的服务。
- 服务消费者在启动时,向注册中心订阅自己所需的服务。
- 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
- 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
- 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。 看到这可能会发现,Dubbo其实就是一个分布式RPC的框架。下面我们用一个示范例子来说明该框架的使用方法。
2.运行Dubbo
我这里采用的是当当网修改后的版本DubboX。
0. 安装运行Zookeeper
因为需要用到zookeeper作为注册中心,所以必须先安装运行zookeeper,到apache官网下载zookeeper,解压缩后找到zookeeper根目录下的conf目录下的zoo_sample.cfg文件,复制并重命名一份为zoo.cfg
在这里主要关注第14行zookeeper的开放端口,默认为2181。
修改完毕后在终端中进入zookeeper的根目录,执行bin下面的启动命令bin/zkServer.sh start
- 先下载到本地,并且解压缩
在Dubbox官网中下载Dubbox,并且解压缩。 - 编译
在终端下进入Dubbox的根目录,执行编译命令mvn install -Dmaven.test.skip=true。编译过程比较漫长,可以先干其他事情再过来看结果,如果编译过程出错,可以搜索相关错误信息进行解决。 - 创建相应的工程
编译完成后需要通过maven将项目创建成eclipse项目或者idea项目,由于我使用的是idea,所以这里我直接创建idea项目mvn idea:idea,创建eclipse项目则执行mvn eclipse:eclipse。
完成后将项目导入开发工具中,我在这里导入idea,然后对项目执行maven install操作。
如果报没有配置jdk的错误,则把jdk配置到项目。
- 启动Dubbo 在项目编译成功后会在dubbo-admin的target目录下生成dubbo-admin-2.8.4文件夹,将此文件夹下的内容拷贝到tomcat/webapps/ROOT目录下,然后在tomcat根目录下执行bin/startup.sh,成功启动tomcat后在浏览器输入http://localhost:8080/,如果提示输入用户名和密码则输入root和root。如果进入如下页面则恭喜你,Dubbo启动成功。
3.开发示例程序
1.开发服务提供者provider
a.首先创建接口类TestRegistryService,创建抽象方法hello。
package com.stocsis.gavin.registry.service; /**
* Created by qhg on 16/6/30.
*/
public interface TestRegistryService {
public String hello(String name);
}
b.编写接口实现方法TestRegistryServiceImpl,实现具体的方法
package com.stocsis.gavin.registry.serviceImpl; import com.stocsis.gavin.registry.service.TestRegistryService; /**
* Created by qhg on 16/6/30.
*/
public class TestRegistryServiceImpl implements TestRegistryService {
public String hello(String name) {
return "hello "+name;
}
}
c.编写dubbo-provider.xml配置文件
d.运行provider
import org.springframework.context.support.ClassPathXmlApplicationContext; public class DemoProvider { public static void main(String[] args)throws Exception {
ClassPathXmlApplicationContext content = new ClassPathXmlApplicationContext(new String[]{"dubbo-provider.xml"});
content.start();
System.in.read();
} }
运行成功后查看dubbo的监控页面
2.开发服务消费者consumer
a.编写dubbo-consumer
<?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管理页面比较清晰是哪个应用暴露出来的 -->
<dubbo:application name="dubbo_consumer"></dubbo:application>
<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry address="zookeeper://127.0.0.1:2181" check="true"/> <dubbo:reference interface="com.stocsis.gavin.registry.service.TestRegistryService" id="testRegistryService"/> </beans>
b.编写服务消费类IndexController
package com.stocsis.gavin.provider.controller; import com.stocsis.gavin.registry.service.TestRegistryService;
import org.springframework.context.support.ClassPathXmlApplicationContext; /**
* Created by qhg on 16/7/1.
*/
public class IndexController { public static void main(String[] args) throws Exception {
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[]{"dubbo-consumer.xml"});
context.start(); TestRegistryService testRegistryService = (TestRegistryService) context.getBean("testRegistryService"); // 获取远程服务代理
String hello = testRegistryService.hello("world"); // 执行远程方法 System.out.println(hello); // 显示调用结果
System.in.read();
}
}
在这里不需要自己创建对象,而是直接获取远程bean对象,这就是dubbo提供的主要功能。看看运行结果吧。
dubbo的消费者页面
至此,整个示例结束。
为了方便学习,我将整个项目的源代码上传到github,如有不清楚的请查看github查看详细代码。
欢迎大家在评论区讨论。
SpringMVC与Zookeeper、Dubbo使用示例的更多相关文章
- dubbo+zookeeper+springboot简单示例
目录 dubbo+zookeeper+springboot简单示例 zookeeper安装使用 api子模块 生产者producer 消费者consumer @(目录) dubbo+zookeeper ...
- SpringMVC,Mybatis,FreeMarker连接mycat示例(一)
首页 > 程序开发 > 软件开发 > Java > 正文 SpringMVC,Mybatis,FreeMarker连接mycat示例(一) 项目结构如图: 首先是各种配置文件, ...
- dubbo简单示例
dubbo简单示例 2019-09-06 1 Zookeeper注册中心的搭建(windows单机) 下载zookeeper压缩包并解压到 D:\zookeeper\apache-zookeeper- ...
- spring springmvc mybatis maven 项目整合示例-导航页面
spring原理 实践解析-简单的helloworld spring原理案例-基本项目搭建 01 spring framework 下载 官网下载spring jar包 spring原理案例-基本项目 ...
- 学习笔记_J2EE_SSM_01_spring+springMVC+Mybatis整合_XML配置示例
spring+springMVC+Mybatis整合_XML配置示例 1.概述 spring+springMVC+Mybatis整合 XML配置方式 1.1 测试环境说明 名称 版本 备注 操作系统 ...
- SpringMVC、Zookeeper、Dubbo使用
联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架,在这种情况下诞生的.现在核心业务抽取出来,作为独立的服务,使前 ...
- Zookeeper+Dubbo+SpringMVC环境搭建
项目码云GIT地址:https://gitee.com/xshuai/dubbo/ 开发工具 MyEclipse 10.7 JDK 1.7 容器 Tomcat 8(运行dubbo) zookeeper ...
- Zookeeper + Dubbo + SpringMVC + dubbo-admin
第一步:在CentOS/Windows上安装Zookeeper[前提] A:CentOS Zookeeper作为Dubbo服务的注册中心,Dubbo原先基于数据库的注册中心,没采用Zookee ...
- 【推荐】微服务分布式企业框架Springmvc+mybatis+shiro+Dubbo+ZooKeeper+Redis
摘要: 主要定位于互联网企业架构,已内置企业信息化系统的基础功能和高效的代码生成工具,包括:系统权限组件.数据权限组件.数据字典组件.核心工具 组件.视图操作组件.工作流组件.代码 ...
随机推荐
- js jquery 获取元素(父节点,子节点,兄弟节点),元素筛选
转载:https://www.cnblogs.com/ooo0/p/6278102.html js jquery 获取元素(父节点,子节点,兄弟节点) 一,js 获取元素(父节点,子节点,兄弟节点) ...
- SpringBoot(六):springboot热部署
在j2ee项目开发中,热部署插件是JRebel.JRebel的使用为开发人员带来了极大的帮助,且挺高了开发便捷.而在SpringBoot开发生态环境中,SpringBoot热部署常用插件是:sprin ...
- .NET反编译工具:de4dot
de4dot是一款C#编写的基于GPLv3协议的一个开源的.net反混淆脱壳工具,是目前.net下非常不错的一款反编译工具. 支持如下混淆器: Agile.NET (aka CliSecure) Ba ...
- FreeMarker的用法
freemark就是一个对静态页面上的标签进行动态解析.填充数据的一个框架. 语法(转:http://zhuyuehua.iteye.com/blog/1975251): 1. freemarker ...
- hdu1060 Leftmost Digit---求N的N次方的首位(对数)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1060 题目描述:求N的N次方的第一位. 思路: 第一次做这种类型的题目,学到了如何运用对数. 首先推 ...
- url,href,src之间的区别
发现自己居然没把url.href.src关系及使用搞清楚,今天就理一下.主要包括:url.src.href定义以及使用区别. URL(Uniform Resource Locator) 统一资源定位符 ...
- Oracle数据库(3-7)
显式游标使用主要有四个步骤: 声明/定义游标打开游标读取数据关闭游标 CASE 条件表达式 WHEN 条件表达式结果1 THEN 语句1 WHEN 条件表达式结果2 THEN 语句2 ...... W ...
- Convert.ToInt32、(int)和int.Parse三者的区别
前者适合将object类类型转换成int类型 (int)适合简单数据类型之间的转换: int.Parse适合将string类类型转换成int类型.
- 从零开始系列之vue全家桶(3)安装使用vuex
什么是vuex? vuex:Vue提供的状态管理工具,用于同一管理我们项目中各种数据的交互和重用,存储我们需要用到数据对象. 即data中属性同时有一个或几个组件同时使用,就是data中共用的属性. ...
- PyCharm 2018 永久激活
PyCharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具,比如调试.语法高亮.Project管理.代码跳转.智能提示.自动完成.单元测试.版本控制. ...