成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

【Spring大揭秘】系統性能提升!帶你解鎖系統優化大法

數據庫 其他數據庫
在Spring框架中,數據庫查詢是常見的高負載點之一。因此,優化數據庫查詢是提高系統性能的關鍵。

環境:Spring5.3.23

Spring在各大公司基本上都是標配,它提供了豐富的功能和靈活性,但在使用過程中如果不注意性能優化,可能會導致系統運行緩慢或出現其他問題。以下是一些Spring編程中性能優化的實際案例:

使用AOP實現日志記錄優化

在Spring中,可以使用AOP(面向切面編程)來實現日志記錄的優化。在系統中有大量的日志記錄時,如果每個請求都進行日志記錄,會占用大量的系統資源,導致系統性能下降。因此,可以使用AOP技術,根據一定的條件對日志記錄進行篩選和優化。例如,可以定義一個切面(Aspect),在切面中實現日志記錄的功能,并根據一定的條件判斷是否需要進行日志記錄。這樣可以避免每個請求都進行日志記錄,從而提高系統的性能。示例代碼如下:

優化前:

@Service  
public class UserService {  
  private static final Logger logger = LoggerFactory.getLogger(UserService.class) ;
  @Resource  
  private UserRepository userRepository ;  


  public User queryById(long userId) {  
    User user = this.userRepository.findById(userId) ;
    log.info("queryById - User - {}", user) ;
    return user ;  
  }   
}

在優化前的代碼中,我們直接打印用戶信息到日志中。

接下來,我們將使用AOP來實現日志記錄的優化。首先,我們需要定義一個切面(Aspect),在切面中實現日志記錄的功能,并根據一定的條件判斷是否需要進行日志記錄。以下是優化后的代碼示例:

優化后:

@Aspect  
@Component  
public class UserServiceAspect {  
  
  @Pointcut("execution(* query*(long))")
  private void log() {}
  @Before("log()")  
  public void logBefore(JoinPoint joinPoint) {  
    long userId = (int) joinPoint.getArgs()[0] ;  
    // 只有當userId不合規才打印日志 
    if (userId <= 0) {
      log.info("queryById - start - userId: {}", userId) ;  
    }  
  }
  @AfterReturning(pointcut = "execution(public User query*(long))", returning = "user")  
  public void logAfter(JoinPoint joinPoint, User user) {  
    // 只有查詢到用戶了才記錄用戶信息到日志 
    if (user != null) { 
      long userId = (int) joinPoint.getArgs()[0] ;  
      log.info("queryById - end - userId={}, user info={}", userId, user);  
    }  
  } 
}

通過切面,我們就可以根據條件篩選出需要日志記錄的請求,避免了對所有請求都進行日志記錄,從而提高系統的性能。

使用二級緩存

在Spring框架中,可以使用二級緩存來優化數據的訪問性能。二級緩存是指將數據緩存在內存中,以避免頻繁的數據庫訪問操作。在Spring中,可以使用@Cacheable注解將一個方法標記為可緩存的,這樣該方法的返回值就會被緩存在內存中。當同一個方法被調用時,直接從緩存中獲取返回值,而不需要再次訪問數據庫。這樣可以減少數據庫訪問次數,從而提高系統的性能。

優化前:

@Service  
public class UserService {  
  @Resource  
  private UserRepository userRepository ;  


  public User queryById(long userId) {  
    User user = this.userRepository.findById(userId) ;
    return user ;  
  }   
}

優化前每次獲取用戶都會從數據庫中查詢。

接下來,我們將使用二級緩存來實現數據訪問的優化。首先,我們需要定義一個緩存管理器(CacheManager),用于管理緩存。以下是優化后的代碼示例:

優化后:

// 為了方便演示,這里我們自定義一個緩存管理器
@Configuration  
public class CacheConfig {  
  @Bean  
  public CacheManager cacheManager() {  
    return new ConcurrentMapCacheManager("user") ;  
  }  
}

接下來,我們需要在UserService中注入CacheManager,并使用@Cacheable注解將queryById方法標記為可緩存的。以下是優化后的代碼示例:

@Service  
@CacheConfig(cacheManager = "cacheManager") // 注入CacheManager  
public class UserService {  
      
  @Resource  
  private UserRepository userRepository ;
  @Autowired  
  private CacheManager cacheManager;  


  // 標記為可緩存的,并指定緩存值和鍵  
  @Cacheable(value = "user", key = "#userId") 
  public User queryById(long userId) {  
    User user = userRepository.findById(userId) ;  
    return user ; 
  }  
}

這樣,該方法的返回值會被緩存在內存中,當同一個方法的調用時,直接從緩存中獲取返回值,而不需要再次訪問數據庫。這樣可以減少數據庫訪問次數,從而提高系統的性能。

減少數據庫查詢次數

在一個訂單管理系統中,有一個訂單詳細信息(OrderDetail)實體,該實體與訂單表(Order)在數據庫中有1對1的關系。在獲取訂單詳細信息時,不需要每次都查詢Order表。通過使用JPA的fetch屬性,可以將Order表的數據在一次查詢中一并獲取。這樣,每個訂單詳細信息實體只會引發一次數據庫查詢,而不是之前的每次獲取都查詢。

優化前:

@Repository  
public interface OrderRepository extends JpaRepository<Order, Long> {  
  Order findByOrderId(Long orderId);  
}
@Service  
public class OrderService {  


  @Resource
  private OrderRepository orderRepository;  
  public Order getOrderById(Long orderId) {  
    return orderRepository.findByOrderId(orderId);
  }  


}

上面每次獲取訂單都會發送多條SQL進行數據查詢。優化后:

@Repository  
public interface OrderRepository extends JpaRepository<Order, Long> {  


  @Select("SELECT o.*, od.* FROM Order o LEFT JOIN o.orderDetails od WHERE o.id = ?1")  
  Order findWithOrderDetailsByOrderId(Long orderId);  


}

這樣,我們只需一次數據庫查詢就可以獲取到訂單及其所有詳細信息。

使用多線程池

在Spring框架中,可以使用多線程池來優化任務的執行性能。當系統中有大量的異步任務需要執行時,如果每個任務都創建一個新的線程來執行,會導致系統資源浪費和性能下降。因此,可以使用多線程池來管理任務的執行。在Spring中,可以使用ThreadPoolTaskExecutor來實現多線程池的配置和管理。這樣可以避免每個任務都創建新的線程,從而提高系統的性能。

優化前:

@Service  
public class UserService {  
  
  @Resource  
  private UserRepository userRepository ; 


  @Override  
  public List<User> getUsers() {  
    List<User> users = userRepository.findAll();  
    for (User user : users) {  
      // 處理用戶數據  
    }  
    return users ;  
  }


}

優化前處理用戶在一個線程中執行,時間可能會很長影響系統整體性能。接下來,我們將使用多線程池來實現并發處理的優化。可以考慮使用Java中的Executor框架來管理線程池。我們可以創建ThreadPoolExecutor類來定義線程池,并指定線程池的核心線程數、最大線程數和線程存活時間等參數。在處理每個用戶時,我們可以將任務分配給線程池中的一個線程進行處理,這樣可以同時處理多個用戶,提高系統的并發性能。以下是優化后的代碼示例:

優化后:

@Service  
public class UserService {  
  
  @Resource  
  private UserRepository userRepository ;
  
  private ThreadPoolExecutor pool;  
   
  @Override  
  public List<User> getUsers() {  
    int coreThreads = 10; // 核心線程數      
    int maxThreads = 20; // 最大線程數  
    long keepAliveTime = 60L; // 線程存活時間(單位:秒)  
    ThreadPoolExecutor pool = new ThreadPoolExecutor(
        coreThreads, 
        maxThreads,
        keepAliveTime,
        TimeUnit.SECONDS,
        new LinkedBlockingQueue<>()) ;
    List<User> users = userRepository.findAll() ;  
    for (final User user : users) {  
      pool.execute(() -> {  
        // TODO
      });  
    }  
    pool.shutdown(); // 關閉
    return users;  
  }  
}

注意要在最后調用pool的shutdown方法來關閉線程池(非阻塞)。這樣,系統可以同時處理多個用戶,提高并發性能。

優化數據庫查詢

在Spring框架中,數據庫查詢是常見的高負載點之一。因此,優化數據庫查詢是提高系統性能的關鍵。可以從以下幾個方面對數據庫查詢進行優化:

  • 使用索引:為數據庫中的字段添加索引(根據情況最好是聯合索引)可以加速查詢速度。
  • 避免使用SELECT *:避免查詢所有字段,只查詢需要的字段可以提高查詢速度,盡可能的應用覆蓋索引。
  • 分頁查詢:使用分頁查詢可以減少查詢的數據量,從而提高查詢速度。
  • 批量操作:盡可能減少與數據庫的交互次數,可以批量操作來減少查詢次數。
  • 使用連接池:連接池可以管理數據庫連接,避免頻繁的創建和銷毀連接,從而提高性能。

以上是一些Spring編程中性能優化的實際案例。通過對這些案例的分析和學習,可以更好地應用Spring框架,提高系統的性能和可靠性。

責任編輯:武曉燕 來源: Spring全家桶實戰案例源碼
相關推薦

2024-10-14 12:38:59

2024-06-13 08:24:43

SpringGateway線程池

2023-06-12 00:22:50

操作系統應用程序內核鎖

2024-11-08 14:27:52

系統設計數據庫

2023-10-17 14:35:22

人工智能AI

2010-04-09 13:26:44

2010-04-25 23:39:42

2015-07-28 09:19:10

Linux內核

2024-12-11 07:59:02

2016-09-26 13:50:52

Linux系統性能

2011-08-09 17:15:45

注冊表注冊表編輯器

2011-09-19 14:30:47

Vista緩存

2018-12-10 15:13:06

緩存系統性能數據

2009-02-18 20:27:24

組策略提升Windows性能

2009-03-22 19:19:15

多核多核服務器多核歷史

2023-10-26 08:33:16

Redis管道技術

2021-08-10 08:44:13

系統性能優化

2009-09-29 10:39:04

Linuxlinux系統性能檢測

2010-04-23 11:44:34

Aix系統

2024-04-01 08:04:05

JProfilerJVM工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久精品视频 | 欧美精品三区 | 日日碰碰 | 国产在线观看一区 | 91免费视频观看 | 国产9 9在线 | 中文 | 精产嫩模国品一二三区 | 91小视频在线 | 精品日本中文字幕 | 在线免费观看视频黄 | 中文字幕一区二区三区在线视频 | 免费一级片 | 成人av一区 | 国产精品国产a级 | 久久久青草 | 一级免费视频 | 91看片| 91看片网| 欧美三级在线 | 九九热免费视频在线观看 | 亚洲一区二区三区在线视频 | 91久久久久久久久 | 成在线人视频免费视频 | 国产香蕉视频在线播放 | 久久久xx| 盗摄精品av一区二区三区 | 一区二区在线 | 综合精品在线 | 欧美午夜精品理论片a级按摩 | 国产日韩精品在线 | 亚洲美乳中文字幕 | 欧美日韩a | 91免费在线看 | 国产传媒毛片精品视频第一次 | 国产7777 | 在线观看亚洲 | 亚洲精品福利在线 | 欧美精品久久久久 | 宅女噜噜66国产精品观看免费 | 成人免费一区二区 | 国产亚洲欧美在线 |