进入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" >
org.springframework.web.context.ContextLoaderListener
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;}}