sia-gateway微服务网关实践

2023-11-03 02:21
文章标签 服务 实践 网关 gateway sia

本文主要是介绍sia-gateway微服务网关实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

springcloud + sia-gateway实战

  • 编写目的
  • 环境安装和配置
    • euraka server
    • EKK安装部署
  • sia-gateway部署
    • 核心模块介绍
    • 模块部署
  • 网关配置
    • 路由配置
    • 日志组件配置
  • springcloud工程模板
    • 项目介绍
    • 网关日志组件集成

编写目的

在项目重构过程中,从dubbo切换到spring cloud,soa架构到微服务。使用微服务架构,能够满足越来越复杂的业务发展,但也提高了系统复杂度。需要能够对整个系统进行监控,分析的工具。在重构过程中,将目光放到了网关层,但并没有找到比较满意的产品能提供对应的服务,有没有足够的人力物力和时间去开发一套这样的产品。机缘巧合下,发现了sia-gateway,当时眼前一亮,我所需要的东西,基本上里边都涵盖了,重要的是开源。在此感谢开发sia-gateway的攻城狮,开源项目绝对是人类的福音。
如果此篇博客在解决各位的现实问题的同时,也望大家不吝赐教,留下意见和建议,能够对此项目有一定的推广作用,扩大社区,不断地完善功能,以解决更多用户的问题

环境安装和配置

要部署一套完整的网关系统需要如下的组件:
msyql
redis
euraka server
EKK(elasticsearch + kibana + kafka)
mysql和redis的安装部署这里就不介绍了,网上有太多的资源。

euraka server

使用springboot 构建euraka服务端,在pom文件中加入如下依赖:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-tomcat</artifactId><!--<scope>provided</scope>-->
</dependency>

运行springboot工程,在浏览器中打开http://localhost:8100/,就可以看到euraka server的主页面

EKK安装部署

从网上下载安装包,修改配置文件,执行启动脚本,一般就可以完成安装部署。需要注意几个问题:

  1. 版本问题,kibana、elasticsearch,工程使用的jar包的主版本号必须要一致,否则会导致无法连接的问题,不通主版本间内部协议可能不一致,导致功能无法正常使用,我使用的是5.6.16版本。
  2. 配置文件问题,elasticsearch和kibana绑定的host,要绑定IP地址,不要用localhost或127.0.0.1,否则会导致外部环境无法访问的问题
  3. elasticsearch账户问题,es不能使用root账户启动,需要新建账户,并为账户分配目录权限
    注意上述事项后,基本上能够顺利完成安装。
  4. elasticsearch配置中有网络端口(network.port)和数据端口(transport.tcp.port),网络端口用于前端访问或数据查询,数据端口节点间通信。kibana配置的是网络端口,api包需要配置数据端口。

sia-gateway部署

在完成基础环境的安装部署后,接下来可以进行网关的部署了。首先下载源码:https://github.com/siaorg/sia-gateway.git,在项目md文件,有关于项目的整体接受,如下图所示:
网关模块功能和关系

核心模块介绍

  1. 项目最核心的模块为 sia-gateway-core,core模块集成了zuul网关,路由转发是通过此模块完成
  2. sia-gateway-admin 是前端工程的服务端主键,前端工程的配置,展示等内容,是由此模块提供服务的
  3. sia-gateway-admin-display 为前端组件,需要使用nodejs进行编译
    这3个模块,网关的基本功能已经具备了,可完成网关的配置、转发功能。

模块部署

  • 数据库安装,将sia-gateway-admin模块,resource/db目录下的sql脚本导入到数据库中
  • 后端工程部署,需要部署的模块为:sia-gateway-admin,sia-gateway-synchspeed,sia-gateway-stream,sia-gateway-service,sia-gateway-monitor,sia-gateway-core。修改配置文件,将application.yml文件的配置项,修改为前面安装的基础环境的配置,打包运行
  • 前端工程部署,修改sia-gateway-admin-display模块目录下 config/dev.env.js文件,CESHI_API_HOST项为sia-gateway-admin的地址,CESHI_API_HOST_LOG项是kibana的地址,完成修改后使用nodejs编译运行,npm install 编译, npm run dev运行

部署好后,使用admin登录系统,进入DeskTop页,选择网关组。可看到首页网关统计数据。
在这里插入图片描述

网关配置

路由配置

配置路由转发规则,可根据指导进行路由配置。

  • 网关集群组名为DeskTop页选择的网关组
  • 匹配路径配置路由匹配规则
  • 后端服务ID是注册到euraka的服务名称,后端服务URL是转发到的URL地址,ListofServer是服务名称和URL的组合方式
  • 前缀生效是路由转发前去掉配置规则的头,前缀不生效是转发整个URL

路由配置

日志组件配置

日志管理实际上是使用iframe嵌入了kibana的页面,跟直接打开kibana页面的效果相同。只是在页面打开的时候,去判断了网管组是否在es中创建索引,没有的话,向kibana发送创建网关组索引的命令。
创建索引实际上可在kibana页面上完成,此外在代码逻辑上还有点问题,稍微做了修改。
sia-gateway-admin模块,SettingController类修改如下:
日志组件配置

springcloud工程模板

码云下载地址:https://gitee.com/micheal.com/money-parent.git
dev分支

项目介绍

  • 使用feign进行服务调度
  • hystrix熔断机制
  • 集成sia网关日志组件

├── money-parent
│ ├── money-app 启动组件:包括启动类,配置文件,controller
│ ├── money-core 基础能力组件:包括提供基础功能的类(如util),核心包
│ ├── money-domain 数据持久层
│ ├── money-service-api 服务api
│ ├── money-service-provider 服务提供者,业务模块

注意事项:

  1. server.servlet.context-path= /xxx 配置文件此项需要配置,作为网关转发的规则依据,不然网关无法集成swagger,这也是我放弃使用webflux的原因之一
  2. api接口使用feign配置,所有相比普通接口,此处的接口内容增加了服务发现的地址
@FeignClient(name = ServiceApiName.API_NAME, path = ServiceApiName.API_NAME, fallback = BaseHystrix.class)
public interface BaseService {@RequestMapping(value = "/queryUser", method = RequestMethod.POST)UserResp queryUser(@Valid UserReqeust request);
}
  1. api的接口,在@FeignClient注解path参数,配置统一工程名(及系统context-path)参数,否则feign通过接口找服务的时候,url会少一层目录,无法找到服务

网关日志组件集成

sia-gateway集成了EKK,作为日志组件,也可以集成到我们自己的项目中,提供非常方便的日志收集,查询的功能。

  • pom.xml添加依赖的jar包
 <dependency><groupId>com.sia</groupId><artifactId>sia-gateway-messaging</artifactId><version>1.0</version>
</dependency>
  • 配置logback-spring.xml文件,在logback中加入kafka的日志组件
<appender name="KAFKA" class="com.creditease.gateway.message.appender.SagMqAppender"></appender>
<appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender"><appender-ref ref="KAFKA"/>
</appender><root level="INFO"><appender-ref ref="CONSOLE"/><appender-ref ref="FILE"/><appender-ref ref="ASYNC"/>
</root>
  • 配置文件中加入kafka的配置
########################################################
### KAFKA 基本配置
########################################################
spring.kafka.bootstrap-servers= localhost:9092
# 生产者和消费者topic前缀
spring.kafka.topicPrefix= sag.
spring.kafka.producer.numOfPartition= 1
spring.kafka.producer.retries= 2
# 每次批量发送消息的数量
spring.kafka.producer.batch-size= 16384
spring.kafka.producer.buffer-memory= 33554432
  • 启动类中,加入massage组件的配置路径,和生产者的注解
@SpringBootApplication(scanBasePackages = {"com.cdzg.cloud", "com.creditease.gateway"})
@EnableSagProducer
public class Application {@PostConstructvoid started() {TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));}public static void main(String[] args) {TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));SpringApplication.run(Application.class, args);}
}

如此,就完成了sia消息组件的集成,系统打印到控制台和日志文件的日志记录,会发送给kafka,然后消费者将日志存储到es中。如果要在kibana中方便的查询日志,还需要为该类型的日志创建索引。
创建索引

这篇关于sia-gateway微服务网关实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/334922

相关文章

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶