【自研网关系列】请求服务模块和客户端模块实现

🌈Yu-Gateway:基于 Netty 构建的自研 API 网关,采用 Java 原生实现,整合 Nacos 作为注册配置中心。其设计目标是为微服务架构提供高性能、可扩展的统一入口和基础设施,承载请求路由、安全控制、流量治理等核心网关职能。

🌈项目代码地址:https://github.com/YYYUUU42/YuGateway-master

如果该项目对你有帮助,可以在 github 上点个 ⭐ 喔 🥰🥰

🌈自研网关系列:可以点开专栏,参看完整的文档

目录

1、模块说明

2、请求服务模块

3、客户端

4、实现流程

1、模块说明

这个模块式是测试网关HTTP请求服务模块,后续需要开发过滤器链的功能,这个模块主要就是测试功能,毕竟是驴是马,还是需要拿出来溜一下才知道,网关的性能也是需要测试才知道如何的

2、请求服务模块

主要就是 controller 层发送请求,里面核心的是 @ApiService 和 @ApiInvoker 注解,在客户端实现

/**
 * @author yu
 * @date 2024-04-14
 */
@RestController
@ApiService(serviceId = "backend-http-server", protocol = ApiProtocol.HTTP, patternPath = "/http-server/**")
@Slf4j
public class HttpController {

	@Autowired
	private ApiProperties apiProperties;

	@ApiInvoker(path = "/http-server/ping")
	@GetMapping("/http-server/ping")
	public String ping() {
		log.info("{}", apiProperties);
		return "pong";
	}
}

3、客户端

主要类说明

ApiAnnotationScanner 是注解扫描类,扫描 ApiService、ApiInvoker 注解

ApiClientAutoConfiguration:自动装配

AbstractClientRegisterManager:抽象客户端注册管理器,支持多种协议,方便后续扩展

SpringMVCClientRegisterManager:SpringMVC 客户端注册管理器

4、实现流程

这里依旧用 debug 的方式来讲解流程,总体的执行流程如下

1、Spring Boot应用启动,读取 META-INF/spring.factories文件,查找所有的自动配置类。在您的项目中,spring.factories文件指定了ApiClientAutoConfiguration作为自动配置类。

2、Spring Boot创建并初始化 ApiClientAutoConfiguration 类。在ApiClientAutoConfiguration类的初始化过程中,会执行其中的 @Bean 方法,例如 springMVCClientRegisterManager(),并将其返回值注册为Spring容器中的bean。

在applicant.yml 配置文件中写入配置,将配置传入到 springMVCClientRegisterManager() 中

3、SpringMVCClientRegisterManager类的构造方法被执行,它继承了AbstractClientRegisterManager。在AbstractClientRegisterManager的构造方法中,初始化了 ApiProperties 和 RegisterCenter

这里会先父类的构造函数

public SpringMVCClientRegisterManager(ApiProperties apiProperties) {
    super(apiProperties);
}

依旧是用 spi 的方式将配置注册到 Nacos 中

protected AbstractClientRegisterManager(ApiProperties apiProperties) {
    this.apiProperties = apiProperties;
    //初始化注册中心对象
    ServiceLoader<RegisterCenter> serviceLoader = ServiceLoader.load(RegisterCenter.class);
    //获取注册中心实现 如果没有就报错
    registerCenter = serviceLoader.findFirst().orElseThrow(() -> {
        log.error("not found RegisterCenter impl");
        return new RuntimeException("not found RegisterCenter impl");
    });
    //注册中心初始化代码
    registerCenter.init(apiProperties.getRegisterAddress(), apiProperties.getEnv());
}

4、Spring Boot 继续初始化其他的 bean。如果 AbstractClientRegisterManager 有其他的初始化方法,那么这些方法将会被执行。这里没有其他的 bean,所以直接到下一步

5、当Spring Boot应用启动时,SpringMVCClientRegisterManager 的 onApplicationEvent 方法将会被调用,因为它实现了 ApplicationListener<ApplicationEvent> 接口。在 onApplicationEvent 方法中,它会检查传入的事件是否是 ApplicationStartedEvent 。如果是,那么它会调用 doRegisterSpringMvc方法 ,进行服务的注册。

@Override
public void onApplicationEvent(ApplicationEvent applicationEvent) {
    //监听spring启动事件
    if (applicationEvent instanceof ApplicationStartedEvent) {
        try {
            //执行具体的springmvc项目注册
            doRegisterSpringMvc();
        } catch (Exception e) {
            log.error("doRegisterSpringMvc error", e);
            throw new RuntimeException(e);
        }
        log.info("springmvc api started");
    }
}

6、在doRegisterSpringMvc方法中,首先获取所有的RequestMappingHandlerMapping,然后遍历所有的请求处理映射器,获取所有的HandlerMethod。对于每一个HandlerMethod,扫描服务得到服务定义信息,然后创建服务实例,最后调用register方法进行服务的注册。

服务的实例和定义

弄好之后就可以在 Nacos 看到服务了

服务具体信息

  • 15
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
设计服务器的功能和模块需要结合具体业务需求来进行,但一般而言,服务器应该具备以下几个常见的功能和模块: 1. 负载均衡:对于高并发的请求服务器需要进行负载均衡,将请求分发到不同的后服务器上,以提高系统的性能和可用性。 2. 安全认证:服务器需要对请求进行安全认证,防止未授权的请求访问后服务器,保护服务器的安全。 3. 数据转发:将请求转发到后服务器,并将响应返回给客户。在转发时,服务器需要对请求进行解析和处理,以保证请求的正确性和完整性。 4. 缓存管理:对于一些经常访问的数据,可以进行缓存,以提高访问速度和减轻后服务器的压力。 5. 日志和监控:记录服务器的操作日志和监控服务器的运行状态,以便排查问题和优化性能。 6. 动态路由:根据不同的请求,将其路由到不同的后服务器上,以提高系统的灵活性和可扩展性。 7. 限流控制:对于高并发的请求,可以进行限流控制,防止系统崩溃或服务不可用。 8. 络安全:对于络攻击,服务器需要进行相应的安全防护,如防火墙、DDoS攻击防御等。 以上是常见的服务器功能和模块,具体实现需要根据具体业务需求进行。在设计时,需要考虑到系统的可扩展性、可维护性和安全性等因素。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值