通过单例模式模拟RAC连接 (r4笔记第76天)
单例模式基本是学习设计模式的第一个模式,而且在工作中使用太普遍了,通用到我们感觉就应该是这样,但是如果真给你纸和笔,在5分钟内写出一个完整的单例模式,估计还是有不少人会中招。RAC是实时应用集群,是oracle的一种高可用方案,假设我们有2个节点,如果其中一个节点出现问题,另外一个节点依然能够正常工作,对于客户端来说感觉是完全透明的,感觉不到任何的异常。我们今天来通过设计模式的单例模式来模拟一下RAC连接的情况首先是单例模式,一般都是认为一个类可以产生一个对象,如果对象的数量不收限制,也是可以实现的,这个就是单例模式的扩展。我尝试写了如下的代码,模拟两个节点的情况
点击(此处)折叠或打开
import java.util.ArrayList;public class RacTest {private static final RacTest rac1= new RacTest();private static final RacTest rac2= new RacTest();private final static ArrayList<RacTest> racNodes = new ArrayList<RacTest>();private RacTest(){}public static RacTest getInstance(){int i = (int)(1+Math.random()*2)-1;if(racNodes.size()==0){racNodes.add(rac1);racNodes.add(rac2);}System.out.println("rac instance "+(i+1)+" "+racNodes.get(i));return racNodes.get(i);}public static void main(String[] args){for(int i=0;i<20;i++){RacTest.getInstance();} }}
这样,我们定义了两个节点,在初始化的时候指定getInstance()方法,然后在每次调用的时候都只初始化一次。当然从客户端来说为了能够更加清晰表达出连接节点的随机性,我写了一个循环,一次循环200次,打印出连接的情况,通过数据更能够说明。可以从初始化的两个对象的地址看到只有两个对象。rac instance 1 RacTest@42e816rac instance 1 RacTest@42e816rac instance 1 RacTest@42e816rac instance 2 RacTest@9304b1rac instance 1 RacTest@42e816rac instance 1 RacTest@42e816rac instance 2 RacTest@9304b1rac instance 2 RacTest@9304b1rac instance 1 RacTest@42e816rac instance 2 RacTest@9304b1rac instance 1 RacTest@42e816rac instance 2 RacTest@9304b1rac instance 2 RacTest@9304b1rac instance 1 RacTest@42e816rac instance 2 RacTest@9304b1rac instance 1 RacTest@42e816rac instance 1 RacTest@42e816rac instance 1 RacTest@42e816rac instance 1 RacTest@42e816rac instance 2 RacTest@9304b1