Spring Boot3.3 架構巔峰對決:整潔架構 vs 垂直切片架構(VSA)
前言
隨著軟件系統(tǒng)復雜度的提升,選擇適合的架構風格對于項目的可維護性和可擴展性至關重要。本文將通過代碼示例,詳細對比 整潔架構 和 垂直切片架構(Vertical Slice Architecture, VSA)在 Spring Boot3.3 項目中的應用場景和實現(xiàn)方式。前后端代碼集成使用 Thymeleaf 模板 + jQuery + Bootstrap,展示兩種架構的不同特點及實現(xiàn)方法。
整潔架構
整潔架構(Clean Architecture) 是一種強調分層與職責分離的軟件架構風格,其核心思想是將代碼按照職責劃分為不同的層次,通過明確的依賴規(guī)則,保證代碼的高內聚和低耦合。整潔架構通常包含以下層次:
- 控制器層(Controller Layer):負責處理用戶請求,調用服務層完成業(yè)務邏輯,并返回結果。
- 服務層(Service Layer):包含核心業(yè)務邏輯,負責協(xié)調數(shù)據(jù)訪問和業(yè)務規(guī)則。
- 數(shù)據(jù)訪問層(Repository Layer):負責與數(shù)據(jù)庫或外部數(shù)據(jù)源的交互。
- 實體層(Entity Layer):定義核心數(shù)據(jù)模型,通常為持久化對象。
整潔架構的優(yōu)點:
- 模塊化:每一層有明確的職責,便于理解和維護。
- 可測試性:每一層的邏輯獨立,便于單元測試。
- 可擴展性:新增功能或更換技術棧對其他層影響較小。
適用場景:復雜度較高、需要長期維護的大型系統(tǒng)。
垂直切片架構(Vertical Slice Architecture, VSA)
垂直切片架構 是一種按功能模塊劃分的軟件架構風格。與傳統(tǒng)的分層架構不同,VSA 將一個功能的所有代碼(如控制器、服務、數(shù)據(jù)訪問等)放在同一個模塊中,模塊之間相互獨立,避免了跨模塊依賴。
VSA 的核心思想是以業(yè)務功能為單位,將代碼組織為多個“切片”(Slice),每個切片封裝一個完整的功能:
- 獨立性強:每個切片自成體系,不依賴其他模塊。
- 簡化開發(fā):減少跨模塊依賴,開發(fā)者只需關注單一功能。
- 快速迭代:新增功能僅需添加新的切片,不會影響現(xiàn)有系統(tǒng)。
VSA 的優(yōu)點:
- 靈活性:便于快速開發(fā)新功能或修改現(xiàn)有功能。
- 隔離性:模塊獨立性強,減少變更的影響范圍。
- 適應微服務:垂直切片架構可直接遷移到微服務架構中。
適用場景:業(yè)務功能明確、需要快速迭代的中小型系統(tǒng)或模塊化較強的項目。
整潔架構實現(xiàn)
整潔架構通過層次劃分(控制器、服務層、數(shù)據(jù)訪問層),注重職責分離和模塊化。以下以用戶管理模塊為例展示實現(xiàn)。
項目目錄結構:
src/main/java/com/icoderoad
├── controller
│ └── UserController.java
├── service
│ ├── UserService.java
│ └── UserServiceImpl.java
├── repository
│ └── UserRepository.java
├── entity
│ └── User.java實體類:
package com.icoderoad.entity;
import jakarta.persistence.*;
import lombok.Data;
@Data
@Entity
@Table(name = "users")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(nullable = false, unique = true)
private String username;
@Column(nullable = false)
private String password;
@Column(nullable = false)
private String email;
}數(shù)據(jù)訪問層:
package com.icoderoad.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import com.icoderoad.entity.User;
public interface UserRepository extends JpaRepository<User, Long> {
}服務層接口定義:
package com.icoderoad.service;
import com.icoderoad.entity.User;
import java.util.List;
public interface UserService {
List<User> getAllUsers();
User createUser(User user);
}接口實現(xiàn):
package com.icoderoad.service;
import org.springframework.stereotype.Service;
import com.icoderoad.entity.User;
import com.icoderoad.repository.UserRepository;
import java.util.List;
@Service
public class UserServiceImpl implements UserService {
private final UserRepository userRepository;
public UserServiceImpl(UserRepository userRepository) {
this.userRepository = userRepository;
}
@Override
public List<User> getAllUsers() {
return userRepository.findAll();
}
@Override
public User createUser(User user) {
return userRepository.save(user);
}
}控制器:
package com.icoderoad.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import com.icoderoad.service.UserService;
import com.icoderoad.entity.User;
import java.util.List;
@Controller
public class UserController {
private final UserService userService;
public UserController(UserService userService) {
this.userService = userService;
}
@GetMapping("/users")
public String listUsers(Model model) {
List<User> users = userService.getAllUsers();
model.addAttribute("users", users);
return "user-list";
}
@PostMapping("/users")
public String createUser(User user) {
userService.createUser(user);
return "redirect:/users";
}
}垂直切片架構實現(xiàn)
垂直切片架構將功能模塊作為獨立的切片,模塊內包含該功能的所有邏輯。
項目目錄結構:
src/main/java/com/icoderoad/usermanagement
├── User.java
├── UserController.java
├── UserService.java
├── UserRepository.java實體類:
package com.icoderoad.usermanagement;
import jakarta.persistence.*;
import lombok.Data;
@Data
@Entity
@Table(name = "users")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(nullable = false, unique = true)
private String username;
@Column(nullable = false)
private String password;
@Column(nullable = false)
private String email;
}數(shù)據(jù)訪問層:
package com.icoderoad.usermanagement;
import org.springframework.data.jpa.repository.JpaRepository;
public interface UserRepository extends JpaRepository<User, Long> {
}服務層:
package com.icoderoad.usermanagement;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserService {
private final UserRepository userRepository;
public UserService(UserRepository userRepository) {
this.userRepository = userRepository;
}
public List<User> getAllUsers() {
return userRepository.findAll();
}
public User createUser(User user) {
return userRepository.save(user);
}
}控制器
package com.icoderoad.usermanagement;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import java.util.List;
@Controller
public class UserController {
private final UserService userService;
public UserController(UserService userService) {
this.userService = userService;
}
@GetMapping("/users")
public String listUsers(Model model) {
List<User> users = userService.getAllUsers();
model.addAttribute("users", users);
return "user-list";
}
@PostMapping("/users")
public String createUser(User user) {
userService.createUser(user);
return "redirect:/users";
}
}前端實現(xiàn)
整潔架構與垂直切片架構共用相同的前端實現(xiàn)。
user-list.html
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<title>用戶列表</title>
<link rel="stylesheet">
<script src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
</head>
<body>
<div class="container mt-5">
<h1>用戶列表</h1>
<table class="table table-bordered">
<thead>
<tr>
<th>ID</th>
<th>用戶名</th>
<th>郵箱</th>
</tr>
</thead>
<tbody>
<tr th:each="user : ${users}">
<td th:text="${user.id}"></td>
<td th:text="${user.username}"></td>
<td th:text="${user.email}"></td>
</tr>
</tbody>
</table>
</div>
</body>
</html>總結
整潔架構注重模塊化、職責分離,適合大型企業(yè)級應用;垂直切片架構獨立性強,適合模塊化程度高的系統(tǒng)。根據(jù)需求選擇合適的架構,將為項目帶來更高的可維護性和開發(fā)效率!


































