网站首页 > 博客文章 正文
欢迎关注点赞转发留言!
第一讲 开源微服务架构介绍
第二讲 支持国产,开源微服务架构项目之Knife4j使用
第三讲 开源微服务项目集成Knife4j——解密Knife4j
第四讲 开源微服务项目认证中心增加移动端认证
Undertow是一种用Java编写的灵活的高性能开源Web服务器,它提供基于NIO的阻塞和非阻塞API。具有基于合成的体系结构,该体系结构允许您通过组合小型单一用途处理程序来构建Web服务器。使用,您可以灵活地在完整的Java EE Servlet 4.0容器或低级别的非阻塞处理程序之间进行选择。 设计为完全可嵌入的,并具有易于使用的流畅的Builder API。Undertow的生命周期完全由嵌入应用程序控制。在高并发系统中undertow 吞吐量 比tomcat,jetty好。
下面介绍undertown在开源微服务项目Ruoyi-cloud下的应用
1 在项目模块下pom文件引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-undertow</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
2 undertown 配置及原理
2.1 以Ruoyi-cloud 模块下ruoyi-system yam文件做配置
server:
port: 9201
undertow:
io-threads: 16
# 阻塞任务线程池, 当执行类似servlet请求阻塞IO操作, undertow会从这个线程池中取得线程
# 它的值设置取决于系统线程执行任务的阻塞系数,默认值是IO线程数*8
worker-threads: 256
# 以下的配置会影响buffer,这些buffer会用于服务器连接的IO操作,有点类似netty的池化内存管理
# 每块buffer的空间大小,越小的空间被利用越充分,不要设置太大,以免影响其他应用,合适即可
buffer-size: 1024
# 每个区分配的buffer数量 , 所以pool的大小是buffer-size * buffers-per-region
buffers-per-region: 1024
# 是否分配的直接内存(NIO直接分配的堆外内存)
direct-buffers: true
2.2 2.1的配置undertown怎样去获取?启动时候undertown 会去读取yml 文件server 开头的配置参数,并对数据封装,初始化数据。依据这个ServerProperties得知一些原理的
2.3 undertown 怎样处理请求呢?
A 当用户访问系统,undertown接收到请求后建立链接,XNIO调用io.undertow.server.HttpOpenListener,此监听器创建一个新的io.undertow.server.HttpServerConnection以保持与此连接关联的状态,
B 然后调用io.undertow.server.HttpReadListener负责解析传入的请求,并创建一个新 io.undertow.server.HttpServerExchange的存储请求状态,交换对象包含请求和响应状态。
C 通过执行根处理程序io.undertow.server.Connectors#executeRootHandler(Connectors下面的函数executeRootHandler())。处理程序链接在一起,每个处理程序可以修改交换,发送响应或委托给其他处理程序。
D 最后调用ServletInitialHandler 里面函数dispatchRequest(HttpServerExchange exchange, ServletRequestContext servletRequestContext, ServletChain servletChain, DispatcherType dispatcherType)把请求分发到对应处理接口上。
欢迎关注点赞转发留言!
猜你喜欢
- 2024-10-29 jfinal vue ElementUI OA HRM的前后端分离CRM系统源码免费分享
- 2024-10-29 如何项目性能优化?压力测试,数据分析,代码实战
- 2024-10-29 Spring Boot 3 使用 Java 17 和 Jakarta EE 9,并支持GraalVM 的原生 Java
- 2024-10-29 走进Spring Boot源码学习之路和浅谈入门
- 2024-10-29 7 种提升 Spring Boot 吞吐量神技
- 2024-10-29 教你Spring Boot 2.3 优雅关闭的新姿势
- 2024-10-29 拥抱Kubernetes,再见了Spring Cloud
- 2024-10-29 美团动态线程池实践思路,开源了(美团 线程池)
- 2024-10-29 Spring Boot性能优化:提高响应速度的秘密
- 2024-10-29 Java 9 和Spring Boot 2.0纷纷宣布支持的HTTP/2到底是什么?
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)