服务端轻量级开发框架:lightning4j

jopen 9年前


简介

一个基于Netty网络库的java服务端轻量级开发框架,用于快速开发手游,页游等服务端程序,使用WebSocket通信协议,支持mysql,redis,连接池,全局定时任务,心跳检测,可配置逻辑处理线程等,使用简单,部署方便。

项目网站:http://www.53hql.com/lightning4j
项目WiKi:http://www.53hql.com/lightning4j/wiki

使用(基于IntelliJ IDEA)

新建一个maven project或在已有project中新建一个maven module,编辑pom.xml中的依赖包:

<dependencies>      <dependency>          <groupId>netty</groupId>          <artifactId>netty</artifactId>          <version>4.0.25.Final</version>      </dependency>      <dependency>          <groupId>mysql</groupId>          <artifactId>mysql-connector-java</artifactId>          <version>5.1.30</version>      </dependency>      <dependency>          <groupId>redis.clients</groupId>          <artifactId>jedis</artifactId>          <version>2.4.0</version>      </dependency>      <dependency>          <groupId>c3p0</groupId>          <artifactId>c3p0</artifactId>          <version>0.9.1.2</version>      </dependency>      <dependency>          <groupId>org.slf4j</groupId>          <artifactId>slf4j-log4j12</artifactId>          <version>1.7.6</version>      </dependency>      <dependency>          <groupId>log4j</groupId>          <artifactId>log4j</artifactId>          <version>1.2.17</version>      </dependency>      <dependency>          <groupId>dom4j</groupId>          <artifactId>dom4j</artifactId>          <version>1.6.1</version>      </dependency>      <dependency>          <groupId>org.mybatis</groupId>          <artifactId>mybatis</artifactId>          <version>3.2.3</version>      </dependency>      <dependency>          <groupId>junit</groupId>          <artifactId>junit</artifactId>          <version>4.11</version>          <scope>test</scope>      </dependency>      <dependency>          <groupId>com.alibaba</groupId>          <artifactId>fastjson</artifactId>          <version>1.1.41</version>      </dependency>      <dependency>          <groupId>com.hql</groupId>          <artifactId>lightning4j</artifactId>          <version>1.0.0</version>      </dependency>  </dependencies>
  • lib目录下为框架的jar包,用于添加到maven仓库
  • 建议使用maven私服管理依赖包
  • confFile下为项目所需的配置文件、模块文件及log存放目录
  • 示例代码请参考test目录
  • client.html为测试客户端

基本用法

  • 在IDEA的project目录下新建一个文件夹例如:conf存放配置文件及log,将源码目录下confFile里的内容拷贝到该文件夹中。
  • 修改配置选项为开发者自己的配置
  • 在初始化代码中设置配置文件根路径:ServerInit.getInstance().initConfPath("conf");
  • 简历游戏模块工程(new maven module in IntelliJ IDEA)参考项目结构:
    ......包
    |--handler(业务逻辑handler)
    |--model(MyBatis使用的数据dao)
    |--manager(缓存数据管理)
    |--vo(用于映射json的对象)
  • 使用maven打包该module为jar文件
  • 拷贝至confFile里的module目录
  • 配置moduleConf.xml

    <?xml version="1.0" encoding="UTF-8"?>  <handlers>    <!--模块名和模块jar文件名对应-->    <test>      <test><!--handler注册名-->        com.hql.test.handler.HandlerTest<!--类名-->      </test>      <onDisconnect>        com.hql.test.handler.DisconnectHandlerTest      </onDisconnect>      ......    </test>    ......  </handlers>
  • 启动代码示例:

    public class Server {      public void run() throws Exception {          ServerInit.getInstance().initConfPath("conf");          ServerInit.getInstance().initLog4j();          ServerInit.getInstance().initGameWorkers();          ServerInit.getInstance().initModules();            GameBoss.getInstance().boot(new GameUpProcessor() {              @Override              public void process(GameUpBuffer buffer) {                  GameWorkerManager.getInstance().pushDataToWorker(buffer);              }          });      }        public static void main(String[] args) throws Exception {          new Server().run();      }  }
  • 热更新示例

    ModuleUtil.getInstance().updateModule("test2");//更新test2模块


项目主页:http://www.open-open.com/lib/view/home/1423830845357