微服务就是将一个完整的系统,按照不同的业务功能,拆系统分成一个个独立的子系统,在微服务结构中,每个子系统就被称为“服务”。这些子系统能够独立运行在web容器中,它们之间通过RPC方式通信。例如我们开发一个管理系统,按照微服务的思想,我们需要拆分为人事服务、办公事务服务、进销存服务等等。这一个个服务都是一个个独立的项目,可以独立运行。如果服务之间有依赖关系,那么通过RPC方式调用,RPC方式调用,我们可以采用阿里的dubbo框架。
采用RPC的优点:
1、降低系统间的耦合度,可独立开发业务模板,开发时只需启动必要的服务,其他业务服务无需启动。
2、增加代码复用性。
本项目的目录结构:生产者+消费者+公共接口
框架:springboot+dubbo+zk
第一步:创建父子结构的项目
最后的目录:comom为公共接口与实体类,myprovide为服务提供者,mycustomer为服务消费者。
第二步:导入所需的公共jar,这可以在父的pom中引入。
4.0.0
org.springframework.boot
spring-boot-starter-parent
2.1.6.RELEASE
com.janion
demo
0.0.1-SNAPSHOT
demo
Demo project for Spring Boot
1.8
1.16.18
mycustomer
myprovide
comom
org.springframework.boot
spring-boot-starter
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-test
test
mysql
mysql-connector-java
runtime
io.dubbo.springboot
spring-boot-starter-dubbo
1.0.0
com.alibaba
dubbo
com.101tec
zkclient
com.alibaba
dubbo
2.6.0
org.javassist
javassist
com.github.sgroschupf
zkclient
0.1
zookeeper
org.apache.zookeeper
org.apache.zookeeper
zookeeper
3.4.9
slf4j-log4j12
org.slf4j
log4j
log4j
org.springframework.boot
spring-boot-starter-aop
org.springframework.boot
spring-boot-maven-plugin
第三步:配置生产者的依赖。其中dubbo启动未找到bean,需导入javasisit,否则dubbo启动会报错,未找到dubbo的相关bean文件。
4.0.0
com.myprovide
myprovide
0.0.1-SNAPSHOT
myprovide
Demo project for Spring Boot
com.janion
demo
0.0.1-SNAPSHOT
../pom.xml
1.8
com.comom
demo
0.0.1-SNAPSHOT
org.springframework.boot
spring-boot-starter-web
org.javassist
javassist
3.20.0-GA
org.springframework.boot
spring-boot-starter-test
test
org.junit.vintage
junit-vintage-engine
org.springframework.boot
spring-boot-maven-plugin
这里的zk采用的集群的方式,可自行百度集群的搭建方式。
server:
port : 8080
spring:
#发布应用程序配置
application:
name: myprovide
dubbo:
application:
name: myprovide #提供方应用信息
registry:
address: zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183 #使用zookeeper注册中心暴露服务地址
protocol:
name: dubbo
port: -1 #配置暴露服务端口 -1为随机端口
scan: com.myprovide.myprovide.service.impl #扫描需要暴露的服务
生产者的代码块,其中service,需引入dubbo的方法。
好了,到目前为止dubbo生产者已经搭建完成,我们可以启动生成zk和服务检测生成者是否搭建注册成功。
服务开始注册zk
然后我们可以进去zk去查看生产者是否注册成功,可通过cmd进行查看,进入zk的安装目录下的bin文件中,打开zkCli.cmd。
输入:ls /dubbo/com.comom.demo.service.UserService/providers,若显示一下信息,则表示注册成功,可以进行暴露服务给消费者使用了。
第四步:配置消费者
配置pom文件
4.0.0
com.mycustomer
demo
0.0.1-SNAPSHOT
demo
Demo project for Spring Boot
com.janion
demo
0.0.1-SNAPSHOT
../pom.xml
1.8
com.comom
demo
0.0.1-SNAPSHOT
com.alibaba.spring
spring-context-support
1.0.2
org.springframework.boot
spring-boot-starter-web
org.javassist
javassist
3.20.0-GA
org.springframework.boot
spring-boot-starter-test
test
org.junit.vintage
junit-vintage-engine
org.springframework.boot
spring-boot-maven-plugin
配置yml文件
server:
port : 8081
spring:
application:
name: mycustomer
dubbo:
application:
name: mycustomer
registry:
address: zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183 #使用zookeeper注册中心暴露服务地址
scan: com.mycustomer.demo.controller
好了,现在可以开始测试dubbo提供的服务了。
1、调用服务需使用@Reference,对应好服务的版本号。
对于引入服务为空指针有两种解决方式
(1)将check检测需置为false,dubbo默认为true,为true(为无提供者时检测),若为true,则消费者启动是,引入的服务无法注入显示为空指针。
(2)在启动类上,先扫描dubbo的引用,再启动配置类
到目前,代码块已全部编辑完,开始测试消费者调用生产者的功能,启动消费者,若显示一下信息,则注册成功。
同时我们也可以通过命令查看zk:ls /dubbo/com.comom.demo.service.UserService/consumers,若显示以下信息则表示成功。
最后接口测试: