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

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)。

相关推荐
LiAo_1996_Y2 小时前
如何使用Navicat连接云端MariaDB_白名单与实例配置
jvm·数据库·python
2401_837163892 小时前
mysql如何利用cron定时备份_mysql自动化配置说明
jvm·数据库·python
ch.ju2 小时前
Java程序设计(第3版)第二章——循环结构1
java
大黄烽2 小时前
IDEA中集成AI 工具CodeBuddy和Trae区别和选型
java·人工智能·intellij-idea
JMchen1232 小时前
第 1 篇|Kotlin 基础入门 —— 变量、函数与空安全
开发语言·kotlin·android 入门·kotlin 空安全·android 零基础
t***5442 小时前
如何验证Clang是否在Dev-C++中正常工作
开发语言·c++
HalvmånEver2 小时前
MySQL表的约束(二)
java·数据库·mysql
2301_773553622 小时前
如何在登录界面添加自定义背景图片_Login CSS覆盖修改
jvm·数据库·python
m0_493934532 小时前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python