• 职责链实现的apache.chain使用


        其实职责链在老早就使用过了,以前在HW给Vodafone做金融项目的时候,使用职责链完成交易步骤,那时觉得这东西真好用,可以直接通过配置决定业务流程,现在终于有机会实践一下。

     
        
        这种设计模式本身的实现是非常容易的,可以简单单做是一组IF条件的集合,符合条件的继续传递;不符合条件的终止运行。chain代表了一条运行逻辑,就如同一条项链,我们的业务逻辑就如同是珍珠,并且都实现了同样的compute接口。apache的实现,是通过将数据封装到上下文(context)中,而且该上下文就是串起这些珍珠的金线。
     
        下面是自己写的一段例子:
     
     链的组织,也可以通过配置xml文件来实现,用在spring框架中非常合适。
     
    /**
     * 职责链的组织类,负责构造整个链
     */
    public class RootCauseChain extends ChainBase
    {
    	/**
    	 * 通过此方法增减生效的分析器
    	 */
    	public RootCauseChain()
    	{
    		addCommand(new DataRootCauseAnalyzer());
    		//addCommand(new EnvRootCauseAnalyzer());
    		//addCommand(new PifRootCauseAnalyzer());
    		//addCommand(new TaskRootCauseAnalyzer());
    	}
    }

      具体的业务:  

    /**
     * 实现了command接口,数据均通过context组织
     */
    public class DataRootCauseAnalyzer implements Command
    {
    	private DataQueryService dqService = new DataQueryService();
    
    	private static final String ROOT_CAUSE_FORMAT = "indicator value is abnormal: check ? for more information";
    
    	@SuppressWarnings("unchecked")
    	@Override
    	public boolean execute(Context arg0) throws Exception
    	{
    		boolean res = false;
    
    		Log.info(RootCauseConstant.MODULE_CODE, "0000",
    				"begin to execute DataRootCauseAnalyzer.execute");
    
    		List<DataPoint> exceptionDataPoints = (List<DataPoint>) arg0.get("expData");
    		ExceptionRule exceptionRule = (ExceptionRule) arg0.get("rule");
    
    		List<RootCause> result = new ArrayList<RootCause>();
    
    		if (exceptionDataPoints != null && !exceptionDataPoints.isEmpty())
    		{
    			for (DataPoint dataPoint : exceptionDataPoints)
    			{
    				List<RootCause> rootCauseList = generateRootCause(dataPoint, exceptionRule);
    
    				result.addAll(rootCauseList);
    			}
    		}
    
    		// 如果分析出了根因,则结束分析流程
    		if (result != null && !result.isEmpty())
    		{
    			arg0.put("result", result);
    
    			res = true;
    		}
    
    		// 没有分析出根因,交到下一个分析器进行分析
    		return res;
    	}
    
    	/**
    	 * 生成具体的异常信息
    	 * 
    	 * @param exceptionPoint
    	 *            异常数据点
    	 * @param rule
    	 *            异常规则
    	 * @return 查询上下级关系
    	 */
    	private List<RootCause> generateRootCause(DataPoint exceptionPoint, ExceptionRule rule)
    	{
    		List<RootCause> rclist = new ArrayList<RootCause>();
    
        
    		return rclist;
    	}
    }
    

      调用:

    public class RootCauseService
    {
        /**
         * 分析异常点的根因
         * 
         * @param points
         *            异常数据点
         * @param rule
         *            异常数据发现规则
         * @return 异常数据点及根因
         */
        @SuppressWarnings("unchecked")
        public List<RootCause> getRootCause(List<DataPoint> points, ExceptionRule rule)
        {
            Log.info(RootCauseConstant.MODULE_CODE, "0000", "begin to execute getRootCause, points="
                    + points + ", rule=" + rule);
    
            List<RootCause> result = new ArrayList<RootCause>();
    
            try
            {
                Command command = new RootCauseChain();
                ContextBase ctx = new ContextBase();
    
                ctx.put("expData", points);
                ctx.put("rule", rule);
    
                command.execute(ctx);
                result = (List<RootCause>) ctx.get("result");
            }
            catch (Exception e)
            {
                Log.error(RootCauseConstant.MODULE_CODE, "0000",
                        "execute analysisRootCauseByCommandChain exception.", e);
            }
    
            Log.info(RootCauseConstant.MODULE_CODE, "0000", "execute getRootCause finished, result="
                    + result);
    
            return result;
        }
    }

     

  • 相关阅读:
    T1-TensorFlow基础
    iOS之开发小技巧
    iOS之自定义控件
    plist文件的读取和xib加载cell
    iOS之tabBar随tableView的滑动而隐藏/显现
    iOS之initialize与load
    iOS之九宫格图片
    iOS之ToolBar定制
    iOS之新浪微博的OAuth授权
    Markdown的简单实用
  • 原文地址:https://www.cnblogs.com/jiyuqi/p/4589344.html
Copyright © 2020-2023  润新知