欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

dubbo+zookeeper

时间:2023-05-01
1、zookeeper的使用

进入Zookeeper的bin目录,启动服务命令 ./zkServer.sh start 停止服务命令 ./zkServer.sh stop 查看服务状态: ./zkServer.sh status 客户端连接 ./zkCli.sh

2、Dubbo的demo 

以服务的提供者为例

2.1 web.xml

"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >

Archetype Created Web Application

contextConfigLocation
classpath:applicationContext*.xml


org.springframework.web.context.ContextLoaderListener

2.2 服务接口和实现类

public interface HelloService { public String sayHello(String name);}@Servicepublic class HelloServiceImpl implements HelloService {public String sayHello(String name) {return "hello " + name;}}

2.3 在src/main/resources下创建applicationContext-service.xml 然后运行服务 3. Dubbo无法发布被事务代理的Service问题

们如果在服务提供者类上加入@Transactional事务控制注解后,服务就发布不成功了。原因是事 务控制的底层原理是为服务提供者类创建代理对象,而默认情况下Spring是基于JDK动态代理方式创建 代理对象,而此代理对象的完整类名为com.sun.proxy.$Proxy42(最后两位数字不是固定的),导致 Dubbo在发布服务前进行包匹配时无法完成匹配,进而没有进行服务的发布。

解决方案:不使用jdk代理,使用cglib代理

修改applicationContext-service.xml配置文件,开启事务控制注解支持时指定proxy-target-class 属性,值为true。其作用是使用cglib代理方式为Service类创建代理对象。

修改HelloServiceImpl类,在Service注解中加入interfaceClass属性,值为HelloService.class, 作用是指定服务的接口类型。

@Service(interfaceClass = HelloService.class)@Transactionalpublic class HelloServiceImpl implements HelloService {public String sayHello(String name) {return "hello " + name;}}

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。