Skip to content

Seiryuu-Qiu/ioGame-example

 
 

Repository files navigation

ioGame

无锁异步化、事件驱动的架构设计;轻量级,无需依赖任何第三方中间件或数据库就能支持集群、分布式
通过 ioGame 可以很容易的搭建出一个集群无中心节点、集群自动化、多进程的分步式游戏服务器
包体小、启动快、内存占用少、更加的节约、无需配置文件、提供了优雅的路由访问权限控制
让开发者使用一套业务代码,无需改动,支持多种连接方式:WebSocket、TCP、UDP
让开发者用一套业务代码,能轻松切换和扩展不同的通信协议:Protobuf、JSON
近原生的性能;业务框架在单线程中平均每秒可以执行 1152 万次业务逻辑
代码即联调文档、JSR380验证、断言 + 异常机制 = 更少的维护成本
框架具备智能的同进程亲和性;开发中,业务代码可定位与跳转
架构部署灵活性与多样性:既可相互独立,又可相互融合
可同时与同类型的多个游戏逻辑服通信并得到数据
逻辑服之间可相互跨进程、跨机器进行通信
支持玩家对游戏逻辑服进行动态绑定
能与任何其他框架做融合共存
对 webMVC 开发者友好
无 spring 强依赖
零学习成本

http://game.iohao.com

JDK 17
AGPL3.0
gitee star github star



过去、现在、将来都不会有商业版本,所有功能全部开源!

只做真的完全式开源,拒绝虚假开源,售卖商业版,不搞短暂维护!

承诺项目的维护周期是十年起步, 2022-03-01起,至少十年维护期!

提供高质量的使用文档!

如果您觉得还不错,帮忙给个 star 关注!

综合示例请看

这个仓库用于存放 ioGame 相关的使用示例

https://www.yuque.com/iohao/game/ruaqza

示例内容包含

  1. 多服多进程的方式部署
  2. 单体应用方式部署
  3. springboot 集成
  4. JSR380验证
  5. 断言 + 异常机制 = 清晰简洁的代码
  6. 请求、无响应
  7. 请求、响应
  8. 广播指定玩家
  9. 广播全服玩家
  10. 单个逻辑服与单个逻辑服通信请求 - 有返回值(可跨进程)
  11. 单个逻辑服与单个逻辑服通信请求 - 无返回值(可跨进程)
  12. 单个逻辑服与同类型多个逻辑服通信请求(可跨进程)
  13. 业务参数自动装箱、拆箱基础类型(解决协议碎片问题)
  14. 游戏文档生成
  15. 业务协议文件 .proto 的生成
  16. 登录相关:包含重复登录、顶号相关的业务
  17. 启动多个同类型的游戏逻辑服
  18. 将项目打成 jar 包
  19. 启动 jar 包
  20. docker 运行综合示例
  21. 纯原生 proto 数据的模拟客户端模块
  22. CocosCreator 与综合示例联调
  23. 模块的整理与建议(路由相关)
  24. k8s
  25. 元信息

还有更多,将在后续添加 ... ...

阅读前的建议

阅读综合示例这部分时,建议先看简单介绍快速从零编写服务器完整示例这两部分;

源码目录介绍

.
├── example (示例)
│   ├── example-broadcast (广播示例)
│   ├── example-cluster-run-one (集群示例)
│   ├── example-endpoint 示例目录 玩家动态绑定逻辑服节点
│   ├── example-for-spring (spring集成示例)
│   ├── example-for-tcp-socket (对外服使用tcp协议示例)
│   ├── example-hook 示例目录 钩子相关(心跳,用户上线、下线)
│   ├── example-interaction (逻辑服与逻辑服之间的交互,可跨进程通信)
│   ├── example-interaction-same 示例目录 逻辑服间的相互通信;请求同类型多个逻辑服的结果集(可跨进程)
│   ├── example-parent
│   ├── example-redisson-lock (分步式锁)
│   ├── example-redisson-lock-spring-boot-starter (分步式锁 for springBootStarter)
│   └── example-run-one (快速启动示例)
├── example-game-collect (实战示例、坦克)
│   ├── fxgl-tank (游戏引擎-坦克游戏启动端)
│   ├── game-common (一些通用的功能)
│   ├── game-common-proto (示例 pb )
│   ├── game-external (对外服)
│   ├── game-logic-hall (登录逻辑服)
│   ├── game-logic-tank (坦克逻辑服)
│   └── game-one (一键启动 游戏网关、游戏逻辑服(登录和坦克)、对外服)
└── example-springboot #### 综合示例 #### 
    ├── spring-common-pb (通用PB相关)
    ├── spring-game-broker # 游戏网关服 - 启动项目
    ├── spring-game-external # 游戏对外服 - 启动项目
    ├── spring-game-logic-classes (游戏逻辑服 - 班级)
    ├── spring-game-logic-classes-starter # 游戏逻辑服 - 班级 - 启动项目
    ├── spring-game-logic-school (游戏逻辑服 - 学校)
    ├── spring-game-logic-school-starter # 游戏逻辑服 - 学校 - 启动项目
    ├── spring-websocket-client #游戏客户端模拟 - 启动项目
    └── spring-z-one-game (一键启动)

jmeter 压测

https://gitee.com/iohao/iogame-example/tree/main/example/example-meter

About

ioGame 网络游戏服务器框架示例集合

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • Java 99.5%
  • Other 0.5%