【memcached】SockIOPool和SchoonerSockIOPool关系

本文解析了Memcached Java客户端中SockIOPool与SchoonerSockIOPool的工作原理及实例化过程。SockIOPool提供对外接口,而SchoonerSockIOPool负责维护缓存连接,确保相同名称的连接池对象唯一。

在memcached的java客户端中,

 

SockIOPool是对外服务的class,

SchoonerSockIOPool是真正保存缓存连接的class

 

对于这个2个对象,虽然构造函数都是protected的,但是使用方式却不同:

 

SockIOPool中:

public static synchronized SockIOPool getInstance(String poolName) {
	SockIOPool whalinSockIOPool = new SockIOPool();
	whalinSockIOPool.schoonerSockIOPool = SchoonerSockIOPool.getInstance(poolName);
	return whalinSockIOPool;
}
 

 

每次都是创建一个新的SockIOPool对象;

 

SchoonerSockIOPool.getInstance呢:

public static SchoonerSockIOPool getInstance(String poolName) {
	SchoonerSockIOPool pool;

	synchronized (pools) {
		if (!pools.containsKey(poolName)) {
			pool = new SchoonerSockIOPool(true);
			pools.putIfAbsent(poolName, pool);
		}
	}

	return pools.get(poolName);
}
 

pools是一个static的成员变量

private static ConcurrentMap<String, SchoonerSockIOPool> pools = new ConcurrentHashMap<String, SchoonerSockIOPool>();
 

 

因此如果poolName相同,无论创建了几个SockIOPool,SchoonerSockIOPool都是相同的;

而且同一个server(ip:port),tcp/udp的属性要是一致的,如果前后2次得到的tcp/udp属性不一致,后一次getInstance失败,得到的是null;

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值