/*
* Copyright 2012 The Netty Project
*
* The Netty Project licenses this file to you under the Apache License,
* version 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package io.netty.example.http.helloworld;
import io.netty.bootstrap.ServerBootstrap;
import io.netty.buffer.PooledByteBufAllocator;
import io.netty.buffer.UnpooledByteBufAllocator;
import io.netty.channel.Channel;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.ServerChannel;
import io.netty.channel.epoll.Epoll;
import io.netty.channel.epoll.EpollEventLoopGroup;
import io.netty.channel.epoll.EpollServerSocketChannel;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.nio.NioServerSocketChannel;
import org.apache.commons.lang3.StringUtils;
/**
* An HTTP server that sends back the content of the received HTTP request in a pretty plaintext form.
*/
public class HttpHelloWorldServer
{
private final int port;
public HttpHelloWorldServer(int port)
{
this.port = port;
}
public void run() throws Exception
{
// Configure the server.
if (Epoll.isAvailable())
{
System.out.println("netty-transport: linux-epoll");
doRun(new EpollEventLoopGroup(), new EpollEventLoopGroup(), EpollServerSocketChannel.class);
}
else
{
System.out.println("netty-transport: nio");
doRun(new NioEventLoopGroup(), new NioEventLoopGroup(), NioServerSocketChannel.class);
}
}
private void doRun(EventLoopGroup bossGroup, EventLoopGroup workerGroup, Class<? extends ServerChannel> serverChannelClass) throws InterruptedException
{
try
{
String os_arch = System.getProperty("os.arch");
boolean isARM = StringUtils.contains(os_arch, "arm");
ServerBootstrap b = new ServerBootstrap();
if (isARM)
{
b.childOption(ChannelOption.ALLOCATOR, new UnpooledByteBufAllocator(false));
}
else
{
b.childOption(ChannelOption.ALLOCATOR, new PooledByteBufAllocator(true));
}
b.childOption(ChannelOption.MAX_MESSAGES_PER_READ, Integer.MAX_VALUE);
b.childOption(ChannelOption.SO_REUSEADDR, true);
b.option(ChannelOption.MAX_MESSAGES_PER_READ, Integer.MAX_VALUE);
b.option(ChannelOption.SO_BACKLOG, 1024);
b.option(ChannelOption.SO_REUSEADDR, true);
b.group(bossGroup, workerGroup).channel(serverChannelClass).childHandler(new HttpHelloWorldServerInitializer());
Channel ch = b.bind(port).sync().channel();
System.out.printf("Httpd started. Listening on: %s%n", ch.localAddress().toString());
ch.closeFuture().sync();
}
finally
{
bossGroup.shutdownGracefully();
workerGroup.shutdownGracefully();
}
}
public static void main(String[] args) throws Exception
{
int port;
if (args.length > 0)
{
port = Integer.parseInt(args[0]);
}
else
{
port = 8082;
}
new HttpHelloWorldServer(port).run();
}
}