• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

Java ChannelReceiver类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Java中org.apache.catalina.tribes.ChannelReceiver的典型用法代码示例。如果您正苦于以下问题:Java ChannelReceiver类的具体用法?Java ChannelReceiver怎么用?Java ChannelReceiver使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



ChannelReceiver类属于org.apache.catalina.tribes包,在下文中一共展示了ChannelReceiver类的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。

示例1: ChannelCoordinator

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public ChannelCoordinator(ChannelReceiver receiver,
                          ChannelSender sender,
                          MembershipService service) {
    this();
    this.setClusterReceiver(receiver);
    this.setClusterSender(sender);
    this.setMembershipService(service);
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:9,代码来源:ChannelCoordinator.java


示例2: setClusterReceiver

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public void setClusterReceiver(ChannelReceiver clusterReceiver) {
    if ( clusterReceiver != null ) {
        this.clusterReceiver = clusterReceiver;
        this.clusterReceiver.setMessageListener(this);
    } else {
        if  (this.clusterReceiver!=null ) this.clusterReceiver.setMessageListener(null);
        this.clusterReceiver = null;
    }
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:10,代码来源:ChannelCoordinator.java


示例3: setClusterReceiver

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public void setClusterReceiver(ChannelReceiver clusterReceiver) {
	if (clusterReceiver != null) {
		this.clusterReceiver = clusterReceiver;
		this.clusterReceiver.setMessageListener(this);
	} else {
		if (this.clusterReceiver != null)
			this.clusterReceiver.setMessageListener(null);
		this.clusterReceiver = null;
	}
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:11,代码来源:ChannelCoordinator.java


示例4: getClusterReceiver

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public ChannelReceiver getClusterReceiver() {
    return clusterReceiver;
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:4,代码来源:ChannelCoordinator.java


示例5: getChannelReceiver

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
/**
 * Returns the channel receiver component
 * @return ChannelReceiver
 */
@Override
public ChannelReceiver getChannelReceiver() {
    return coordinator.getClusterReceiver();
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:9,代码来源:GroupChannel.java


示例6: setChannelReceiver

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
/**
 * Sets the channel receiver component
 * @param clusterReceiver ChannelReceiver
 */
@Override
public void setChannelReceiver(ChannelReceiver clusterReceiver) {
    coordinator.setClusterReceiver(clusterReceiver);
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:9,代码来源:GroupChannel.java


示例7: run

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
@Override
public synchronized void run() {
    if ( buffer == null ) {
        int size = getRxBufSize();
        if (key.channel() instanceof DatagramChannel) {
            size = ChannelReceiver.MAX_UDP_SIZE;
        }
        if ( (getOptions() & OPTION_DIRECT_BUFFER) == OPTION_DIRECT_BUFFER) {
            buffer = ByteBuffer.allocateDirect(size);
        } else {
            buffer = ByteBuffer.allocate(size);
        }
    } else {
        buffer.clear();
    }
    if (key == null) {
        return; // just in case
    }
    if ( log.isTraceEnabled() )
        log.trace("Servicing key:"+key);

    try {
        ObjectReader reader = (ObjectReader)key.attachment();
        if ( reader == null ) {
            if ( log.isTraceEnabled() )
                log.trace("No object reader, cancelling:"+key);
            cancelKey(key);
        } else {
            if ( log.isTraceEnabled() )
                log.trace("Draining channel:"+key);

            drainChannel(key, reader);
        }
    } catch (Exception e) {
        //this is common, since the sockets on the other
        //end expire after a certain time.
        if ( e instanceof CancelledKeyException ) {
            //do nothing
        } else if ( e instanceof IOException ) {
            //dont spew out stack traces for IO exceptions unless debug is enabled.
            if (log.isDebugEnabled()) log.debug ("IOException in replication worker, unable to drain channel. Probable cause: Keep alive socket closed["+e.getMessage()+"].", e);
            else log.warn ("IOException in replication worker, unable to drain channel. Probable cause: Keep alive socket closed["+e.getMessage()+"].");
        } else if ( log.isErrorEnabled() ) {
            //this is a real error, log it.
            log.error("Exception caught in TcpReplicationThread.drainChannel.",e);
        }
        cancelKey(key);
    } finally {

    }
    key = null;
    // done, ready for more, return to pool
    getTaskPool().returnWorker (this);
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:55,代码来源:NioReplicationTask.java


示例8: createRandomData

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public static Data createRandomData() {
    return createRandomData(ChannelReceiver.MAX_UDP_SIZE);
}
 
开发者ID:liaokailin,项目名称:tomcat7,代码行数:4,代码来源:TestMulticastPackages.java


示例9: ChannelCoordinator

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public ChannelCoordinator(ChannelReceiver receiver, ChannelSender sender, MembershipService service) {
	this();
	this.setClusterReceiver(receiver);
	this.setClusterSender(sender);
	this.setMembershipService(service);
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:7,代码来源:ChannelCoordinator.java


示例10: getClusterReceiver

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
public ChannelReceiver getClusterReceiver() {
	return clusterReceiver;
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:4,代码来源:ChannelCoordinator.java


示例11: run

import org.apache.catalina.tribes.ChannelReceiver; //导入依赖的package包/类
@Override
public synchronized void run() {
	if (buffer == null) {
		int size = getRxBufSize();
		if (key.channel() instanceof DatagramChannel) {
			size = ChannelReceiver.MAX_UDP_SIZE;
		}
		if ((getOptions() & OPTION_DIRECT_BUFFER) == OPTION_DIRECT_BUFFER) {
			buffer = ByteBuffer.allocateDirect(size);
		} else {
			buffer = ByteBuffer.allocate(size);
		}
	} else {
		buffer.clear();
	}
	if (key == null) {
		return; // just in case
	}
	if (log.isTraceEnabled())
		log.trace("Servicing key:" + key);

	try {
		ObjectReader reader = (ObjectReader) key.attachment();
		if (reader == null) {
			if (log.isTraceEnabled())
				log.trace("No object reader, cancelling:" + key);
			cancelKey(key);
		} else {
			if (log.isTraceEnabled())
				log.trace("Draining channel:" + key);

			drainChannel(key, reader);
		}
	} catch (Exception e) {
		// this is common, since the sockets on the other
		// end expire after a certain time.
		if (e instanceof CancelledKeyException) {
			// do nothing
		} else if (e instanceof IOException) {
			// dont spew out stack traces for IO exceptions unless debug is
			// enabled.
			if (log.isDebugEnabled())
				log.debug(
						"IOException in replication worker, unable to drain channel. Probable cause: Keep alive socket closed["
								+ e.getMessage() + "].",
						e);
			else
				log.warn(
						"IOException in replication worker, unable to drain channel. Probable cause: Keep alive socket closed["
								+ e.getMessage() + "].");
		} else if (log.isErrorEnabled()) {
			// this is a real error, log it.
			log.error("Exception caught in TcpReplicationThread.drainChannel.", e);
		}
		cancelKey(key);
	} finally {

	}
	key = null;
	// done, ready for more, return to pool
	getTaskPool().returnWorker(this);
}
 
开发者ID:how2j,项目名称:lazycat,代码行数:63,代码来源:NioReplicationTask.java



注:本文中的org.apache.catalina.tribes.ChannelReceiver类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java Configurator类代码示例发布时间:2022-05-22
下一篇:
Java S3AFileSystem类代码示例发布时间:2022-05-22
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap