- 浏览: 78810 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
asialee:
博主这块写的挺好的,我完全看了,不过我也写了一些关于编解码器的 ...
netty和mina Socket框架(转) -
yan0310:
我试过你写过的方法 好像还是一样的
关于在FireFox中获取radio值的获取方法(原) -
dr88:
@ eoasis 谢谢您的回复,已经调用成功。
向上滚动公告(原) -
eoasis:
调用buildAdHtml方法,把返回值innerHtml到你 ...
向上滚动公告(原) -
dr88:
正需要做过滚动效果,外行问一个问题请问在把上述代码做成js之后 ...
向上滚动公告(原)
(转自:http://blog.163.com/chen_scor/blog/static/178805061201182615318929/)
比较:http://sandaobusi.iteye.com/blog/961175
从Jetty、Tomcat和Mina中提炼NIO构架Server的经典模式:
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(一)
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(二)
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(三)
0.mina比netty出现的早,都是Trustin Lee的作品;
1.mina将内核和一些特性的联系过于紧密,使得用户在不需要这些特性的时候无法脱离,相比下性能会有所下降;netty解决了这个设计问题;
2.netty的文档更清晰,很多mina的特性在netty里都有;
3.netty更新周期更短,新版本的发布比较快;
4.它们的架构差别不大,mina靠apache生存,而netty靠jboss,和jboss的结合度非常高,netty有对google protocal buf的支持,有更完整的ioc容器支持(spring,guice,jbossmc和osgi);
5.netty比mina使用起来更简单,netty里你可以自定义的处理upstream events 或/和 downstream events,可以使用decoder和encoder来解码和编码发送内容;
6.netty和mina在处理UDP时有一些不同,netty将UDP无连接的特性暴露出来;而mina对UDP进行了高级层次的抽象,可以把UDP当成"面向连接"的协议,而要netty做到这一点比较困难。
运用spring注解实现netty服务器端udp应用程序
http://blog.csdn.net/tanrenzong1986/article/details/6404256
netty是JBOSS针对网络开发的一套应用框架,它也是在NIO的基础上发展起来的。netty基于异步的事件驱动,具有高性能、高扩展性等特性,它提供了统一的底层协议接口,使得开发者从底层的网络协议(比如 TCP/IP、UDP)中解脱出来。就使用来说,开发者只要参考 Netty提供的若干例子和它的指南文档,就可以放手开发基于Netty的服务端程序了。
netty有几个比较重要的概念,在此,仅做介绍,详细可以参考netty文档或源码。
1). channelBuffer: Bootstrap 是一个设置服务的帮助类。你甚至可以在这个服务中直接设置一个 Channel 通道。
现在以实现一个UDP协议下的服务器应用程序为例,演示netty通过spring注解开发服务器端。(在此以maven工具管理项目开发)
首先,是导入关联jar的POM文件:
+ expand sourceview plaincopy to clipboardprint?
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.byd.example</groupId>
<artifactId>nettyTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>nettyTest</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>slf4j</groupId>
<artifactId>slf4j-jdk14</artifactId>
<version>1.6.1</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.9</version>
</dependency>
<dependency>
<groupId>org.jboss.netty</groupId>
<artifactId>netty</artifactId>
<version>3.2.0.BETA1</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
</dependencies>
<repositories>
<repository>
<id>repository.jboss.org</id>
<url>http://repository.jboss.org/nexus/content/groups/public/</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<build>
</build>
</project>
接下来是应用程序代码,在本人机器上可以运行并正常工作,如有需要可以试试。
I、Server接口:
view plaincopy to clipboardprint?
package com.byd.example.netty;
public interface IServer
{
/**
* 启动服务器
*/
public void start();
/**
* 重启程序
*/
public void restart();
/**
* 停止程序运行
*/
public void stop();
}
II、ChannelHandler扩张类(继承SimpleChannelHandler):
view plaincopy to clipboardprint?
package com.byd.example.netty;
import java.util.Random;
import org.apache.log4j.Logger;
import org.jboss.netty.buffer.ChannelBuffer;
import org.jboss.netty.buffer.DynamicChannelBuffer;
import org.jboss.netty.channel.ChannelFutureListener;
import org.jboss.netty.channel.ChannelHandlerContext;
import org.jboss.netty.channel.ExceptionEvent;
import org.jboss.netty.channel.MessageEvent;
import org.jboss.netty.channel.SimpleChannelHandler;
import org.springframework.stereotype.Component;
@Component("receiverHandler")
public class ReceiverHandler extends SimpleChannelHandler
{
private static final Logger logger=Logger.getLogger(ReceiverHandler.class.getName());
@Override
public void messageReceived(ChannelHandlerContext ctx,MessageEvent e) throws Exception
{
ChannelBuffer buffer=(ChannelBuffer)e.getMessage();
byte[] recByte=buffer.copy().toByteBuffer().array();
String recMsg=new String(recByte);
logger.info("server received:"+recMsg.trim());
Random random=new Random();
int backWord=random.nextInt(10000);
ChannelBuffer responseBuffer=new DynamicChannelBuffer(4);
responseBuffer.readBytes(backWord);
e.getChannel().write(responseBuffer);
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx,ExceptionEvent e)
{
logger.error(e.getCause());
if(e.getChannel() !=null)
{
e.getChannel().close().addListener(ChannelFutureListener.CLOSE);
}
}
}
III、ChannelPipelineFactory实现类,包装ChannelHandler,处理I/O事件。
view plaincopy to clipboardprint?
package com.byd.example.netty;
import org.jboss.netty.channel.ChannelPipeline;
import org.jboss.netty.channel.ChannelPipelineFactory;
import org.jboss.netty.channel.Channels;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component("serverChannelPipelineFactory")
public class ServerChannelPipelineFactory implements ChannelPipelineFactory
{
@Autowired
@Qualifier("receiverHandler")
private ReceiverHandler handler;
@Override
public ChannelPipeline getPipeline() throws Exception
{
ChannelPipeline pipeline=Channels.pipeline();
pipeline.addLast("handler", this.handler);
return pipeline;
}
public void setHandler(ReceiverHandler handler) {
this.handler = handler;
}
}
IV、Iserver接口的实现类。
+ expand sourceview plaincopy to clipboardprint?
package com.byd.example.netty;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.util.concurrent.Executors;
import org.apache.log4j.Logger;
import org.jboss.netty.bootstrap.ConnectionlessBootstrap;
import org.jboss.netty.channel.Channel;
import org.jboss.netty.channel.ChannelFutureListener;
import org.jboss.netty.channel.socket.DatagramChannelFactory;
import org.jboss.netty.channel.socket.nio.NioDatagramChannelFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component("serverNettyImpl")
public class ServerNettyImpl implements IServer {
@Autowired
@Qualifier("serverChannelPipelineFactory")
private ServerChannelPipelineFactory pipelineFactory;
private Channel channel;
private static final Logger logger = Logger.getLogger(ServerNettyImpl.class
.getName());
@Override
public void start() {
DatagramChannelFactory udpChannelFactory = new NioDatagramChannelFactory(
Executors.newCachedThreadPool());
ConnectionlessBootstrap bootstrap = new ConnectionlessBootstrap(udpChannelFactory);
bootstrap.setOption("reuseAddress", false);
bootstrap.setOption("child.reuseAddress", false);
bootstrap.setOption("readBufferSize", 1024);
bootstrap.setOption("writeBufferSize", 1024);
bootstrap.setPipelineFactory(this.pipelineFactory);
SocketAddress serverAddress = new InetSocketAddress(5000);
this.channel = bootstrap.bind(serverAddress);
logger.info("server start on " + serverAddress);
}
@Override
public void restart() {
this.stop();
this.start();
}
@Override
public void stop() {
if (this.channel != null) {
this.channel.close().addListener(ChannelFutureListener.CLOSE);
}
}
}
V、应用程序入口:
+ expand sourceview plaincopy to clipboardprint?
package com.byd.example;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.byd.example.netty.IServer;
public class NettyTestRun
{
public static void main( String[] args )
{
ApplicationContext context=new ClassPathXmlApplicationContext("classpath*:nettyTest-context.xml");
IServer server=(IServer)context.getBean("serverNettyImpl");
server.start();
}
}
VI、context配置文件:
+ expand sourceview plaincopy to clipboardprint?
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="com.byd.example"/>
<context:annotation-config/>
</beans>
VII、日志配置文件:
+ expand sourceview plaincopy to clipboardprint?
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd" >
<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/' >
<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
<param name="target" value="System.out"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%m%n" />
</layout>
<!--过滤器设置输出的级别-->
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="levelMin" value="debug" />
<param name="levelMax" value="warn" />
<param name="AcceptOnMatch" value="true" />
</filter>
</appender>
<appender name="FILE" class="org.apache.log4j.RollingFileAppender">
<!-- 设置日志输出文件名 -->
<param name="File" value="./target/output.log" />
<!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->
<param name="Append" value="true" />
<param name="MaxBackupIndex" value="10" />
<param name="encoding" value="UTF-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%m%n" />
</layout>
</appender>
<appender name="activexAppender" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="./target/activex.log" />
<param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%m%n" />
</layout>
</appender>
<!--
<logger name="com.runway.bssp.activeXdemo" additivity="false">
<priority value ="info"/>
<param name="Level" value="DEBUG"/>
<appender-ref ref="activexAppender" />
</logger> -->
<!-- 根logger的设置-->
<root>
<priority value ="debug"/>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
</log4j:configuration>
整理上面的代码,运行起来,可以看到服务器侦听在5000端口并接受客户端的信息并返回一个int随机数。
后记:netty当然也可以应用在TCP和客户端的程序,具体的使用可以参考netty API文档。
比较:http://sandaobusi.iteye.com/blog/961175
从Jetty、Tomcat和Mina中提炼NIO构架Server的经典模式:
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(一)
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(二)
从Jetty、Tomcat和Mina中提炼NIO构架网络服务器的经典模式(三)
0.mina比netty出现的早,都是Trustin Lee的作品;
1.mina将内核和一些特性的联系过于紧密,使得用户在不需要这些特性的时候无法脱离,相比下性能会有所下降;netty解决了这个设计问题;
2.netty的文档更清晰,很多mina的特性在netty里都有;
3.netty更新周期更短,新版本的发布比较快;
4.它们的架构差别不大,mina靠apache生存,而netty靠jboss,和jboss的结合度非常高,netty有对google protocal buf的支持,有更完整的ioc容器支持(spring,guice,jbossmc和osgi);
5.netty比mina使用起来更简单,netty里你可以自定义的处理upstream events 或/和 downstream events,可以使用decoder和encoder来解码和编码发送内容;
6.netty和mina在处理UDP时有一些不同,netty将UDP无连接的特性暴露出来;而mina对UDP进行了高级层次的抽象,可以把UDP当成"面向连接"的协议,而要netty做到这一点比较困难。
运用spring注解实现netty服务器端udp应用程序
http://blog.csdn.net/tanrenzong1986/article/details/6404256
netty是JBOSS针对网络开发的一套应用框架,它也是在NIO的基础上发展起来的。netty基于异步的事件驱动,具有高性能、高扩展性等特性,它提供了统一的底层协议接口,使得开发者从底层的网络协议(比如 TCP/IP、UDP)中解脱出来。就使用来说,开发者只要参考 Netty提供的若干例子和它的指南文档,就可以放手开发基于Netty的服务端程序了。
netty有几个比较重要的概念,在此,仅做介绍,详细可以参考netty文档或源码。
1). channelBuffer: Bootstrap 是一个设置服务的帮助类。你甚至可以在这个服务中直接设置一个 Channel 通道。
现在以实现一个UDP协议下的服务器应用程序为例,演示netty通过spring注解开发服务器端。(在此以maven工具管理项目开发)
首先,是导入关联jar的POM文件:
+ expand sourceview plaincopy to clipboardprint?
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.byd.example</groupId>
<artifactId>nettyTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>nettyTest</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>slf4j</groupId>
<artifactId>slf4j-jdk14</artifactId>
<version>1.6.1</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.9</version>
</dependency>
<dependency>
<groupId>org.jboss.netty</groupId>
<artifactId>netty</artifactId>
<version>3.2.0.BETA1</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.0.2.RELEASE</version>
</dependency>
</dependencies>
<repositories>
<repository>
<id>repository.jboss.org</id>
<url>http://repository.jboss.org/nexus/content/groups/public/</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<build>
</build>
</project>
接下来是应用程序代码,在本人机器上可以运行并正常工作,如有需要可以试试。
I、Server接口:
view plaincopy to clipboardprint?
package com.byd.example.netty;
public interface IServer
{
/**
* 启动服务器
*/
public void start();
/**
* 重启程序
*/
public void restart();
/**
* 停止程序运行
*/
public void stop();
}
II、ChannelHandler扩张类(继承SimpleChannelHandler):
view plaincopy to clipboardprint?
package com.byd.example.netty;
import java.util.Random;
import org.apache.log4j.Logger;
import org.jboss.netty.buffer.ChannelBuffer;
import org.jboss.netty.buffer.DynamicChannelBuffer;
import org.jboss.netty.channel.ChannelFutureListener;
import org.jboss.netty.channel.ChannelHandlerContext;
import org.jboss.netty.channel.ExceptionEvent;
import org.jboss.netty.channel.MessageEvent;
import org.jboss.netty.channel.SimpleChannelHandler;
import org.springframework.stereotype.Component;
@Component("receiverHandler")
public class ReceiverHandler extends SimpleChannelHandler
{
private static final Logger logger=Logger.getLogger(ReceiverHandler.class.getName());
@Override
public void messageReceived(ChannelHandlerContext ctx,MessageEvent e) throws Exception
{
ChannelBuffer buffer=(ChannelBuffer)e.getMessage();
byte[] recByte=buffer.copy().toByteBuffer().array();
String recMsg=new String(recByte);
logger.info("server received:"+recMsg.trim());
Random random=new Random();
int backWord=random.nextInt(10000);
ChannelBuffer responseBuffer=new DynamicChannelBuffer(4);
responseBuffer.readBytes(backWord);
e.getChannel().write(responseBuffer);
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx,ExceptionEvent e)
{
logger.error(e.getCause());
if(e.getChannel() !=null)
{
e.getChannel().close().addListener(ChannelFutureListener.CLOSE);
}
}
}
III、ChannelPipelineFactory实现类,包装ChannelHandler,处理I/O事件。
view plaincopy to clipboardprint?
package com.byd.example.netty;
import org.jboss.netty.channel.ChannelPipeline;
import org.jboss.netty.channel.ChannelPipelineFactory;
import org.jboss.netty.channel.Channels;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component("serverChannelPipelineFactory")
public class ServerChannelPipelineFactory implements ChannelPipelineFactory
{
@Autowired
@Qualifier("receiverHandler")
private ReceiverHandler handler;
@Override
public ChannelPipeline getPipeline() throws Exception
{
ChannelPipeline pipeline=Channels.pipeline();
pipeline.addLast("handler", this.handler);
return pipeline;
}
public void setHandler(ReceiverHandler handler) {
this.handler = handler;
}
}
IV、Iserver接口的实现类。
+ expand sourceview plaincopy to clipboardprint?
package com.byd.example.netty;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.util.concurrent.Executors;
import org.apache.log4j.Logger;
import org.jboss.netty.bootstrap.ConnectionlessBootstrap;
import org.jboss.netty.channel.Channel;
import org.jboss.netty.channel.ChannelFutureListener;
import org.jboss.netty.channel.socket.DatagramChannelFactory;
import org.jboss.netty.channel.socket.nio.NioDatagramChannelFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Component;
@Component("serverNettyImpl")
public class ServerNettyImpl implements IServer {
@Autowired
@Qualifier("serverChannelPipelineFactory")
private ServerChannelPipelineFactory pipelineFactory;
private Channel channel;
private static final Logger logger = Logger.getLogger(ServerNettyImpl.class
.getName());
@Override
public void start() {
DatagramChannelFactory udpChannelFactory = new NioDatagramChannelFactory(
Executors.newCachedThreadPool());
ConnectionlessBootstrap bootstrap = new ConnectionlessBootstrap(udpChannelFactory);
bootstrap.setOption("reuseAddress", false);
bootstrap.setOption("child.reuseAddress", false);
bootstrap.setOption("readBufferSize", 1024);
bootstrap.setOption("writeBufferSize", 1024);
bootstrap.setPipelineFactory(this.pipelineFactory);
SocketAddress serverAddress = new InetSocketAddress(5000);
this.channel = bootstrap.bind(serverAddress);
logger.info("server start on " + serverAddress);
}
@Override
public void restart() {
this.stop();
this.start();
}
@Override
public void stop() {
if (this.channel != null) {
this.channel.close().addListener(ChannelFutureListener.CLOSE);
}
}
}
V、应用程序入口:
+ expand sourceview plaincopy to clipboardprint?
package com.byd.example;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.byd.example.netty.IServer;
public class NettyTestRun
{
public static void main( String[] args )
{
ApplicationContext context=new ClassPathXmlApplicationContext("classpath*:nettyTest-context.xml");
IServer server=(IServer)context.getBean("serverNettyImpl");
server.start();
}
}
VI、context配置文件:
+ expand sourceview plaincopy to clipboardprint?
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="com.byd.example"/>
<context:annotation-config/>
</beans>
VII、日志配置文件:
+ expand sourceview plaincopy to clipboardprint?
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd" >
<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/' >
<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
<param name="target" value="System.out"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%m%n" />
</layout>
<!--过滤器设置输出的级别-->
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="levelMin" value="debug" />
<param name="levelMax" value="warn" />
<param name="AcceptOnMatch" value="true" />
</filter>
</appender>
<appender name="FILE" class="org.apache.log4j.RollingFileAppender">
<!-- 设置日志输出文件名 -->
<param name="File" value="./target/output.log" />
<!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->
<param name="Append" value="true" />
<param name="MaxBackupIndex" value="10" />
<param name="encoding" value="UTF-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%m%n" />
</layout>
</appender>
<appender name="activexAppender" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="./target/activex.log" />
<param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}-%m%n" />
</layout>
</appender>
<!--
<logger name="com.runway.bssp.activeXdemo" additivity="false">
<priority value ="info"/>
<param name="Level" value="DEBUG"/>
<appender-ref ref="activexAppender" />
</logger> -->
<!-- 根logger的设置-->
<root>
<priority value ="debug"/>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
</log4j:configuration>
整理上面的代码,运行起来,可以看到服务器侦听在5000端口并接受客户端的信息并返回一个int随机数。
后记:netty当然也可以应用在TCP和客户端的程序,具体的使用可以参考netty API文档。
评论
1 楼
asialee
2013-02-20
博主这块写的挺好的,我完全看了,不过我也写了一些关于编解码器的,请批评指正http://asialee.iteye.com/blog/1769508
发表评论
-
最有效修改文件关联图标方法(转)
2010-04-16 14:05 4657今天电脑里的dreamweaver Cs3装完后发现,asp ... -
Spring+iBatis多数据源的动态配置方案(转)
2010-04-14 14:01 3114在仅使用ibatis时,多数据源简直就是梦魇,每多一个数 ... -
TOMCAT、 JBOSS HTTPS应用配置方法(转)
2010-04-14 11:35 1480keytool生产非签发证书 keytool -gen ... -
利用Tokyo Tyrant构建兼容Memcached协议、支持故障转移、高并发的分布式key-value持久存储系统(转)
2010-04-13 11:19 1320原文地址: http://blog.s135.com/post ... -
Squid配置详解(转)
2010-04-13 09:02 1963前言 在此,我们要配置一个只对内部网络提供代理服务的Pro ...
相关推荐
最后,“MinaDemo”可能是Mina框架的一个示例项目,你可以通过运行和分析这个项目,进一步掌握Mina的实战应用。 总结来说,本教程将引导你从理论到实践,掌握Java NIO的基本原理,理解Mina框架的使用,以及如何在...
该项目为基于Java语言的Socket编程学习项目,集成Mina和Netty框架,源代码库包含76个文件,其中Java源文件52个,XML配置文件15个,YAML配置文件5个,Git忽略文件1个,LICENSE文件1个,YAML文件1个,Markdown文件1个...
描述进一步确认了这个项目是关于MINA框架与Socket应用的,意味着它可能包含了一个简单的服务器和客户端示例,用来展示如何在MINA中创建和管理Socket连接。"包含了所需jar"这部分意味着所有必要的依赖都已经包含在内...
Netty 高性能原理和框架架构解析 Netty 是一个广受欢迎的异步事件驱动的 Java 开源网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。Netty 的高性能原理和框架架构可以从多方面进行解析。 首先,...
开源的Socket框架如QuickServer和Netty提供了简化TCP服务器和客户端开发的解决方案。QuickServer是一个免费的Java库,专注于多线程、多客户端TCP服务器应用的快速创建。而Netty是一个高性能的网络应用框架,它封装了...
在Java开发中,使用Netty框架可以解决传统Socket编程中的一些问题,例如BIO阻塞和NIO全轮询。使用Netty框架可以实现高性能、高可靠的网络通信,降低开发难度和成本。 Netty框架的主要特点包括: * 高性能、高可靠...
改用网络通信框架、目前比较流行的又netty、mina;由于主要作者是同一个人所以差别不是很大、这边选择mina学习; minaserver为采用mina搭建的基本服务器;这边使用了自带的简单TextLineCodesFactory;也自定义了了一...
Netty是一个高性能、异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。它在Java NIO(非阻塞I/O)的基础上构建,相比其他如Mina等框架,Netty在性能、易用性和可定制性方面有着显著...
Mina(MinA Socket API)是Apache软件基金会的一个开源项目,主要设计用于构建高性能、高可扩展性的网络应用程序,如服务器、客户端和服务端通信等。这个教程的PDF文档详细地阐述了如何利用Mina来构建高效能的网络...
- **Netty** 是由 Mina 的作者基于 Mina 打造的一个全新 Java 网络开发框架,它以其简单、易用及高效的特点而受到广泛好评。 - 当前,Netty 由 JBoss 负责维护和支持,这为它的稳定性和权威性提供了保障。 #### 二...
nSocket与mina、netty、xSocket这类高性能的设计不同之处在于,nSocket将直接使用java7中的异步通道构建异步操作,并在后期将弱化C/S模式,逐步过渡到P2P模式。 编写目的: 简化NIO开发过程,将业务与实现...
支持HTTP、WebSocket、Protobuf、BinaryTCP|和UDP,Netty已经被很多高性能项目作为其Socket底层基础,如HornetQInfinispanVert.xPlayFrameworkFinangle和Cassandra。其竞争对手是:ApacheMINA和Grizzly。传统堵塞的...
提供异步的、事件驱动网络应用程序框架和工具 优点:提供异步的、事件驱动网络应用程序框架和工具 优点:提供异步的、事件驱动网络应用程序框架和工具 优点:提供异步的、事件驱动网络应用程序框架和工具 优点:提供...
其中值得一提的是,Netty 的主要贡献者之一也是 Apache MINA(另一个流行的网络应用框架)的重要贡献者。这表明 Netty 在设计之初就吸收了大量来自 MINA 的经验教训,并在此基础上进行了创新和发展。 ##### 1.3 ...
网络框架如Netty、Grizzly和MINA简化了网络应用的开发。这些框架提供了高级API,用于处理多线程、异步I/O、事件驱动的网络编程。例如,Netty以其高性能、灵活性和易用性而闻名,它使用了NIO(非阻塞I/O)来处理大量...
Java_Socket网络编程是Java平台中用于实现网络通信的核心组件,它基于TCP/IP协议栈,提供了客户端和...此外,对于大型网络应用,通常会使用更高层次的框架,如Netty、Apache MINA等,以提供更强大的功能和更好的性能。
综上所述,一位出色的Java高级工程师不仅需要扎实的编程基础,还要具备广泛的框架和技术知识,同时,能够在复杂系统中解决性能和扩展性问题。此外,良好的团队协作能力和持续学习的态度也是必不可少的。