重新认识策略模式---利用策略实现容错恢复机制

原创 2016年05月30日 15:50:22
一、说明:   
   容错恢复机制是应用程序开发中常见的功能,在程序运行的时候,正常情况下应该按照某种方式来做,按照某种方式来做发生错误的话,系统并不会崩溃。而是由容忍出错的能力,并且还能在出错后有备用方案,也就是恢复机制,使程序正常执行下去。
二、实例:
   下面一个实例:所有对系统的操作都有日志记录,而且这个日志还需要有管理界面,通常情况下,会把日志记录到数据库里面,方便后续的管理,但是在数据库记录日志的时候可能会发生错误,那就先记录到文件里面,在核实的时候把文件里面的记录撞到数据库中。
   采用策略模式实现把日志记录到数据库和纸质记录到文件两种日志记录的策略,然后在运行期间根据需要进行动态切换。
public interface LogStrategy {
    /**
     * 记录日志
     * @param msg 需要记录的日志信息
     * */
    public void log(String msg);
} 
 public class DBLog implements LogStrategy {
    @Override
    public void log(String msg) {
        
        //制造错误
        if(msg != null && msg.trim().length()>5){
            int a=5/0;
        }
        System.out.println("现在把'"+msg+"'记录到数据库中");
    }
}
public class FileLog implements LogStrategy {
    @Override
    public void log(String msg) {
        
        System.out.println("现在把'"+msg+"'记录到文件中");
    }
}
public class LogContext {
    public void log(String msg){
        //在上下文中自行进行具体的策略选择
        //优先选择策略:几率到数据库中
        LogStrategy strategy = new DBLog();
        try{
            strategy.log(msg);
        }catch(Exception e){
            strategy = new FileLog();
            strategy.log(msg);
        }
    }
}
public class Client {
    public static void main(String[] args){
        LogContext log= new LogContext();
        
        log.log("记录日志");
        log.log("再次记录日志");
    }
}

效果图:


三、总结:
    通过策略,实现一种算法之间的动态切换,从而达到容错恢复的目的。策略的实质使分离算法,选择实现。在整个过程中由上下文的策略对象去进行算法选择,通过上下文将接口和具体算法实现解耦合,具有更好的扩展性,但是也存在缺点,用户必须了解每种策略的不同,了解增加了对象的数目,并且策略只适合扁平的算法结构。

   实例代码地址:http://download.csdn.net/detail/wangdan1030/9535410
版权声明:本文为博主原创文章,未经博主允许不得转载。

浅谈Hadoop容错机制

简单介绍一下Hadoop中数据存储的可靠性和完整性,其中包括HDFS的容错机制、NameNode(元数据结点)的单点失效解决机制、Block数据块的多副本存储机制、 NameNode与DataNode...
  • xiaozhuaixifu
  • xiaozhuaixifu
  • 2013年11月22日 14:26
  • 3273

高性能web服务容错机制

一、 重试机制 最容易也最简单被人想到的容错方式,当然就是“失败重试”,总而言之,简单粗暴!简单是指它的实现通常很简单,粗暴则是指使用不当,很可能会带来系统“雪崩”的风险,因为重试意味着对后端服...
  • u013676711
  • u013676711
  • 2016年04月11日 18:11
  • 374

Dubbo——容错机制

容错机制 Dubbo提供了集群部署、路由、负载均衡等容错机制,在客户端引用服务时,由MockClusterInvoker封装具体的集群策略类,默认是FailoverCluster类,具体...
  • meilong_whpu
  • meilong_whpu
  • 2017年05月15日 17:04
  • 1834

【Spark】Spark容错机制

引入一般来说,分布式数据集的容错性有两种方式:数据检查点和记录数据的更新。 面向大规模数据分析,数据检查点操作成本很高,需要通过数据中心的网络连接在机器之间复制庞大的数据集,而网络带宽往往比内存带宽...
  • JasonDing1354
  • JasonDing1354
  • 2015年07月14日 19:48
  • 2392

dubbo工作原理,集群容错,负载均衡

dubbo的构架,调用关系,集群容错,负载均衡
  • hll814
  • hll814
  • 2016年03月15日 00:59
  • 6099

Dubbo-容错机制

容错机制 Dubbo提供了集群部署、路由、负载均衡等容错机制,在客户端引用服务时,由MockClusterInvoker封装具体的集群策略类,默认是FailoverCluster...
  • Tank_666
  • Tank_666
  • 2017年11月23日 09:02
  • 62

MapReduce的容错机制

Failures 在现实世界中,难免遇到用户代码的错误、进程崩溃、机器宕机等情况。使用Hadoop的一个好处是它有能力处理这些失败,使你的job能够成功完成。我们需要考虑以下实体的失败:task、a...
  • qiruiduni
  • qiruiduni
  • 2015年09月08日 11:24
  • 1201

kafka容灾机制

Kafka的消息安全性与容灾机制主要是通过副本replication的设置和leader/follower的的机制实现的。 Replication机制broker 容灾机制 Leade...
  • sgs1018
  • sgs1018
  • 2017年03月09日 19:40
  • 995

Android 异常容错处理

原文地址:http://blog.csdn.net/aqi00/article/details/50855205 Exception Java的异常分两类,运行时异常Runtime...
  • happy_love1990
  • happy_love1990
  • 2017年08月09日 17:53
  • 164

Storm(四):容错机制

Apache Storm分布式集群主要节点由控制节点(Nimbus节点)和工作节点(Supervisor节点),在集群下,怎么保证拓扑的可靠性,storm提供哪些容错机制?...
  • congcong68
  • congcong68
  • 2017年06月11日 10:25
  • 594
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:重新认识策略模式---利用策略实现容错恢复机制
举报原因:
原因补充:

(最多只允许输入30个字)