标签:
Dubbo[]是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
其核心部分包含:
想了解跟多关于Dubbo的信息,请查看:http://alibaba.github.io/dubbo-doc-static/Home-zh.htm
第一步:定义接口
创建接口类和接口方法,和通常的接口定义没有什么区别,如:
public interface TestService { /** * * @param a * @return */ public String test(String a); }
第二步:实现并发布服务
引入接口项目(test-dubbo-service-api)、Crystal框架dubbo服务支持包(crystal-remote-server-dubbo),如:
<dependency> <groupId>com.gsoft.test</groupId> <artifactId>test-dubbo-service-api</artifactId> </dependency> <dependency> <groupId>com.gsoft.crystal</groupId> <artifactId>crystal-remote-server-dubbo</artifactId> </dependency>
实现服务接口,如:
@Service public class TestServiceImpl implements TestService { @Value("${crystal.application.name}") private String name; /* * (non-Javadoc) * * @see com.gsoft.test.dubbo.TestService#test(java.lang.String) */ @Override public String test(String a) { return "Hello, " + a + "! " + " I‘m " + name + " " + System.getenv("LOGONSERVER") + "."; } }
在实现类上添加注解@Service,此处Service为dubbo服务的声明注解com.alibaba.dubbo.config.annotation.Service,到此,基于Dubbo发布的服务已经开发并发布完成。
第一步:项目中引用Dubbo服务接口包和Crystal框架dubbo客户端支持包(crystal-remote-client-dubbo),如
<dependency> <groupId>com.gsoft.test</groupId> <artifactId>test-dubbo-service-api</artifactId> </dependency> <dependency> <groupId>com.gsoft.crystal</groupId> <artifactId>crystal-remote-client-dubbo</artifactId> </dependency>
第二步:在需要使用Dubbo RPC服务的类中,添加服务的引用,并添加@Reference注解:(此处Reference为dubbo服务的声明注解com.alibaba.dubbo.config.annotation.Reference
public class TestCostumer { @Reference private TestService s; private int i = 0; @Value("${crystal.application.name}") private String name; public void hello() { System.out.println(s.test(name + " " + System.getenv("LOGONSERVER") + "-" + ++i)); } }
标签:
原文地址:http://www.cnblogs.com/jytx/p/5481987.html