1 /* 2 * Copyright 2010 Red Hat, Inc. 3 * 4 * Red Hat licenses this file to you under the Apache License, version 2.0 5 * (the "License"); you may not use this file except in compliance with the 6 * License. You may obtain a copy of the License at: 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 12 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 13 * License for the specific language governing permissions and limitations 14 * under the License. 15 */ 16 package org.jboss.netty.example.portunification; 17 18 import java.net.InetSocketAddress; 19 import java.util.concurrent.Executors; 20 21 import org.jboss.netty.bootstrap.ServerBootstrap; 22 import org.jboss.netty.channel.ChannelPipeline; 23 import org.jboss.netty.channel.ChannelPipelineFactory; 24 import org.jboss.netty.channel.Channels; 25 import org.jboss.netty.channel.socket.nio.NioServerSocketChannelFactory; 26 27 /** 28 * Serves two protocols (HTTP and Factorial) using only one port, enabling 29 * either SSL or GZIP dynamically on demand. 30 * <p> 31 * Because SSL and GZIP are enabled on demand, 5 combinations per protocol 32 * are possible: none, SSL only, GZIP only, SSL + GZIP, and GZIP + SSL. 33 * 34 * @author <a href="http://www.jboss.org/netty/">The Netty Project</a> 35 * @author <a href="http://gleamynode.net/">Trustin Lee</a> 36 * 37 * @version $Rev: 2126 $, $Date: 2010-02-02 13:27:33 +0900 (Tue, 02 Feb 2010) $ 38 */ 39 public class PortUnificationServer { 40 41 public static void main(String[] args) throws Exception { 42 // Configure the server. 43 ServerBootstrap bootstrap = new ServerBootstrap( 44 new NioServerSocketChannelFactory( 45 Executors.newCachedThreadPool(), 46 Executors.newCachedThreadPool())); 47 48 // Set up the event pipeline factory. 49 bootstrap.setPipelineFactory(new ChannelPipelineFactory() { 50 public ChannelPipeline getPipeline() throws Exception { 51 return Channels.pipeline(new PortUnificationServerHandler()); 52 } 53 }); 54 55 // Bind and start to accept incoming connections. 56 bootstrap.bind(new InetSocketAddress(8080)); 57 } 58 }