第一步:在虚拟机中搭建zookeeper。

第二步:本地创建3个maven工程,分别为wxh-dubbo-api(对外暴露的接口),wxh-dubbo-provider(服务提供者,接口的具体实现),wxh-dubbo-consumer(服务的消费方)

//如下工程的类都是在包“com.test.wxh”下创建的

第三步:在wxh-dubbo-api写一个简单的对外暴露的接口

public interface IUserService {
        public void getName(String name) ;
       }

第四步:① 在wxh-dubbo-provider的pom文件的依赖如下

<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
<version>1.16.14</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>io.dubbo.springboot</groupId>
<artifactId>spring-boot-starter-dubbo</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>com.test.wxh</groupId>
<artifactId>wxh-dubbo-api</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>

②,添加一个类实现上述的接口

@Service
@Component
public class UserService implements IUserService {

@Override
public void getName(String name) {
System.out.println("HELLO" + name);
}}

**注意此处的service是com.alibaba.dubbo.config.annotation.Service包的**

③,写一个启动类

@SpringBootApplication(scanBasePackages = { "com.test"})//此处写自己工程的包路径
public class Application {

public static void main(String[] args) {
SpringApplication springApplication = new SpringApplication(Application.class);
springApplication.setWebEnvironment(true);
springApplication.run(args);
System.out.println("启动成功 ");
}}

④,配置一个yml文件

⑤接下来可以运行步骤③的类,这个时候查看zookeeper会发现注册了一个。

如何查看zookeeper上注册了哪些服务

1、进入到zookeeper的bin目录,执行   sh zkCli.sh -server 虚拟机的地址:2181

2、执行ls /dubbo

   会发现列表中有一个自己的工程  com.test.wxh.service.IUserService

3、执行ls /dubbo/com.test.wxh.service.IUserService/providers

4,执行ls /dubbo/com.test.wxh.service.IUserService/consumers(在还没有进行第五步的时候此处是一个空的列表,当启动了consumer工程后此处如下图)

第五步:配置consumer工程的pom

①、

<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
<version>1.16.14</version>
</dependency>
<dependency>
<groupId>com.test.wxh</groupId>
<artifactId>wxh-dubbo-api</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
<version>1.5.2.RELEASE</version>
</dependency>
<dependency>
<groupId>io.dubbo.springboot</groupId>
<artifactId>spring-boot-starter-dubbo</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>

②、yml文件同provider工程

③、写具体的consumer类

@Component
public class ConsumerTest {
@Reference// 注意此处是dubbo的
private IUserService userService;

public void name() {
userService.getName("jane");
}
}

④、写启动类

@SpringBootApplication(scanBasePackages = { "com.test" })
public class Application {
@Autowired
private ConsumerTest consumerTest;

public static void main(String[] args) {
SpringApplication springApplication = new SpringApplication(Application.class);
springApplication.setWebEnvironment(true);
springApplication.run(args);
System.out.println("启动成功-consumer ");
}

@PostConstruct
public void r() {
consumerTest.name();
}

⑤。启动工程之后可以看到provider工程会输出一句话“HELLOjane”;

最新文章

  1. Java继承中的转型及其内存分配
  2. 使用enum建立简单的状态机
  3. poj 2299 Ultra-QuickSort :归并排序求逆序数
  4. Java核心技术II读书笔记(一)
  5. Cocos2d-x 3.0 动作
  6. vc多文档应用程序窗口初始化,关闭子框架,标题,动态切换
  7. python学习--string
  8. Android五大布局重新回顾
  9. Debian8 部署 laravel 5.3 (php7.0 + nginx)
  10. Java学习8——类(对象)之间的关系
  11. 深度学习与NLP简单应用
  12. (haut oj 1261 ) 地狱飞龙 利用不定积分求值
  13. python之路——23
  14. Makefile有三个非常有用的变量。分别是$@,$^,$
  15. CentOS_mini下安装docker 之 yum mount
  16. 3. ELMo算法原理解析
  17. Console下Pause效果的函数
  18. Cheerleaders UVA - 11806(容斥+二进制技巧)
  19. leetcode 两个排序的中位数 python
  20. Git之远程库与本地库交互

热门文章

  1. RocketMQ学习 -&gt; NameServer路由中心
  2. mysql查询数据库中每一张表的内存大小
  3. 使用ImageIO.write上传二维码文件时候,提示系统找不到指定路径
  4. springboot 2.1.3 + mybatis + druid配置多数据源
  5. xampp修改mysql 启动脚本
  6. Shell之StdI/O和Pipe
  7. 我的mongoDb之旅(一)
  8. HTML5 相关扩展
  9. Kafka 学习笔记之 Producer/Consumer (Scala)
  10. 一个基于protobuf的极简RPC