Dubbo目前支持4种注册中心,(multicast、zookeeper、redis、simple) ,推荐使用Zookeeper注册中心。
Zookeeper 是 Apacahe Hadoop 的子项目,是一个树型的目录服务,支持变更推送,适合作为 Dubbo 服务的注册中心,工业强度较高,可用于生产环境,因此被dubbo并推荐使用。
时,记录失败注册和订阅请求,后台定时重试
设置 zookeeper 登录信息
设置 zookeeper 的根节点,不设置将使用无根树*
号通配符
,可订阅服务的所有分组和所有版本的提供者(1)Zookeeper官网:https://zookeeper.apache.org/
(2)下载并解压 “apache-zookeeper-3.5.6-bin.tar.gz”
(3)修改配置文件(~/config/zoo.cfg)
复制“~/config/zoo_sample.cfg”文件副本并改名为“zoo.cfg”,修改其中的“dataDir”(数据文件路径)和“admin.serverPort”(内置的Jetty服务器监听的端口。默认是8080 ),保存。
(4)启动(~/bin/zkServer.cmd)
(1)添加依赖(除了 spring、springmvc、dubbo、接口中间层依赖外,需要额外添加 zookeeper 注册中心依赖)
<properties>
<project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
<maven.compiler.source>1.8maven.compiler.source>
<maven.compiler.target>1.8maven.compiler.target>
properties>
<dependencies>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-contextartifactId>
<version>4.3.9.RELEASEversion>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>4.3.9.RELEASEversion>
dependency>
<dependency>
<groupId>com.alibabagroupId>
<artifactId>dubboartifactId>
<version>2.6.2version>
dependency>
<dependency>
<groupId>samchen.dubbogroupId>
<artifactId>006-zk-interfaceartifactId>
<version>1.0.0version>
dependency>
<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-frameworkartifactId>
<version>4.1.0version>
dependency>
dependencies>
(2)实现业务接口
(3)配置 dubbo 服务提供者(dubbo-zk-userservice-provider.xml)
添加
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://dubbo.apache.org/schema/dubbo http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="007-zk-userservice-provider" />
<dubbo:protocol name="dubbo" port="20880"/>
<dubbo:registry address="zookeeper://localhost:2181" />
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService"/>
<bean id="userService" class="com.bjpowernode.service.UserServiceImpl" />
beans>
(4)配置web服务器(web.xml)
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<context-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:dubbo-zk-provider.xmlparam-value>
context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener
listener-class>
listener>
web-app>
(1)添加依赖
<properties>
<project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
<maven.compiler.source>1.8maven.compiler.source>
<maven.compiler.target>1.8maven.compiler.target>
properties>
<dependencies>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-contextartifactId>
<version>4.3.9.RELEASEversion>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>4.3.9.RELEASEversion>
dependency>
<dependency>
<groupId>com.alibabagroupId>
<artifactId>dubboartifactId>
<version>2.6.2version>
dependency>
<dependency>
<groupId>samchen.dubbogroupId>
<artifactId>006-zk-interfaceartifactId>
<version>1.0.0version>
dependency>
<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-frameworkartifactId>
<version>4.1.0version>
dependency>
(2)配置 dubbo 消费者
添加
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://dubbo.apache.org/schema/dubbo
http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="008-zk-userserivce-consumer"/>
<dubbo:registry address="zookeeper://localhost:2181" />
<dubbo:reference id="userService" interface="com.bjpowernode.service.UserService" />
beans>
(3)配置mvc
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="com.bjpowernode.web"/>
<mvc:annotation-driven/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"/>
<property name="suffix" value=".jsp"/>
bean>
beans>
(4)配置 web 服务器web.xml
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<context-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:dubbo-zk-consumer.xmlparam-value>
context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
listener>
<servlet>
<servlet-name>dispatcherServletservlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
<init-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring-mvc.xmlparam-value>
init-param>
servlet>
<servlet-mapping>
<servlet-name>dispatcherServletservlet-name>
<url-pattern>/url-pattern>
servlet-mapping>
web-app>
(1)优先启动 zookeeper
(2)然后启动服务提供者
(3)最后启动服务消费者
dubbo允许在接口实现更新时保留旧的服务实现,添加新的服务实现,只要通过版本号来标识暴露的服务即可。
(1)新建服务提供者(009-zk-multi-userservice-provider),添加一个新的服务接口实现
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bsbrdUuO-1666011084676)(dubbo.assets/image-20210424222416577.png)]
(2)配置服务提供者(dubbo-zk-multi-userservice-provider.xml)
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://dubbo.apache.org/schema/dubbo
http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="009-zk-userservice-provider" />
<dubbo:protocol name="dubbo" port="20880"/>
<dubbo:registry address="zookeeper://localhost:2181" />
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" version="1.0.0"/>
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService2" version="2.0.0"/>
<bean id="userService" class="com.bjpowernode.service.UserServiceImpl" />
<bean id="userService2" class="com.bjpowernode.service.UserServiceImpl2" />
beans>
(1)配置消费者声明服务引用,指定版本号
<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="010-zk-userserivce-consumer"/>
<dubbo:registry address="zookeeper://localhost:2181"/>
<dubbo:reference id="userService1" interface="com.bjpowernode.service.UserService" version="1.0.0" />
<dubbo:reference id="userService2" interface="com.bjpowernode.service.UserService" version="2.0.0" />
beans>
(2)根据不同的 服务id 调用不同的服务实现
@Controller
public class IndexController {
@Autowired
private UserService userService1;
@Autowired
private UserService userService2;
@RequestMapping("/index")
public String index(Model model){
model.addAttribute("user1",userService1.queryByUserId(1));
model.addAttribute("user2",userService2.queryByUserId(1));
return "index";
}
}
阿里为方便管理人员可视化的维护dubbo服务,提供了一个dubbo管理程序,这是一个基于SpringBoot的工程。
使用者可以下载该项目:
https://github.com/apache/incubator-dubbo-ops
解压后可以根据情况修改信息( application.properties)并将源码编译打包生成jar运行使用。
进入 dubbo-admin 项目(管理控制台)
1) 修改dubbo-admin配置文件中zookeeper的注册地址(配置信息在application.properties文件)
2) 使用mvn clean package 命令进行打包
3)使用java -jar dubbo-admin-0.0.1-SNAPSHOT.jar命令运行
4)访问http://localhost:7001
账号:root 密码:root
Dubbo是一个分布式服务框架,能避免单点故障和支持服务的横向扩容。一个服务通常会部署多个实例。如何从多个服务 Provider 组成的集群中挑选出一个进行调用,就涉及到一个负载均衡的策略。
Dubbo内置了4种负载均衡策略:
(1)将提供者项目,复制一份,更名为“011-zk-multi-userservice-se”,改变端口
第一个提供者配置端口
<dubbo:application name="009-zk-multi-userservice" />
<dubbo:protocol name="dubbo" port="20880"/>
第二个提供者配置端口
<dubbo:application name="011-zk-multi-userservice-se" />
<dubbo:protocol name="dubbo" port="20881"/>
(2)轮询策略
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" version="1.0.0" loadbalance="roundrobin"/>
(3)设置随机的权重策略
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" version="1.0.0" loadbalance="random" weight="100"/>
修改权重----每个服务权重默认为100,越大几率越高
(4)最少活跃策略leastactive
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" loadbalance="leastactive" />
最少活跃调用数表示为服务器节点处理接口的能力,处理接口约耗时则活跃数约小,系统会使慢的节点约少接收到请求。配置方式loadbalance=“leastactive”。(使用最小活跃调用数时,不要配置权重不然失去了该模式意义)当启动两个服务后通过接口中睡眠时间来模拟接口处理能力,通过控制台可以看到睡眠时间越小的节点获取的请求越多。耗时越久的接收的请求越小
(5)一致性Hash模式策略
一致性hash模式表示相同接口相同参数的请求将固定发送到某一个节点。在Service注解中使用**loadbalance=“consistenthash”**进行设置。
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" loadbalance="consistenthash" />
有时候服务停止了,但是dubbo-admin还显示有,即使服务停止了,也会自动从缓存中获取服务提供数据.
Dubbo缺省会在启动时检查依赖的服务是否可用,不可用时抛出异常,阻止Spring初始化完成,以便上线时,能及早发现问题,默认check=true。
如果你的Spring容器是懒加载的,或者通过API编程延迟引用服务,请关闭check,否则服务临时不可用时,会抛出异常,拿到null引用,如果check=false,总是会返回引用,当服务恢复时,能自动连上。
可以通过check="false"关闭检查,比如,测试时,有些服务不关心,或者出现了循环依赖,必须有一方先启动。
<dubbo:reference id="userService" interface="com.bjpowernode.service.UserService" check="false"/>
(1)pom.xml(仅jdk编译版本设定,无需其它依赖)
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.pluginsgroupId>
<artifactId>maven-compiler-pluginartifactId>
<version>3.3version>
<configuration>
<source>1.8source>
<target>1.8target>
configuration>
plugin>
plugins>
build>
(2)实体类
import java.io.Serializable;
//必须是可序列化类才能被dubbo传输
public class User implements Serializable {
private int id;
private String username;
private String password;
public int getId() { return id; }
public void setId(int id) { this.id = id; }
public String getUsername() { return username; }
public void setUsername(String username) { this.username = username; }
public String getPassword() { return password; }
public void setPassword(String password) { this.password = password; }
@Override
public String toString() {
return "User{ id=" + id + ", username='" + username + '\'' +", password='" + password + '\'' +'}';
}
}
(3)业务接口
public interface UserService {
User queryUserById(Integer id);
}
(1)pom.xml(springmvc、dubbo、zookeeper)
<properties>
<project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
<maven.compiler.source>1.8maven.compiler.source>
<maven.compiler.target>1.8maven.compiler.target>
properties>
<dependencies>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-contextartifactId>
<version>4.3.9.RELEASEversion>
dependency>
<dependency>
<groupId>org.springframeworkgroupId>
<artifactId>spring-webmvcartifactId>
<version>4.3.9.RELEASEversion>
dependency>
<dependency>
<groupId>com.alibabagroupId>
<artifactId>dubboartifactId>
<version>2.6.2version>
dependency>
<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-frameworkartifactId>
<version>4.1.0version>
dependency>
dependencies>
(2)业务实现类:
public class UserServiceImipl implements UserService {
@Override
public User queryUserById(Integer id) {
User user = new User();
user.setId(1003);
user.setUsername("wangwu");
user.setPassword("123456");
return user;
}
}
(3)spring dubbo配置(dubbo-userservice-provider.xml)
dubbo直连版本:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://dubbo.apache.org/schema/dubbo
http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" />
<dubbo:protocol name="dubbo" port="20880" />
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" registry="N/A"/>
<bean id="userService" class="com.bjpowernode.service.UserServiceImpl" />
beans>
zookeeper注册中心版本:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://dubbo.apache.org/schema/dubbo
http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="007-zk-userservice-provider" />
<dubbo:protocol name="dubbo" port="20880" />
<dubbo:registry address="zookeeper://localhost:2181" />
<dubbo:service interface="com.bjpowernode.service.UserService" ref="userService" />
<bean id="userService" class="com.bjpowernode.service.UserServiceImipl" />
beans>
(5)spring监听器配置(web.xml)
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<context-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:/dubbo-userservice-provider.xmlparam-value>
context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
listener>
web-app>
(1)pom.xml (略:与服务提供者配置相同)
(2)spring dubbo配置(dubbo-consumer.xml)
dubbo直连版本:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://dubbo.apache.org/schema/dubbo
http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="002-link-consumer" />
<dubbo:reference id="userService"
interface="com.bjpowernode.service.UserService"
url="dubbo://localhost:20880" registry="N/A"/>
beans>
zookeeper注册中心版本:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dubbo="http://dubbo.apache.org/schema/dubbo"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://dubbo.apache.org/schema/dubbo
http://dubbo.apache.org/schema/dubbo/dubbo.xsd">
<dubbo:application name="008-zk-consumer" />
<dubbo:registry address="zookeeper://localhost:2181" />
<dubbo:reference id="userService" interface="com.bjpowernode.service.UserService" />
beans>
(3)spring-mvc.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="com.bjpowernode.web"/>
<mvc:annotation-driven/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"/>
<property name="suffix" value=".jsp"/>
bean>
beans>
(4)springmvc核心控制器(web.xml)
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<servlet>
<servlet-name>springmvcservlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
<init-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring-mvc.xml,classpath:dubbo-consumer.xmlparam-value>
init-param>
servlet>
<servlet-mapping>
<servlet-name>springmvcservlet-name>
<url-pattern>/url-pattern>
servlet-mapping>
web-app>
(5)控制器IndexController(调用服务提供者)
@Controller
public class IndexController {
@Autowired
private UserService userService;
@RequestMapping("/index")
public String index(Model model){
model.addAttribute("user",userService.queryUserById(1));
return "index";
}
}
(6)jsp页面(显示调用服务结果)
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
服务消费者
${user}
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
springmvc
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring-mvc.xml,classpath:dubbo-consumer.xml
springmvc
/
```
(5)控制器IndexController(调用服务提供者)
@Controller
public class IndexController {
@Autowired
private UserService userService;
@RequestMapping("/index")
public String index(Model model){
model.addAttribute("user",userService.queryUserById(1));
return "index";
}
}
(6)jsp页面(显示调用服务结果)
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
服务消费者
${user}