All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.logicbus.backend.QueuedServantFactory Maven / Gradle / Ivy

There is a newer version: 1.6.17
Show newest version
package com.logicbus.backend;

import java.lang.reflect.Constructor;
import java.util.Iterator;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.locks.ReentrantLock;
import com.anysoft.util.IOTools;
import com.anysoft.util.Properties;
import com.anysoft.util.PropertiesConstants;
import com.anysoft.util.Settings;
import com.logicbus.models.catalog.Path;
import com.logicbus.models.servant.ServiceDescription;

/**
 * 基于QueuedPool的ServantFactory
 * 
 * @author duanyy
 * @since 1.2.4
 * 
 * @version 1.2.6 [20140807 duanyy] 
* - ServantPool和ServantFactory插件化
* * @version 1.2.8.2 [20141014 duanyy]
* - 修正异常处理
* - servant.pool缺省改为QueuedServantPool2
* * @version 1.6.6.9 [20161209 duanyy]
* - 淘汰QueuedServantPool
* * @version 1.6.6.13 [20170112 duanyy]
* - 主容器由hashtable改为ConcurrentHashMap,增强并发性
* * @version 1.6.7.9 [20170201 duanyy]
* - 采用SLF4j日志框架输出日志
* * @version 1.6.12.29 [20190409]
* - 优化底层的错误代码的处理;
*/ public class QueuedServantFactory extends ServantFactory.Abstract { /** * 服务资源池列表 */ private Map m_pools = null; /** * 资源池的Class */ protected Class poolClazz = null; /** * m_pools对象锁 */ protected ReentrantLock lockPools = new ReentrantLock(); public QueuedServantFactory(){ } @SuppressWarnings("unchecked") @Override public void configure(Properties props){ m_pools = new ConcurrentHashMap(); String poolClass = PropertiesConstants.getString(props, "servant.pool","com.logicbus.backend.QueuedServantPool2",false); ClassLoader cl = Settings.getClassLoader(); try { poolClazz = (Class)cl.loadClass(poolClass); }catch (Throwable t){ poolClazz = QueuedServantPool2.class; logger.error("Can not load servant pool class,using default:" + QueuedServantPool2.class.getName(),t); } } /** * 获得服务资源池列表 * @return 服务资源池列表 */ @Override public ServantPool [] getPools(){ return m_pools.values().toArray(new ServantPool[0]); } /** * 获取指定服务的服务资源池 * @param id 服务ID * @return 服务资源池 */ protected ServantPool getServantPool(Path id) { ServantRegistry sm = getServantRegistry(); ServiceDescription sd = sm.get(id); if (sd != null){ try { Constructor constructor = poolClazz.getConstructor(ServiceDescription.class); return constructor.newInstance(sd); }catch (Throwable t){ logger.error("Can not create servant pool instance,using default:",t); return new QueuedServantPool2(sd); } } return null; } /** * 重新装入指定服务的资源池 * @param _id 服务id * @return 服务资源池 */ @Override public ServantPool reloadPool(Path _id){ lockPools.lock(); try { ServantPool temp = m_pools.get(_id.getPath()); if (temp != null){ //重新装入的目的是因为更新了服务描述信息 ServantRegistry sm = getServantRegistry(); ServiceDescription sd = sm.get(_id); temp.reload(sd); } return temp; }finally{ lockPools.unlock(); } } /** * 获取指定服务的的服务资源池 * @param _id 服务Id * @return 服务资源池 * @throws ServantException */ @Override public ServantPool getPool(Path _id){ ServantPool found = m_pools.get(_id.getPath()); if (found == null){ lockPools.lock(); try { found = m_pools.get(_id.getPath()); if (found == null){ found = getServantPool(_id); if (found != null) { m_pools.put(_id.getPath(), found); } } }finally{ lockPools.unlock(); } } return found; } /** * 关闭 */ @Override public void close(){ super.close(); lockPools.lock(); try { Iterator iter = m_pools.values().iterator(); while (iter.hasNext()){ ServantPool sp = iter.next(); IOTools.close(sp); } }finally{ lockPools.unlock(); } } @Override public void changed(Path id, ServiceDescription desc) { lockPools.lock(); try { logger.info("changed" + id); ServantPool temp = m_pools.get(id); if (temp != null){ //重新装入的目的是因为更新了服务描述信息 logger.info("Service has been changed,reload it:" + id); temp.reload(desc); } }finally{ lockPools.unlock(); } } @Override public void removed(Path id){ lockPools.lock(); try { logger.info("removed:" + id); ServantPool temp = m_pools.get(id); if (temp != null){ //服务被删除了 logger.info("Service has been removed,close it:" + id); try { temp.close(); }catch (Throwable t){ } m_pools.remove(id); } }finally{ lockPools.unlock(); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy