发布时间:2026/7/2 2:32:23
下面设计实现的是:交换机Hlr指令处理任务模块。当然,在后续的业务发展过程中,还可能出现,其他类型指令的任务处理,所以根据“开闭”原则的定义,要抽象出一个接口类:BusinessEvent /** * filename:BusinessEvent.java * * Newland Co. Ltd. All rights reserved. * * Description:业务事件任务接口定义 * author tangjie * version 1.0 * */ package newlandframework.batchtask.model; public interface BusinessEvent { // 执行具体批处理的任务 public int execute(Integer userId); }然后具体的Hlr指令发送任务模块HlrBusinessEvent要实现这个接口类的方法完成用户停复机Hlr指令的派发。代码如下/** * filename:HlrBusinessEvent.java * * Newland Co. Ltd. All rights reserved. * * Description:Hlr指令派发任务接口定义 * author tangjie * version 1.0 * */ package newlandframework.batchtask.model; import org.apache.commons.lang.math.RandomUtils; public class HlrBusinessEvent implements BusinessEvent { // 交换机上的指令执行成功失败标识0表示成功 1表示失败 public final static int TASKSUCC 0; public final static int TASKFAIL 1; private final static int ELAPSETIME 1000; Override public int execute(Integer userId) { // 这里为了举例,随机产生1000以内的随机数 int millis RandomUtils.nextInt(ELAPSETIME); // 简单模拟往交换机发送停机/复机的指令 try { Thread.sleep(millis); String strContent String.format( 线程标识[%s]用户标识:[%d]执行交换机指令工单耗时:[%d]毫秒, Thread .currentThread().getName(), userId, millis); System.out.println(strContent); // 这里为了演示直接简单根据随机数是不是偶数简单模拟交换机指令执行的结果 return (millis % 2 0) ? TASKSUCC : TASKFAIL; } catch (InterruptedException e) { e.printStackTrace(); return TASKFAIL; } } }实际运行情况中我们可能要监控一下指令发送的时长于是再设计一个针对Hlr指令发送任务模块HlrBusinessEvent切面嵌入代理的Hlr指令时长计算代理类HlrBusinessEventAdvisor具体的代码如下/** * filename:HlrBusinessEventAdvisor.java * * Newland Co. Ltd. All rights reserved. * * Description:Hlr指令派发时长计算代理类 * author tangjie * version 1.0 * */ package newlandframework.batchtask.model; import org.aopalliance.intercept.MethodInterceptor; import org.aopalliance.intercept.MethodInvocation; import org.apache.commons.lang.time.StopWatch; public class HlrBusinessEventAdvisor implements MethodInterceptor { public HlrBusinessEventAdvisor() { } Override public Object invoke(MethodInvocation invocation) throws Throwable { // 计算一下指令派发时长 StopWatch sw new StopWatch(); sw.start(); Object obj invocation.proceed(); sw.stop(); System.out.println(执行交换机指令工单耗时: [ sw.getTime() ] 毫秒); return obj; } }剩下的我们由于是要异步并行计算得到执行结果于是我们设计一个批处理Hlr任务执行模块HlrBusinessEventTask它要实现java.util.concurrent.Callable接口的方法call它会返回一个异步任务的执行结果。/** * filename:HlrBusinessEventTask.java * * Newland Co. Ltd. All rights reserved. * * Description:Hlr指令派任务执行类 * author tangjie * version 1.0 * */ package newlandframework.batchtask.model; import java.util.concurrent.Callable; import org.springframework.aop.framework.ProxyFactory; import org.springframework.aop.support.NameMatchMethodPointcutAdvisor; public class HlrBusinessEventTask implements CallableInteger { private NotifyUsers user null; private final static String MAPPERMETHODNAME execute; public HlrBusinessEventTask(NotifyUsers user) { this.user user; } Override public Integer call() throws Exception { synchronized (this) { ProxyFactory weaver new ProxyFactory(new HlrBusinessEvent()); NameMatchMethodPointcutAdvisor advisor new NameMatchMethodPointcutAdvisor(); advisor.setMappedName(MAPPERMETHODNAME); advisor.setAdvice(new HlrBusinessEventAdvisor()); weaver.addAdvisor(advisor); BusinessEvent proxyObject (BusinessEvent) weaver.getProxy(); Integer result new Integer(proxyObject.execute(user.getUserId())); // 返回执行结果 return result; } } }接下来我们要把并行异步加载的查询结果和并行异步处理任务执行的模块给它组合起来使用故重新封装一个通知用户批处理任务管理类模块NotifyUsersBatchTask。它的主要功能是批量并行异步加载查询待停复机的手机用户然后把它放入并行异步处理的线程池中进行异步处理。然后我们打印出本次批处理的任务一共有多少成功数和失败数分别是多少当然本文还给出了另外一种JMX方式的监控。NotifyTaskSuccCounter类主要是统计派发的任务中执行成功的任务的数量而与之相对应的类NotifyTaskFailCounter是用来统计执行失败的任务的数量。具体的代码如下/** * filename:NotifyUsersBatchTask.java * * Newland Co. Ltd. All rights reserved. * * Description:通知用户批处理任务管理类 * author tangjie * version 1.0 * */ package newlandframework.batchtask; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import javax.sql.DataSource; import java.util.ArrayList; import java.util.List; import java.util.concurrent.ExecutorService; import org.apache.commons.collections.Closure; import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.functors.IfClosure; import org.apache.commons.lang.StringUtils; import newlandframework.batchtask.jmx.BatchTaskMonitor; import newlandframework.batchtask.model.NotifyUsers; import newlandframework.batchtask.parallel.BatchQueryLoader; import newlandframework.batchtask.parallel.BatchTaskReactor; public class NotifyUsersBatchTask { public NotifyUsersBatchTask() { } private ArrayListDataSource dataSource; // 基于JMX的任务完成情况监控计数器 private BatchTaskMonitor monitor new BatchTaskMonitor(BatchTaskReactor.BATCHTASK_THREADPOOL_NAME); // 支持同时加载多个数据源 public NotifyUsersBatchTask(ArrayListDataSource dataSource) { this.dataSource dataSource; } // 批处理任务执行成功计数器 class NotifyTaskSuccCounter implements Closure { public static final String NOTIFYTASKSUCCCOUNTER TASKSUCCCOUNTER; private int numberSucc 0; public void execute(Object input) { monitor.increaseBatchTaskCounter(NOTIFYTASKSUCCCOUNTER); numberSucc; } public int getSuccNumber() { return numberSucc; } } // 批处理任务执行失败计数器 class NotifyTaskFailCounter implements Closure { public static final String NOTIFYTASKFAILCOUNTER TASKFAILCOUNTER; private int numberFail 0; public void execute(Object input) { monitor.increaseBatchTaskCounter(NOTIFYTASKFAILCOUNTER); numberFail; } public int getFailNumber() { return numberFail; } } // 并行加载查询多个水平分库的数据集合 public ListNotifyUsers query() throws SQLException { BatchQueryLoader loader new BatchQueryLoader(); String strSQL select home_city, msisdn, user_id from notify_users; for (int i 0; i dataSource.size(); i) { Connection con dataSource.get(i).getConnection(); Statement st con.createStatement(); loader.attachLoadEnv(strSQL, st, con); } ListResultSet list loader.executeQuery(); System.out.println(查询出记录总数为: list.size()); final ListNotifyUsers listNotifyUsers new ArrayListNotifyUsers(); for (int i 0; i list.size(); i) { ResultSet rs list.get(i); while (rs.next()) { NotifyUsers users new NotifyUsers(); users.setHomeCity(rs.getInt(1)); users.setMsisdn(rs.getInt(2)); users.setUserId(rs.getInt(3)); listNotifyUsers.add(users); } } // 释放连接资源 loader.close(); return listNotifyUsers; } // 批处理数据集合,任务分派 public void batchNotify(ListNotifyUsers list, final ExecutorService excutor) { System.out.println(处理记录总数为: list.size()); System.out.println(StringUtils.center(记录明细如下, 40, -)); NotifyTaskSuccCounter cntSucc new NotifyTaskSuccCounter(); NotifyTaskFailCounter cntFail new NotifyTaskFailCounter(); BatchTaskPredicate predicate new BatchTaskPredicate(excutor); Closure batchAction new IfClosure(predicate, cntSucc, cntFail); CollectionUtils.forAllDo(list, batchAction); System.out.println(批处理一共处理: list.size() 记录,处理成功: cntSucc.getSuccNumber() 条记录,处理失败: cntFail.getFailNumber() 条记录); } }

相关新闻

2026/7/2 2:32:23

西安便民社区系统开发哪家靠谱,邻里互助匹配架构教程

西安多数老旧小区、新建社区均存在邻里沟通弱、便民资源闲置、互助需求匹配难的问题,传统社区微信群、线下求助模式信息杂乱、时效性差、无规范记录,无法形成可持续的邻里互助体系。便民社区系统的核心核心模块之一就是邻里互助匹配架构,支持…

2026/7/2 2:32:23

星盘接口开发文档:骰子占卜接口指南

星盘接口开发文档:骰子占卜接口指南 1. 引言 本文档详细介绍了占星系统的骰子占卜接口的使用方法,包括请求参数详解、响应数据结构、错误处理机制以及最佳实践建议。 2. 接口基础信息 接口名称: 骰子占卜 请求方式: POSTContent-Type: application/x-www…

2026/7/2 3:32:23

iOS 27 安全新规下,手机租赁商如何守住资产生命线?

随着 iOS 27 的发布,苹果公司对设备管理的网络安全要求进行了全面升级。对于手机租赁行业而言,这并非一次简单的技术迭代,而是一场关乎资产安全与风控能力的严峻考验。过去,租赁商评估移动设备管理(MDM)服务…

2026/7/2 3:32:23

GTC外汇的规则说明清楚吗?

评价GTC外汇时,真正有参考意义的,往往是基础环节是否讲得明白、安排得顺手。从基础服务角度观察,平台把复杂事项拆解得更容易理解,普通用户自然更容易形成稳定印象。因此,文章如果从场景、说明和服务边界展开&#xff…

2026/7/2 3:32:23

大神级文件传输工具,支持win、安卓、Mac多设备互传

这是一款无损高效的文件互传工具,支持Windows、安卓、Linux设备在同一局域网内实现互联互通,多设备之间的文件传输速率可达每秒十兆。 下面以电脑与安卓手机的互传操作为例演示使用方法,首先要确保所有设备连接同一个局域网。如果想将电脑文件…

2026/7/2 2:32:23

第9章 MCP 协议与 Skills 工具生态《AI Agent 开发平台资深技术专家 AI Agent 应用架构师 CTO 面试题库详解》

第9章 MCP 协议与 Skills 工具生态 “MCP 解决的不是’Agent 能不能调用工具’,而是’换了模型之后,工具还能不能被调用’。这才是标准化的真正价值——它让能力与模型解耦,让生态与厂商脱钩。” “Skills 不是把所有知识塞进 Agent 的脑子,而是在需要时才翻开那本技能手册。渐…

2026/7/2 0:32:22

基于LARA-R6001与PIC18LF46K42的VoLTE通信平台开发指南

1. 4G LTE VoLTE平台开发概述在物联网和移动通信技术快速发展的今天,构建自主可控的4G LTE VoLTE通信平台成为许多开发者的需求。LARA-R6001是一款高性能的4G LTE Cat 1模块,而PIC18LF46K42则是Microchip公司推出的低功耗8位单片机,两者的结合…

2026/7/2 0:32:22

AI 辅助:UI 色彩层级设计:颜色不是越多越有表现力

AI 辅助:UI 色彩层级设计:颜色不是越多越有表现力 一、色彩系统先解决层级,再表达情绪 UI 色彩设计的关键不是使用更多颜色,而是建立清晰层级。颜色承担品牌、状态、反馈和信息分组等职责。如果每个区域都使用高饱和色&#xff0c…

2026/7/2 0:32:22

ASM330LHH与TM4C123GH6PZ运动跟踪系统设计

1. 运动跟踪技术的现状与挑战在当今的智能设备领域,运动跟踪技术正经历着前所未有的变革。从智能手机到可穿戴设备,从工业机器人到虚拟现实系统,精确的运动感知能力已成为这些设备"理解"物理世界的基础。然而,要实现高精…

2026/7/2 1:27:35

3个高效策略:快速掌握Axure中文界面配置

3个高效策略:快速掌握Axure中文界面配置 【免费下载链接】axure-cn Chinese language file for Axure RP. Axure RP 简体中文语言包。支持 Axure 11、10、9。不定期更新。 项目地址: https://gitcode.com/gh_mirrors/ax/axure-cn 还在为Axure RP的英文界面感…