本文整理汇总了Java中org.glassfish.grizzly.filterchain.FilterChainBuilder类的典型用法代码示例。如果您正苦于以下问题:Java FilterChainBuilder类的具体用法?Java FilterChainBuilder怎么用?Java FilterChainBuilder使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
FilterChainBuilder类属于org.glassfish.grizzly.filterchain包,在下文中一共展示了FilterChainBuilder类的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: doOpen
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
@Override
protected void doOpen() throws Throwable {
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
filterChainBuilder.add(new TransportFilter());
filterChainBuilder.add(new GrizzlyCodecAdapter(getCodec(), getUrl(), this));
filterChainBuilder.add(new GrizzlyHandler(getUrl(), this));
TCPNIOTransportBuilder builder = TCPNIOTransportBuilder.newInstance();
ThreadPoolConfig config = builder.getWorkerThreadPoolConfig();
config.setPoolName(CLIENT_THREAD_POOL_NAME)
.setQueueLimit(-1)
.setCorePoolSize(0)
.setMaxPoolSize(Integer.MAX_VALUE)
.setKeepAliveTime(60L, TimeUnit.SECONDS);
builder.setTcpNoDelay(true).setKeepAlive(true)
.setConnectionTimeout(getTimeout())
.setIOStrategy(SameThreadIOStrategy.getInstance());
transport = builder.build();
transport.setProcessor(filterChainBuilder.build());
transport.start();
}
示例2: start
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
public void start(int listenPort, ExecutorService threadpool) throws Exception {
ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) threadpool;
ThreadPoolConfig config = ThreadPoolConfig.defaultConfig().copy().setCorePoolSize(threadPoolExecutor.getCorePoolSize())
.setMaxPoolSize(threadPoolExecutor.getMaximumPoolSize()).setPoolName("GRIZZLY-SERVER");
ExecutorService executorService = GrizzlyExecutorService.createInstance(config);
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
filterChainBuilder.add(new TransportFilter());
filterChainBuilder.add(new GrizzlyProtocolFilter());
filterChainBuilder.add(new GrizzlyServerHandler(executorService));
TCPNIOTransportBuilder builder = TCPNIOTransportBuilder.newInstance();
builder.setOptimizedForMultiplexing(true);
builder.setIOStrategy(SameThreadIOStrategy.getInstance());
transport = builder.build();
transport.setProcessor(filterChainBuilder.build());
transport.bind(listenPort);
transport.start();
LOGGER.warn("server started,listen at: " + listenPort);
}
示例3: start
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
public void start() throws IOException {
// Create TCP transport
transport = TCPNIOTransportBuilder.newInstance().build();
// Create a FilterChain using FilterChainBuilder
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
// Add TransportFilter, which is responsible
// for reading and writing data to the connection
filterChainBuilder.add(new TransportFilter());
// filterChainBuilder.add(new ClientEncodeFilter());
filterChainBuilder.add(new TunnelRedirectServerFilter(
TCPNIOConnectorHandler.builder(transport).build(), targetHost,
targetPort));
transport.setProcessor(filterChainBuilder.build());
// transport.setReadBufferSize(512);
// Set async write queue size limit
// transport.getAsyncQueueIO().getWriter()
// .setMaxPendingBytesPerConnection(10240 * 10240);
// binding transport to start listen on certain host and port
transport.bind(localHost, localPort);
// start the transport
transport.start();
logger.info("Press any key to stop the server...");
}
示例4: doOpen
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
@Override
protected void doOpen() throws Throwable {
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
filterChainBuilder.add(new TransportFilter());
filterChainBuilder.add(new GrizzlyCodecAdapter(getCodec(), getUrl(), this));
filterChainBuilder.add(new GrizzlyHandler(getUrl(), this));
TCPNIOTransportBuilder builder = TCPNIOTransportBuilder.newInstance();
ThreadPoolConfig config = builder.getWorkerThreadPoolConfig();
config.setPoolName(CLIENT_THREAD_POOL_NAME)
.setQueueLimit(-1)
.setCorePoolSize(0)
.setMaxPoolSize(Integer.MAX_VALUE)
.setKeepAliveTime(60L, TimeUnit.SECONDS);
builder.setTcpNoDelay(true).setKeepAlive(true)
.setConnectionTimeout(getTimeout())
.setIOStrategy(SameThreadIOStrategy.getInstance());
transport = builder.build();
transport.setProcessor(filterChainBuilder.build());
transport.start();
}
示例5: start
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
public static TCPServer start(int port, BaseFilter requestCodecFilter, BaseFilter serverFilter) {
TCPServer server = new TCPServer( port);
// Create a FilterChain using FilterChainBuilder
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
// Add filters to the chain
filterChainBuilder.add(new TransportFilter())
.add(requestCodecFilter)
.add(serverFilter);
// Create TCP NIO transport
server.transport = TCPNIOTransportBuilder.newInstance()
/*.setReadBufferSize(1024 * 1024 * 16)
.setTcpNoDelay(true)
.setMemoryManager(new ByteBufferManager())*/
.build();
server.transport.setProcessor(filterChainBuilder.build());
try {
// Bind server socket and start transport
server.transport.bind(port);
server.transport.start();
return server;
} catch (Exception ex) {
if ( server.transport != null) {
server.transport.shutdown();
}
throw new RuntimeException( ex.getMessage(), ex);
}
}
示例6: createClient
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
@SuppressWarnings("rawtypes")
protected Client createClient(String targetIP, int targetPort, int connectTimeout, String key) throws Exception {
Connection connection = null;
GrizzlyClientHandler handler = new GrizzlyClientHandler();
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
filterChainBuilder.add(new TransportFilter());
filterChainBuilder.add(new GrizzlyProtocolFilter());
filterChainBuilder.add(handler);
final TCPNIOTransportBuilder transportBuilder = TCPNIOTransportBuilder.newInstance();
transportBuilder.setOptimizedForMultiplexing(true);
transportBuilder.setIOStrategy(SameThreadIOStrategy.getInstance());
final TCPNIOTransport transport = transportBuilder.build();
transport.setTcpNoDelay(Boolean.parseBoolean(System.getProperty("nfs.rpc.tcp.nodelay", "true")));
transport.setProcessor(filterChainBuilder.build());
transport.start();
Future<Connection> future = transport.connect(targetIP, targetPort);
if (connectTimeout < 1000) {
connectTimeout = 1000;
}
connection = future.get(connectTimeout, TimeUnit.MILLISECONDS);
@SuppressWarnings("unchecked")
GrizzlyClient client = new GrizzlyClient(targetIP, targetPort, connectTimeout, connection, key);
handler.setClient(client);
return client;
}
示例7: setup
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
@Override
public void setup(NetworkListener networkListener, FilterChainBuilder builder) {
// Get the index of HttpCodecFilter in the HttpServer filter chain
final int httpCodecFilterIdx = builder.indexOfType(HttpServerFilter.class);
if (httpCodecFilterIdx >= 0) {
// Insert the WebSocketFilter right after HttpCodecFilter
HttpServerFilter originalFilter = (HttpServerFilter) builder.get(httpCodecFilterIdx);
builder.set(httpCodecFilterIdx, new ContentLengthFilter(originalFilter));
}
}
示例8: setup
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
@Override
public void setup(NetworkListener networkListener, FilterChainBuilder builder) {
// Get the index of HttpServerFilter in the HttpServer filter chain
final int httpServerFilterIdx = builder.indexOfType(HttpServerFilter.class);
if (httpServerFilterIdx >= 0) {
// Insert the WebSocketFilter right before HttpServerFilter
builder.add(httpServerFilterIdx, new GrizzlyServerFilter(container, contextPath));
}
}
示例9: start
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
public static TCPClient start(String host, int port, BaseFilter coder, BaseFilter clientFilter) {
TCPClient client = new TCPClient( host, port);
client.clientFilter = clientFilter;
FilterChainBuilder filterChainBuilder = FilterChainBuilder.stateless();
// Add TransportFilter, which is responsible
// for reading and writing data to the connection
filterChainBuilder.add(new TransportFilter());
// StringFilter is responsible for Buffer <-> String conversion
filterChainBuilder.add(coder);
// EchoFilter is responsible for echoing received messages
filterChainBuilder.add(clientFilter);
// Create TCP transport
client.transport = TCPNIOTransportBuilder.newInstance().build();
client.transport.setProcessor(filterChainBuilder.build());
try {
// binding transport to start listen on certain host and port
try {
client.transport.start();
// perform async. connect to the server
Future<Connection> future = client.transport.connect(client.host, client.port);
// wait for connect operation to complete
client.connection = future.get(5, TimeUnit.SECONDS);
if ( client.connection.isOpen())
return client;
else
throw new ConnectionException("can not connect to "+client.toString());
//System.in.read();
} catch (Exception e) {
//shutdown transport thread
if ( client.transport != null )
client.transport.shutdown();
throw new RuntimeException( e.getMessage(), e);
}
} finally {
}
}
示例10: setup
import org.glassfish.grizzly.filterchain.FilterChainBuilder; //导入依赖的package包/类
@Override
public void setup(NetworkListener listener, FilterChainBuilder builder) {
int index = builder.indexOfType(HttpServerFilter.class);
index = index < 0 ? 0 : index;
builder.add(index, this);
}