# java-Kcp
[![Powered][2]][1]
[1]: https://github.com/skywind3000/kcp
[2]: http://skywind3000.github.io/word/images/kcp.svg
[README in english](https://github.com/l42111996/java-Kcp/blob/master/README.en.md)
基于netty版本实现的kcp(包含fec功能的实现)
KCP是一个基于udp的快速可靠协议(rudp),能以比 TCP浪费10%-20%的带宽的代价,换取平均延迟降低 30%-40%,且最大延迟降低三倍的传输效果。
# maven地址:
```xml
<dependency>
<groupId>com.github.l42111996</groupId>
<artifactId>kcp-base</artifactId>
<version>1.6</version>
</dependency>
```
# 使用方法以及参数
1. [server端示例](https://github.com/l42111996/java-Kcp/blob/master/kcp-example/src/main/java/test/KcpRttExampleServer.java)
2. [client端实例](https://github.com/l42111996/java-Kcp/blob/master/kcp-example/src/main/java/test/KcpRttExampleClient.java)
3. [最佳实践](https://github.com/skywind3000/kcp/wiki/KCP-Best-Practice)
4. [大量资料](https://github.com/skywind3000/kcp)
5. 兼容c#端,[java服务端](https://github.com/l42111996/java-Kcp/blob/master/kcp-example/src/main/java/test/Kcp4sharpExampleServer.java) , [c#客户端](https://github.com/l42111996/csharp-kcp/blob/master/example-Kcp/KcpRttExampleClient.cs)
6. [遇到过的问题](https://github.com/l42111996/java-Kcp/blob/master/QA.md)
7. [性能测试结果](https://github.com/l42111996/java-Kcp/blob/master/Benchmark.md)
8. [兼容kcp-go,包含fec兼容](https://github.com/l42111996/java-Kcp/blob/master/kcp-example/src/main/java/test/Kcp4GoExampleClient.java)
# 兼容性:
1. 兼容c版本kcp
2. fec基于 https://github.com/Backblaze/JavaReedSolomon 实现
3. 完美兼容的C#版本,https://github.com/l42111996/csharp-kcp ,快速构建游戏前后端网络库
# 稳定性:
已经是稳定版本,据统计有5~10款上线项目接入,包含腾讯,快手等公司产品使用
# 优化:
1. 基于事件驱动,充分利用多核
2. 优化fastack逻辑,降低10%流量
3. 优化check函数。
4. 优化集合迭代器。
5. 包含fec,降低延迟
6. 附带crc32校验
7. 使用时间轮,优化大量连接cpu占用
8. 使用directbuf和对象池,无gc压力
9. 增加使用conv或者ip+port确定channel唯一性,游戏建议使用conv与tcp配置使用,[相关资料](https://github.com/skywind3000/kcp/wiki/Cooperate-With-Tcp-Server)
10. 增加游戏使用时4G切换wifi等出口ip变动不会导致连接断开
# 相关资料
1. https://github.com/skywind3000/kcp 原版c版本的kcp
2. https://github.com/xtaci/kcp-go go版本kcp,有大量优化
3. https://github.com/Backblaze/JavaReedSolomon java版本fec
4. https://github.com/LMAX-Exchange/disruptor 高性能的线程间消息传递库
5. https://github.com/JCTools/JCTools 高性能并发库
6. https://github.com/szhnet/kcp-netty java版本的一个kcp
7. https://github.com/l42111996/csharp-kcp 基于dotNetty的c#版本kcp,完美兼容
# 交流
QQ:526167774
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
Java是一种高性能、跨平台的面向对象编程语言。它由Sun Microsystems(现在是Oracle Corporation)的James Gosling等人在1995年推出,被设计为一种简单、健壮、可移植、多线程、动态的语言。Java的主要特点和优势包括以下几个方面: 跨平台性(Write Once, Run Anywhere): Java的代码可以在不同的平台上运行,只需编写一次代码,就可以在任何支持Java的设备上执行。这得益于Java虚拟机(JVM),它充当了代码和底层硬件之间的中介。 面向对象: Java是一种纯粹的面向对象编程语言,支持封装、继承和多态等面向对象的概念。这使得Java编写的代码更加模块化、可维护和可扩展。 多线程支持: Java内置了对多线程的支持,允许程序同时执行多个任务。这对于开发需要高并发性能的应用程序(如服务器端应用、网络应用等)非常重要。 自动内存管理(垃圾回收): Java具有自动内存管理机制,通过垃圾回收器自动回收不再使用的对象,使得开发者不需要手动管理内存,减轻了程序员的负担,同时也减少了内存泄漏的风险。
资源推荐
资源详情
资源评论
收起资源包目录
基于java的netty实现的可靠udp网络库(kcp算法),包含fec实现,可用于游戏,视频,加速等业务.zip (166个子文件)
libjni.dylib 22KB
.gitignore 378B
kcp-base.iml 6KB
kcp-lockStepSynchronization.iml 5KB
kcp-fec.iml 5KB
kcp-example.iml 5KB
java-Kcp.iml 1KB
Kcp.java 44KB
ReItrHashMap.java 34KB
ReItrLinkedList.java 33KB
ReedSolomon.java 19KB
OrderedThreadPoolExecutor.java 18KB
Ukcp.java 14KB
ReedSolomonTest.java 13KB
Galois.java 12KB
FecDecode.java 12KB
FecDecode.java 12KB
FecTest.java 12KB
Matrix.java 10KB
LatencySimulator.java 10KB
ReedSolomonBenchmark.java 9KB
FecEncode.java 9KB
FecEncode.java 8KB
Snmp.java 8KB
FecTestNative.java 7KB
MpscBenchmark.java 6KB
KcpClient.java 6KB
KcpServer.java 5KB
CodingLoop.java 5KB
KcpRttExampleClient.java 5KB
GaloisTest.java 5KB
MpscaBenchmark.java 5KB
ChannelConfig.java 5KB
InputOutputByteBufHeapTableCodingLoop.java 4KB
TestThreadLoop.java 4KB
CodecOutputList.java 4KB
ServerChannelHandler.java 4KB
KcpGameTestClient.java 4KB
TestOrderThreadPoolOrder.java 4KB
InputOutputByteBufTableCodingLoop.java 4KB
SampleDecoder.java 4KB
InputOutputByteTableCodingLoop.java 3KB
SampleEncoder.java 3KB
ByteBufCodingLoop.java 3KB
KcpLockStepSynchronizationServer.java 3KB
OutputInputByteTableCodingLoop.java 3KB
KcpGameTestServer.java 3KB
DisruptorSingleExecutor.java 3KB
ReadTask.java 3KB
IKcp.java 3KB
KcpLockStepSynchronizationClient.java 3KB
BytebufBenchmarkNative.java 3KB
SpeedExampleClient.java 3KB
SignalBenchmark.java 3KB
KcpPingPongExampleServer.java 3KB
TcpLockStepSynchronizationServer.java 3KB
KcpPingPongExampleClient.java 3KB
TestEncryption.java 3KB
KcpDisconnectExampleClient.java 3KB
BytebufBenchmark.java 3KB
Tps.java 3KB
KcpReconnectExampleClient.java 3KB
TestCrc32.java 2KB
MatrixTest.java 2KB
KcpMultiplePingPongExampleClient.java 2KB
ScheduleTask.java 2KB
KcpIdleExampleClient.java 2KB
SpeedExampleServer.java 2KB
KcpIdleExampleServer.java 2KB
NetAcceptor.java 2KB
TpsCounter.java 2KB
TcpLockStepSynchronizationClient.java 2KB
KcpMultiplePingPongExampleServer.java 2KB
DisruptorThread.java 2KB
MpmcBenchmark.java 2KB
VolatileAtomicBenchmark.java 2KB
KcpReconnectExampleServer.java 2KB
WriteTask.java 2KB
SleepingWaitConditionStrategy.java 2KB
TestRoom.java 2KB
FecAdapt.java 2KB
BlockingWaitConditionStrategy.java 2KB
InputByteOutputTableCodingLoop.java 2KB
KcpRttExampleServer.java 2KB
Kcp4sharpExampleServer.java 2KB
Kcp4GoExampleClient.java 2KB
ByteInputOutputTableCodingLoop.java 2KB
FecPacket.java 2KB
Room.java 2KB
KcpDisconnectExampleServer.java 2KB
ReedSolomonNative.java 2KB
InputByteOutputExpCodingLoop.java 2KB
InputOutputByteExpCodingLoop.java 2KB
YieldingWaitConditionStrategy.java 2KB
ByteInputOutputExpCodingLoop.java 1KB
NetConnector.java 1KB
DisruptorExecutorPool.java 1KB
User.java 1KB
OutputInputByteExpCodingLoop.java 1KB
CodingLoopBase.java 1KB
共 166 条
- 1
- 2
资源评论
JJJ69
- 粉丝: 6006
- 资源: 5593
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功