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

使用Spring自定義注解實現任務路由

開發
在Spring mvc的開發中,我們可以通過RequestMapping來配,當前方法用于處理哪一個URL的請求.同樣我們現在有一個需求,有一個任務調度器,可以按照不同的任務類型路由到不同的任務執行器。其本質就是通過外部參數進行一次路由和Spring mvc做的事情類似。簡單看了Spring mvc的實現原理之后,決定使用自定義注解的方式來實現以上功能。

使用Spring自定義注解實現任務路由

在Spring mvc的開發中,我們可以通過RequestMapping來配,當前方法用于處理哪一個URL的請求.同樣我們現在有一個需求,有一個任務調度器,可以按照不同的任務類型路由到不同的任務執行器。其本質就是通過外部參數進行一次路由和Spring mvc做的事情類似。簡單看了Spring mvc的實現原理之后,決定使用自定義注解的方式來實現以上功能。

自定義TaskHandler注解

  1. @Target({ElementType.TYPE}) 
  2. @Retention(RetentionPolicy.RUNTIME) 
  3. @Documented 
  4. @Component 
  5. public @interface TaskHandler { 
  6.  
  7.     String taskType() default ""
  8.  

以上定義了任務處理器的注解,其中@Component表示在spring 啟動過程中,會掃描到并且注入到容器中。taskType表示類型。

任務處理器定義

  1. public abstract class AbstractTaskHandler { 
  2.  
  3.     /** 
  4.      * 任務執行器 
  5.      * 
  6.      * @param task 任務 
  7.      * @return 執行結果 
  8.      */ 
  9.      public abstract BaseResult execute(Task task); 
  10.  

以上定義了一個任務執行的處理器,其他所有的具體的任務執行器繼承實現這個方法。其中Task表示任務的定義,包括任務Id,執行任務需要的參數等。

任務處理器實現

接下來,我們可以實現一個具體的任務處理器。

  1. @TaskHandler(taskType = "UserNameChanged"
  2. public class UserNameChangedSender extends AbstractTaskHandler { 
  3.     @Override 
  4.     public BaseResult execute(Task task) { 
  5.       return new BaseResult(); 
  6.     } 
  7.  

以上我們就實現一個用戶名修改通知的任務處理器,具體的業務邏輯這里沒有實現。

其中:@TaskHandler(taskType = "UserNameChanged"),這里我們指定這個Handler用于處理用戶名變更的任務

任務處理Handler注冊

  1. public class TaskHandlerRegister extends ApplicationObjectSupport { 
  2.  
  3.     private final static Map<String, AbstractTaskHandler> TASK_HANDLERS_MAP = new HashMap<>(); 
  4.  
  5.     private static final Logger LOGGER = LoggerFactory.getLogger(TaskHandlerRegister.class); 
  6.  
  7.     @Override 
  8.     protected void initApplicationContext(ApplicationContext context) throws BeansException { 
  9.         super.initApplicationContext(context); 
  10.         Map<String, Object> taskBeanMap = context.getBeansWithAnnotation(TaskHandler.class); 
  11.         taskBeanMap.keySet().forEach(beanName -> { 
  12.             Object bean = taskBeanMap.get(beanName); 
  13.             Class clazz = bean.getClass(); 
  14.             if (bean instanceof AbstractTaskHandler && clazz.getAnnotation(TaskHandler.class) != null) { 
  15.                 TaskHandler taskHandler = (TaskHandler) clazz.getAnnotation(TaskHandler.class); 
  16.                 String taskType = taskHandler.taskType(); 
  17.                 if (TASK_HANDLERS_MAP.keySet().contains(taskType)) { 
  18.                     throw new RuntimeException("TaskType has Exits. TaskType=" + taskType); 
  19.                 } 
  20.                 TASK_HANDLERS_MAP.put(taskHandler.taskType(), (AbstractTaskHandler) taskBeanMap.get(beanName)); 
  21.                 LOGGER.info("Task Handler Register. taskType={},beanName={}", taskHandler.taskType(), beanName); 
  22.             } 
  23.         }); 
  24.     } 
  25.  
  26.     public static AbstractTaskHandler getTaskHandler(String taskType) { 
  27.         return TASK_HANDLERS_MAP.get(taskType); 
  28.     } 
  29.  

這里繼承了Spring的ApplicationObjectSupport類,具體的注冊過程如下

  1. Spring完成bean的初始化
  2. 查找spring的容器中,所有帶有TaskHandler注解的bean
  3. 校驗bean是否為AbstractTaskHandler類型,獲取到taskType
  4. 把該bean放到TASK_HANDLERS_MAP容器中,即注冊完成

任務執行

接下來我們來看下任務執行

  1. public class TaskExecutor implements Job { 
  2.  
  3.     private static final String TASK_TYPE = "taskType"
  4.  
  5.     @Override 
  6.     public BaseResult execute(Task task){ 
  7.         String taskType=task.getTaskType(); 
  8.         if (TaskHandlerRegister.getTaskHandler(taskType) == null) { 
  9.             throw new RuntimeException("can't find taskHandler,taskType=" + taskType); 
  10.         } 
  11.         AbstractTaskHandler abstractHandler = TaskHandlerRegister.getTaskHandler(taskType); 
  12.         return abstractHandler.execute(task); 
  13.     } 
  14.  

這里發起任務執行的是一個Job,具體過程如下

  1. 校驗該任務類型,有沒有在注冊中心注冊相關Handler
  2. 從任務注冊中心獲取到對應的處理的Handelr
  3. 執行該Handelr

以上過程就完成了,可以實現基于注解的一個任務路由過程。其實現思路來自于Spring mvc的RequestMapping的設計思路. 

責任編輯:龐桂玉 來源: wangyan9110的博客
相關推薦

2024-10-14 17:18:27

2023-10-24 13:48:50

自定義注解舉值驗證

2020-11-25 11:20:44

Spring注解Java

2024-12-27 15:37:23

2015-06-10 10:54:24

自定義路PHP

2021-12-30 12:30:01

Java注解編譯器

2023-10-09 07:37:01

2022-02-17 07:10:39

Nest自定義注解

2024-10-09 10:46:41

springboot緩存redis

2024-07-02 11:42:53

SpringRedis自定義

2009-08-13 09:07:36

Java多線程

2025-03-13 07:33:46

Spring項目開發

2020-09-04 13:30:43

Java自定義代碼

2018-06-21 14:46:03

Spring Boot異步調用

2023-10-11 07:57:23

springboot微服務

2023-10-23 08:18:50

掃描SpringBean

2024-04-03 09:18:03

Redis數據結構接口防刷

2009-09-07 22:00:15

LINQ自定義

2022-05-18 07:44:13

自定義菜單前端

2018-07-17 14:47:55

Windows 10Windows任務欄
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人午夜| 亚洲电影在线播放 | 国产成人精品一区二区三区网站观看 | 久久精品一区二区三区四区 | 正在播放国产精品 | 国产做a爱片久久毛片 | 国产精品一区久久久 | 色呦呦网站 | 在线观看av网站永久 | caoporn免费| 国产偷录视频叫床高潮对白 | 亚州激情 | 亚洲成人av在线播放 | 久久99精品久久久水蜜桃 | 亚洲国产精品va在线看黑人 | 久久久久久久久久久91 | 操人网| 精品福利视频一区二区三区 | 噜啊噜在线 | 国产在线一区二区三区 | 99久久久无码国产精品 | 国产成人在线视频免费观看 | 午夜视频在线免费观看 | 亚洲在线一区二区 | 免费观看一级特黄欧美大片 | 欧美日韩国产一区二区三区 | 羞羞视频在线观看免费观看 | 国产美女网站 | 在线观看国产三级 | 日韩av啪啪网站大全免费观看 | 国产在线一区二区三区 | 丁香六月激情 | 日韩aⅴ在线观看 | 亚洲国产精品视频一区 | 一级片在线播放 | 黄色国产在线视频 | 激情五月婷婷综合 | 久久国产亚洲精品 | a爱视频 | 日韩三级 | 国产国产精品久久久久 |