@
目录
- 背景
- 一、项目框架
- 1.1 采用IDEA和Maven多模块进行项目搭建
- 1.2 模块管理及版本管理
- 二、微服务公共接口
- 2.1 定义一个公共接口Api
- 2.2 pom.xml
- 2.3 GoodsService接口类
- 三、微服务提供者
- 3.1 商品信息微服务
- 3.2 pom.xml
- 3.3 application.yml项目配置文件
- 3.4 GoodsServiceImpl商品信息微服务实现类
- 四、微服务调用者
- 4.1 对外提供Restful接口
- 4.2 pom.xml
- 4.3 application.yml项目配置文件
- 4.4 UserConsumer Restful api接口
- 五、启动微服务
- 六、使用JMeter测试微服务
- 6.1 创建微服务测试项目
- 6.2 流量控制
- 小结
背景
- 在上篇文章《Spring Cloud Alibaba微服务生态的基础实践》中,我们初步了解了
Spring Cloud Alibaba
微服务生态体系,并动手实践了Nacos
与Sentinel
的基本应用。 - 本文将继续对Spring Cloud Alibaba生态进行探索:研究以
Dubbo
框架作为RPC组件,Nacos
作为服务注册与发现中心,并集成Sentinel
进行流量控制,搭建微服务的整个过程。
一、项目框架
1.1 采用IDEA和Maven多模块进行项目搭建
1.2 模块管理及版本管理
-父目录pom.xml:
4.0.0
dubbo-api
dubbo-provider
dubbo-consumer
nacos
dubbo
pom
0.0.1-SNAPSHOT
Dubbo对接Spring Cloud Alibaba项目
1.8
2.2.9.RELEASE
Hoxton.SR1
2.2.0.RELEASE
2.7.6
1.8
1.8
org.springframework.cloud
spring-cloud-dependencies
${spring.cloud.version}
pom
import
com.alibaba.cloud
spring-cloud-alibaba
${spring.cloud.alibaba.version}
pom
import
com.alibaba.cloud
spring-cloud-alibaba-dependencies
${spring.cloud.alibaba.version}
pom
import
org.springframework.boot
spring-boot-starter
${spring.boot.version}
org.apache.dubbo
dubbo-spring-boot-starter
${dubbo.version}
pom
import
org.apache.dubbo
dubbo
${dubbo.version}
pom
import
org.springframework.boot
spring-boot-maven-plugin
${spring.boot.version}
repackage
二、微服务公共接口
2.1 定义一个公共接口Api
2.2 pom.xml
dubbo
nacos
0.0.1-SNAPSHOT
4.0.0
dubbo-api
2.3 GoodsService接口类
/**
* 商品信息服务接口-模拟返回商品列表
*/
public interface GoodsService {
// 获取所有商品信息
List getAllGoods();
}
- Goods商品类
/**
* 商品类
*/
public class Goods implements Serializable {
// 商品名称
private String name;
// 商品价格
private Integer number;
public Goods(String name, Integer number) {
this.name = name;
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getNumber() {
return number;
}
public void setNumber(Integer number) {
this.number = number;
}
}
三、微服务提供者
3.1 商品信息微服务
3.2 pom.xml
-
需引入上述定义的微服务公共接口dubbo-api。
dubbo
nacos
0.0.1-SNAPSHOT
4.0.0
dubbo-provider
jar
nacos
dubbo-api
0.0.1-SNAPSHOT
org.springframework.boot
spring-boot-starter
org.apache.dubbo
dubbo-spring-boot-starter
org.apache.dubbo
dubbo
org.apache.dubbo
dubbo-registry-nacos
2.7.6
com.alibaba.nacos
nacos-client
com.alibaba.cloud
spring-cloud-starter-alibaba-sentinel
com.alibaba.csp
sentinel-apache-dubbo-adapter
1.7.1
com.alibaba.csp
sentinel-transport-simple-http
1.7.1
org.springframework.boot
spring-boot-maven-plugin
3.3 application.yml项目配置文件
server:
port: 9001
spring:
application:
name: nacos-duboo-goods-service
# Spring Cloud Alibaba Sentinel DashBoard
cloud:
sentinel:
transport:
port: 8719
dashboard: 172.16.109.118:8080
dubbo:
# 扫描包地址
scan:
base-packages: nacos.dubbo
# 协议
protocol:
name: dubbo
port: -1
# 注册地址
registry:
address: nacos://172.16.109.118:8848/
# 版本号
service:
version: 1.0.0
3.4 GoodsServiceImpl商品信息微服务实现类
/**
* 商品信息服务实现-模拟返回商品列表
*/
// 注意需使用正确的包 org.apache.dubbo.config.annotation.Service
@Service(version = "${service.version}")
public class GoodsServiceImpl implements GoodsService {
private static final Logger logger = LoggerFactory.getLogger(GoodsServiceImpl.class);
@Override
public List getAllGoods() {
List goods = new ArrayList<>();
goods.add(new Goods("电脑", 10));
goods.add(new Goods("手机", 20));
goods.add(new Goods("书籍", 30));
logger.info(RpcContext.getContext().getRemoteHost()+"正在调用服务..");
return goods;
}
}
- ProviderApplication启动类
/**
* 启动类
*/
@SpringBootApplication
public class ProviderApplication {
public static void main(String[] args) {
SpringApplication.run(ProviderApplication.class, args);
}
}
四、微服务调用者
4.1 对外提供Restful接口
4.2 pom.xml
- 需引入上述定义的微服务公共接口dubbo-api
dubbo
nacos
0.0.1-SNAPSHOT
../pom.xml
4.0.0
dubbo-consumer
jar
nacos
dubbo-api
0.0.1-SNAPSHOT
org.springframework.boot
spring-boot-starter
org.springframework.boot
spring-boot-starter-web
org.apache.dubbo
dubbo-spring-boot-starter
org.apache.dubbo
dubbo
org.apache.dubbo
dubbo-registry-nacos
2.7.6
com.alibaba.nacos
nacos-client
org.springframework.boot
spring-boot-maven-plugin
4.3 application.yml项目配置文件
server:
port: 9002
spring:
application:
name: nacos-dubbo-user-consumer
dubbo:
registry:
address: nacos://172.16.109.118:8848/
service:
version: 1.0.0
4.4 UserConsumer Restful api接口
- 用户消费者调用商品信息微服务
/**
* Restful api接口:用户消费者调用商品信息微服务
*/
@RestController
public class UserConsumer {
@Reference(version= "${service.version}")
private GoodsService goodsService;
@GetMapping("/userGoods")
public User getUserGoods() {
User user = new User();
// 通过GoodsService接口调用商品微服务
try {
List goods = goodsService.getAllGoods();
user.setName("jack");
user.setGoods(goods);
} catch (Exception e){
throw new RuntimeException(e.getMessage());
}
return user;
}
}
- 用户类
/**
* 用户类
*/
public class User implements Serializable {
private String name;
private List goods;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public List getGoods() {
return goods;
}
public void setGoods(List goods) {
this.goods = goods;
}
}
- 启动类
/**
* 启动类
*/
@SpringBootApplication
public class UserApplication {
public static void main(String[] args) {
SpringApplication.run(UserApplication.class, args);
}
}
五、启动微服务
- 启动微服务提供者及微服务调用者,通过微服务调用者Restful接口访问,即调用一次微服务,并分别使用
Nacos
控制台与Sentinel
控制台进监测
六、使用JMeter
测试微服务
6.1 创建微服务测试项目
- 创建一个线程组,设置20个并发请求循环执行:
- 创建一个HTTP请求,根据服务调用者的Resuful接口设置请求地址:
- 再创建一个聚合报告及表格,便于观察测试结果:
- 启动
JMeter
,观察Sentinel
控制台
6.2 流量控制
- 通过流控规则配置对
Dubbo
服务进行流量控制
- 将QPS单机上限值设为10,模式设为直接,流控效果设为快速失败。以上信息保存后会在流控规则增加以上设置。
- 再次启动
JMeter
,并通过Sentinel
控制台监测
小结
- pom文件引入
Spring Cloud Alibaba
、Dubbo
、Nacos
及Sentinel
相关依赖会遇到很多坑,请大家参考本工程项目的版本进行测试,或仔细阅读官方文档。 Dubbo
融合Nacos
成为注册中心的操作步骤非常简单,可以完美取代ZooKeeper
。- 在
Spring Cloud Alibaba
中Dubbo
微服务使用Sentinel
实现限流,我们只需要通过Sentinel
控制台中的流控规则等配置即可,Sentinel
会通过这些规则自动保护这些微服务。 - 以上介绍的只是
Sentinel
的一个最简单的场景 —— 限流。Sentinel
还可以处理更复杂的各种情况,比如降级熔断、冷启动、请求匀速等,具体可以参考Sentine
l 文档。