1.apache-zookeeper正常启动
2.启动dubbo-admin
3.编写服务提供者Demo
pomjar包坐标
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.8</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.14</version>
<!--排除这个slf4j-log4j12-->
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
开始编写服务类
package com.dubbo.demo.serivce;
public interface TicketSerivce {
public String getBook();
}
package com.dubbo.demo.serivce;
import org.apache.dubbo.config.annotation.DubboService;
import org.springframework.stereotype.Component;
@DubboService
@Component
public class TicketSerivceImpl implements TicketSerivce{
@Override
public String getBook() { return "一本小说"; }
}
编写配置文件
server.port=8081
#当前应用名字
dubbo.application.name=provider-server
#注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
#扫描指定包下服务
dubbo.scan.base-packages=com.dubbo.demo.serivce
启动程序,在dubbo查看是否提供服务
服务是以接口存在,所以在消费者编写需要按照指定服务接口类存在开发
在新建boot项目编写消费者
pomjar坐标
<!--dubbo-->
<!-- Dubbo Spring Boot Starter -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.3</version>
</dependency>
<!--zookeeper-->
<!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
<dependency>
<groupId>com.github.sgroschupf</groupId>
<artifactId>zkclient</artifactId>
<version>0.1</version>
</dependency>
<!-- 引入zookeeper -->
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-framework</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.curator</groupId>
<artifactId>curator-recipes</artifactId>
<version>2.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.14</version>
<!--排除这个slf4j-log4j12-->
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
package com.dubbo.demo.serivce;
public interface TicketSerivce {
public String getBook();
}
package com.consumer.demo.serivce;
import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;
import com.dubbo.demo.serivce.TicketSerivce;
@Service
public class ConsumerSerivce {
@Reference
TicketSerivce tickserivce;
public void buyBooks() {
String book = tickserivce.getBook();
System.out.println("购买了===》"+book);
}
}
请注意TicketSerivce 接口的所在包位置一定要和服务者一样
在application.properties编写配置项
server.port=8082
#当前应用名字
dubbo.application.name=consumer-server
#注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
注意服务端口不能冲突
进行代码测试
@SpringBootTest
class BootConsumerServiceApplicationTests {
@Autowired
ConsumerSerivce coumer;
@Test
void contextLoads() {
coumer.buyBooks();
}
}
测试成功