目录
1. ZooKeeper安转(注册中心)
1.1 下载地址
下载地址: zookeeper-3.4.14.tar.gz.(windows、linux都可以用)
1.2 下载之后,进行解压,如图所示:
1.3 进入bin目录下,双击服务端运行。
启动成功:
然后双击客户端(如下连接成功):
1.4 闪退问题
如果双击服务端闪退,解决办法是先将zkServer.cmd用记事本打开,最后一行加一个pause,然后再双击运行,查看报错信息。
然后就去更改配置:(这个文件里面有客户端端口号等配置信息)
1.5 在客户端zkCli.cmd进行一些测试
比如输入 create -e … 、get 、 ls /:
2. dubbo-admin安装
注意: dubbo-admin是一个监控管理后台(可视化界面),查看我们注册了哪些服务,哪些服务被消费了。(也可以不要)
2.1 下载地址
Dubbo-admin下载地址: Dubbo-admin.
2.2 解压完成之后
2.3 打包
在项目目录下对项目进行打包dubbo-admin,命令如下:
mvn clean package -Dmaven.test.skip=true
打包成功:
在dubbo-admin路径下生成jap包:
2.4 执行jap包
执行前要保证ZooKeeper运行了。
2.5 进行可视化访问
用户名、密码默认都是root
端口号是7001,可以去该项目的.properties配置文件中更改.
3. 进行SpringBoot整合
3.1 新建两个SpringBoot项目
这里分别叫provider-server、consumer-server了,分别是服务提供者和服务消费者
3.2 编写provider-server
- 1.在service层写一个卖票的业务:
TicketService接口:
public interface TicketService {
public String getTicket();
}
TicketService实现类:
@Component //实用Dubbo之后,尽量不要使用@Service注解
public class TicketServiceImpl implements TicketService {
@Override
public String getTicket() {
return "卖票卖票";
}
}
- 2.在配置文件中改端口号为8081(为了和消费者区分,消费者8082),并配置如下信息:
server.port=8081 # 这个不重要,为了让两个项目都跑起来
# 服务应用名字
dubbo.application.name=provider-server
# 注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
# 哪些服务要被注册
dubbo.scan.base-packages=com.hui.service
- 3.增加依赖
<!--导入依赖:Dubbo + zookeeper-->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.3</version>
</dependency>
<!--zkclient,用github的-->
<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>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
- 4.运行起来(保证zookeeper是运行着嘞)
启动之后,可以看到dubbo-admin中多了一个连接:
3.3 编写consumer-server
-
1.导入依赖,类似于3.2中第3步。
-
2.在配置文件中改端口号为8082,还有其他配置
server.port=8082
# 消费者取拿服务需要暴漏自己的名字
dubbo.application.name=consumer-server
# 注册中心的地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
- 3.写一个UserService类实现用户买票业务
import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;
@Service
public class UserService {
// 想拿到provider-server提供的票
@Reference // 方式一:引用pom坐标,方式二:也可以定义路径相同的接口名
TicketService ticketService;
public void buyTicket(){
String ticket = ticketService.getTicket();
System.out.println("在注册中心拿到"+ticket);
}
}
- 4.在消费者中编写测试类:
@SpringBootTest
class ConsumerServerApplicationTests {
@Autowired
UserService userService;
@Test
void contextLoads() {
userService.buyTicket();
}
}
- 5.运行成功: