- 授权协议: Apache
- 开发语言: Java
- 操作系统: 跨平台
- 软件首页: https://www.generallycloud.com/index.html
- 软件文档: https://gitee.com/generallycloud/baseio
软件介绍
BaseIO是基于java nio开发的一款可快速构建网络通讯项目的异步IO框架,其以简单易用的API和优良的性能深受开发者喜爱。
项目特色
支持协议扩展,已知的扩展协议有:
Redis协议(仅作测试),示例:详见 {baseio-test}
LineBased协议(基于换行符的消息分割),示例:详见 {baseio-test}
FixedLength协议(固定长度报文头),支持传输文本和二进制数据
HTTP1.1协议(lite),示例: https://www.generallycloud.com/
WebSocket协议,示例: https://www.generallycloud.com/web-socket/chat/index.html
Protobase(自定义协议),支持传输文本和二进制数据及混合数据
轻松实现断线重连(轻松实现心跳机制)
支持SSL(jdkssl,openssl)
压力测试
超过200W QPS的处理速度(Http1.1,I7-4790,16.04.1-Ubuntu) wrk压测
快速入门
Maven引用:
<dependency> <groupId>com.generallycloud</groupId> <artifactId>baseio-all</artifactId> <version>3.2.6.RELEASE</version> </dependency>
Simple Server:
public static void main(String[] args) throws Exception {
IoEventHandle eventHandle = new IoEventHandle() {
@Override
public void accept(NioSocketChannel channel, Frame frame) throws Exception {
FixedLengthFrame f = (FixedLengthFrame) frame;
frame.write("yes server already accept your message:", channel.getCharset());
frame.write(f.getReadText(), channel.getCharset());
channel.flush(frame);
}
};
ChannelContext context = new ChannelContext(8300);
ChannelAcceptor acceptor = new ChannelAcceptor(context);
context.addChannelEventListener(new LoggerChannelOpenListener());
context.setIoEventHandle(eventHandle);
context.setProtocolCodec(new FixedLengthCodec());
acceptor.bind();
}Simple Client:
public static void main(String[] args) throws Exception {
IoEventHandle eventHandle = new IoEventHandle() {
@Override
public void accept(NioSocketChannel channel, Frame frame) throws Exception {
FixedLengthFrame f = (FixedLengthFrame) frame;
System.out.println();
System.out.println("____________________" + f.getReadText());
System.out.println();
}
};
ChannelContext context = new ChannelContext(8300);
ChannelConnector connector = new ChannelConnector(context);
context.setIoEventHandle(eventHandle);
context.addChannelEventListener(new LoggerChannelOpenListener());
context.setProtocolCodec(new FixedLengthCodec());
NioSocketChannel channel = connector.connect();
FixedLengthFrame frame = new FixedLengthFrame();
frame.write("hello server!", channel);
channel.flush(frame);
ThreadUtil.sleep(100);
CloseUtil.close(connector);
}更多样例详见 {baseio-test}
Python网络编程(第3版)
[美] Brandon Rhodes、[美] John Goerzen / 诸豪文 / 人民邮电出版社 / 2016-9 / 79.00元
本书针对想要深入理解使用Python来解决网络相关问题或是构建网络应用程序的技术人员,结合实例讲解了网络协议、网络数据及错误、电子邮件、服务器架构和HTTP及Web应用程序等经典话题。具体内容包括:全面介绍Python3中最新提供的SSL支持,异步I/O循环的编写,用Flask框架在Python代码中配置URL,跨站脚本以及跨站请求伪造攻击网站的原理及保护方法,等等。一起来看看 《Python网络编程(第3版)》 这本书的介绍吧!
