Soul网关接入与验证

简介: 本章节基于前两章内容,引入Soul网关,重点讲解Provider与Consumer应用如何接入Soul。通过添加@SoulSpringMvcClient和@SoulDubboClient注解、配置application.yml,完成服务注册。需启动zookeeper、MySQL、soul-admin、soul-bootstrap及对应服务,验证通过本地及网关访问接口是否正常,确保divide和zk插件已启用,实现HTTP与Dubbo服务的路由与调用。

此章节将基于上一章节基础之上,引入Soul网关,至于Soul网关是干什么的,怎么做的,我们会在后续章节讲解,1-3章节侧重于搭建应用。本章节的Soul网关接入,如果你1,2章节都是和我保持一致,那么只需要直接启动Soul网关即可,但是对应的provider,consumer应用是需要额外的代码接入的。开发环境和第二章保持一致。3.1 提供者接入Soul3.1.1 pom

3.1.2 Controller与之前不同的是,这里我们会在Controller增加一个注解,@SoulSpringMvcClient,标注其注册成为一个SoulSpringMvcClient对象。这里有两种方式,一种是全局,一种是下面示例文件的局部,我会在 3.1.3 配置文件具体讲解二者实现上的差异性。其中@SoulSpringMvcClient(path = "/consumer/** "), ** 标识允许访问:consumer路径下全部,如果在当前Controller中,你只想部分暴露,那么更正为:删除Controller上的:SoulSpringMvcClient(path = "/consumer/** ")在对应需要暴露的接口上,加上全路径,如:  @SoulSpringMvcClien(path = "/consumer/getUserById")3.1.3 配置文件说明:http:标注这里协议是Http,同样还有(dubbo等)adminUrl:对应soul-admin启动的应用地址,端口contextPath:对应注册进Soul的路由前缀(即我们后续通过网关访问的限制名,多个应用应不同)appName:对应的应用名称,不配置的话,会默认取 dubbo配置中application 中的名称full:true则表示代理全部,全局允许访问,权限很大;false表示非全局,只访问有注解的地方(推荐)port:当前应用的启动端口,并非soul-admin或网关,需保持一直另外,如果你在 application.yaml(properties) 中配置了context-path,请删除,这个配置对于Soul而言是无感知的,即你的配置文件中不应出现下面的servlet配置:如果你在这里配置的:full是false,那么对应3.1.2章节就无需调整,如果是true,直接3.1.2关于SoulPringMvcClient相关注解即可。3.2 消费者接入Soul消费者相关配置,和提供者是一致的,这里不再赘述,直接贴出相关代码。3.2.1 pom3.2.2 Controller3.2.3 配置文件说明:这里同时暴露出去了dubbo,http两套协议,dubbo对应的就是我们提供在Service层的代码,其变更很小,如下,只是增加了一个注解:@SoulDubboClientdubbo,http提供的contextPath的路由前缀,需要保持不同,同时全局唯一(即不能和其他应用一致)3.3 验证前提:启动了zookeeper,启动了MySQL。3.3.1 启动soul-admin直接启动相关Application即可,登陆控制台查看:localhost:9093,用户名/密码:admin/123456。成功之后,查看插件,注意这里确保二者开启,且配置项和我吻合:其中:dividezk:{"register":"zookeeper://127.0.0.1:2181"}3.3.2 启动soul-boostrap直接启动相关Application即可。3.3.3 启动soul-provider直接启动相关Application即可,出现下面的日志则表示注册成功:3.3.4 启动soul-consumer直接启动相关Application即可,出现下面的日志则表示注册成功:注意:3.3.3,3.3.4启动完成之后,查看soul-admin的网页管理端,应该出现下图:3.3.5 验证此时直接通过自身IP访问消费者,地址:http://localhost:9092/consumer/getUserById?id=1,查看日志:消费者:提供者:通过网关访问消费者,地址:http://localhost:9094/consumer/consumer/getUserById?id=1,查看日志:消费者:提供者:直接通过自身IP访问提供者,地址:http://localhost:9091/provider/hello?id=-1通过网关访问提供者,地址:http://localhost:9094/provider/provider/hello?id=-1Chrome POST验证provider的dubbo接口

JavaScript

运行代码复制代码

1

2

3

4

5

fetch(new Request('http://localhost:9094/provider/provider-youzha/findById',{

method:'POST',

headers: {'Content-Type': 'application/x-www-form-urlencoded'},

body:"id=1"

})).then((resp)=>{console.log(resp)})

注意:通过网关访问,其地址为boostrap对应的:ip+端口访问地址需要加上路由前缀,即配置文件中 soul 模块中的contextPath如果你的项目和soul不部署在同一服务器,请在你的配置文件中追加上该配置(以你实际部署机器IP为准),保证Soul能管理你的服务soul.http.host=168.10.54.1153.4

相关文章
|
Dubbo Java 应用服务中间件
微服务技术系列教程(30) - Dubbo-SpringCloud与Dubbo区别
微服务技术系列教程(30) - Dubbo-SpringCloud与Dubbo区别
475 0
|
Java 数据库 Maven
深入探讨Java中的new LambdaQueryWrapper<>()方法
在Java编程中,Lambda表达式已经成为一种强大的工具,用于处理集合和数据流。然而,Lambda表达式的威力不仅限于这些领域。在本文中,我们将深入探讨Java中的new LambdaQueryWrapper<>()方法,这是一个强大的查询构建工具,用于简化数据库查询操作。
865 2
|
1月前
|
Java 编译器 C++
google protobuf3中文手册
本文介绍 Protocol Buffers proto3 语言的使用规范,涵盖 `.proto` 文件语法、消息与字段定义、枚举、映射、服务接口及代码生成等内容,指导开发者正确设计和更新数据结构,确保跨语言兼容性与二进制安全。
|
1月前
|
数据安全/隐私保护 iOS开发 Docker
MacOS安装DockerDesktop完整指南(从下载到汉化一步到位)
本教程详细讲解在MacOS上安装DockerDesktop并实现汉化的完整步骤,涵盖系统要求、下载安装、配置验证及中文界面设置,适合新手快速上手,助你轻松掌握Mac上的Docker使用。
|
Java 数据库连接 Spring
SpringBoot2 | BeanDefinition 注册核心类 ImportBeanDefinitionRegistrar 源码分析 (十)
SpringBoot2 | BeanDefinition 注册核心类 ImportBeanDefinitionRegistrar 源码分析 (十)
382 0
|
5月前
|
安全 数据可视化 Java
AiPy开发的 Spring 漏洞检测神器,未授权访问无所遁形
针对Spring站点未授权访问问题,现有工具难以检测如Swagger、Actuator等组件漏洞,且缺乏修复建议。全新AI工具基于Aipy开发,具备图形界面,支持一键扫描常见Spring组件,自动识别未授权访问风险,按漏洞类型标注并提供修复方案,扫描结果可视化展示,支持导出报告,大幅提升渗透测试与漏洞定位效率。
|
9月前
|
SQL 人工智能 数据可视化
StarRocks MCP Server 开源发布:为 AI 应用提供强大分析中枢
StarRocks MCP Server 提供通用接口,使大模型如 Claude、OpenAI 等能标准化访问 StarRocks 数据库。开发者无需开发专属插件或复杂接口,模型可直接执行 SQL 查询并探索数据库内容。其基于 MCP(Model Context Protocol)协议,包含工具、资源和提示词三类核心能力,支持实时数据分析、自动化报表生成及复杂查询优化等场景,极大简化数据问答与智能分析应用构建。项目地址:https://github.com/StarRocks/mcp-server-starrocks。
|
11月前
|
消息中间件
使用RabbitMQ如何保证消息不丢失 ?
消息从发送,到消费者接收,会经理多个过程 , 其中的每一步都可能导致消息丢失 针对这些问题,RabbitMQ分别给出了解决方案: ● 消息发送到交换机丢失 : 发布者确认机制publisher-confirm消息发送到交换机失败会向生产者返回ACK , 生产者通过回调接收发送结果 , 如果发送失败, 重新发送, 或者记录日志人工介入 ● 消息从交换机路由到队列丢失 : 发布者回执机制publisher-return消息从交换机路由到队列失败会向生产者返回失败原因 , 生产者通过回调接收回调结果 , 如果发送失败, 重新发送, 或者记录日志人工介入 ● 消息保存到队列中丢失 : MQ持久化(交
|
Dubbo Java 应用服务中间件
springboot + dubbo + zookeeper入门到实战超级详解
springboot + dubbo + zookeeper入门到实战超级详解
528 0
|
缓存 NoSQL Java
Redis Spring配置集群
【7月更文挑战第5天】
1251 10