- 1. ZooKeeper安转(注册中心)
- 1.1 下载地址
- 1.2 下载之后,进行解压,如图所示:
- 1.3 进入bin目录下,双击服务端运行。
- 1.4 闪退问题
- 1.5 在客户端zkCli.cmd进行一些测试
- 2. dubbo-admin安装
- 2.1 下载地址
- 2.2 解压完成之后
- 2.3 打包
- 2.4 执行jap包
- 2.5 进行可视化访问
- 3. 进行SpringBoot整合
- 3.1 新建两个SpringBoot项目
- 3.2 编写provider-server
- 3.3 编写consumer-server
下载地址: zookeeper-3.4.14.tar.gz.(windows、linux都可以用)
1.2 下载之后,进行解压,如图所示: 1.3 进入bin目录下,双击服务端运行。启动成功:
然后双击客户端(如下连接成功):
如果双击服务端闪退,解决办法是先将zkServer.cmd用记事本打开,最后一行加一个pause,然后再双击运行,查看报错信息。
然后就去更改配置:(这个文件里面有客户端端口号等配置信息)
比如输入 create -e … 、get 、 ls /:
注意: dubbo-admin是一个监控管理后台(可视化界面),查看我们注册了哪些服务,哪些服务被消费了。(也可以不要)
2.1 下载地址Dubbo-admin下载地址: Dubbo-admin.
2.2 解压完成之后 2.3 打包在项目目录下对项目进行打包dubbo-admin,命令如下:
mvn clean package -Dmaven.test.skip=true
打包成功:
在dubbo-admin路径下生成jap包:
执行前要保证ZooKeeper运行了。
用户名、密码默认都是root
端口号是7001,可以去该项目的.properties配置文件中更改.
这里分别叫provider-server、consumer-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.增加依赖
org.apache.dubbo dubbo-spring-boot-starter2.7.3 com.github.sgroschupf zkclient0.1 org.apache.curator curator-framework2.12.0 org.apache.curator curator-recipes2.12.0 org.apache.zookeeper zookeeper3.4.14 org.slf4j slf4j-log4j12
- 4.运行起来(保证zookeeper是运行着嘞)
启动之后,可以看到dubbo-admin中多了一个连接:
-
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.运行成功:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)