进程、线程、多线程、异步

1) 进程 vs 线程

  • 进程:资源分配的最小单位(应用实例)。
  • 线程:CPU 调度的最小单位(代码真正跑在这里)。

以你项目里"采购入库点击生成付款单"为例:

  • 至少涉及多个进程:浏览器进程、Java 服务进程、数据库进程。
  • 后端这边是在同一个 Java 服务进程内,由一个请求线程串行执行。
  • @Transactional 保证的是当前请求这段数据库操作的事务一致性,不是"整个系统只有一个进程"。

可理解为:

点一次按钮 = 发起一次 HTTP 请求 = 后端进程从线程池拿一个线程跑完整链路。

2) 后端Java 服务进程

后端流程通常是:

Controller -> Service -> Mapper -> DB

  • 请求进来后,Tomcat 从线程池分配一个工作线程处理。
  • 默认同步调用下,这条链路通常都在同一个线程里跑完。
  • 不需要你手动创建线程,容器已管理好。

3)Spring MVC + MyBatis 和 Tomcat

  • 在 Spring MVC(Servlet 模型)+ MyBatis 的常规同步请求里,
  • 每个 HTTP 请求会由 Servlet 容器(如 Tomcat)线程池 分配一个工作线程处理,
  • 该线程通常串行执行 Controller -> Service -> Mapper -> DB
  • 所以是"单请求单线程(服务端处理阶段)"的默认模型。

补两点小细节(避免理解偏差):

  • "单请求单线程"是指你应用代码的处理链路默认在同一线程;
    JDBC 驱动和数据库内部当然还有它们自己的线程机制。
  • 只有你显式引入异步(如 @Async、线程池、MQ、WebFlux)才会打破这个默认模型。

4) 多线程的作用

  • 异步:不阻塞接口
  • 并行提速:多个远程调用并发执行
  • 批处理拆分:大任务分片并行
  • 后台任务:日志、报表、通知、导出
  • 解耦削峰:配合消息队列,降低主流程压力
  • 提升吞吐:I/O 密集场景下让线程在等待期间不浪费 CPU

5) 异步常见实现(Spring 里)

  • 轻量:@EnableAsync + @Async + 线程池配置
  • 需要结果:CompletableFuture
  • 高可靠/解耦:MQ(RabbitMQ/Kafka/RocketMQ)
  • 注意:尽量不要手写 new Thread(),优先线程池托管

6) Spring MVC 里的 MVC 是什么

  • M(Model):数据和业务对象(实体、DTO、Service层业务数据)
  • V(View):视图展示(模板页/JSP/前端页面)
  • C(Controller):请求入口与调度(@RestController/@Controller

你这个前后端分离项目里,后端大多返回 JSON,V 主要在前端(Vue)。

相关推荐
18922804861几秒前
NV022固态MT29F16T08GWLCEM5-QBES:C
c语言·开发语言
repetitiononeoneday2 分钟前
【面试题】Redis缓存穿透如何解决?
java·redis·缓存
Solis程序员18 分钟前
亿级流量设计之布隆过滤器原理、优缺点及主流替代方案
java
划水的code搬运工小李21 分钟前
下载CSDN到PDF
开发语言·pdf·swift
不负岁月无痕25 分钟前
STL-- C++ stack_queue _priority_queue类 模拟实现
开发语言·c++
半个烧饼不加肉27 分钟前
JS 底层探究--上下文
开发语言·javascript·ecmascript
小满Autumn29 分钟前
依赖注入设计模式速查手册
开发语言·c#·wpf·mvvm·依赖注入
selt79134 分钟前
Redisson 源码深度分析
java·c++·redis·lua
装不满的克莱因瓶37 分钟前
Servlet 到 Spring MVC 架构演进:Java Web 开发二十年技术变迁史
java·spring·servlet·架构·springmvc