net.sz.framework 框架 轻松搭建服务---让你更专注逻辑功能---初探
前言
在之前的文章中,讲解过 threadmodel,socket tcp ,socket http,log,astart ,scripts;
都是分片讲解,从今天开始,将带大家,一窥 net.sz.framework 框架;
net.sz.framework 框架分为java版本和C#.net 版本,两种语言版本保持高一致性;
net.sz.framework 能做什么呢?
net.sz.framework 是经过多年实践和研究,包括在线项目验证的底层框架,致力于解决框架问题;
让你更轻松,愉快,快捷,方便的开发自己的服务器(无论是游戏,微服务,webapi,数据中心,中转中心,数据集成中心,im服务器等);
让你轻松处理多线程,线程池,线程控制,无需过多考虑多线程的线程安全;
让你无需过多考虑socket传输问题,socket粘包,分包,分包一切;
让你轻松搭建实现基于 tcp协议 服务,基于 http协议 服务;
让你轻松在程序内部实现任意定时器,任意定时触发器;
让你轻松把 .java 和 .cs 的文件作为脚本使用还原你熟悉的脚本无需在去学习其他脚本语言;
让你轻松处理数据库 mysql , sqlite(可继续扩展其他数据源),数据存储,读取的快捷方式;
让你轻松解决高并发文件日志存储结构,记录完整日志数据;
日志处理如果默认参数有修改可以直接调用属性设置也可以用配置文件进行修改
需要在项目其他源根目录加入文件szlogger.ini
########## 日志信息配置 ########## # 日志级别 不区分大小写 debug:调试信息 info:普通信息 WARN:警告信息 ERROR:错误信息 FATAL:严重错误信息 LOG_LEVEL = debug # 是否输出到控制台(默认为false) CONSOLE_PRINT = true # 是否输出到文件(默认为true) CONSOLE_FILE = true # 是否输出到文件(默认为true) CONSOLE_FILE_BUFFER = true # 日志文件存放路径 LOG_PATH =../log/sz.log
s
Holle world
首先打开NetBeans工具
新建项目 net.sz.blog.test
然后我们再按照同样的方式新建 项目net.sz.blog.test-scipts
切记脚本项目的项目名字是主项目名字+ (-scripts);读取脚本文件的约定;
项目创建完成后,我们调用方式,需要处理的是添加引用;根据自己需求,加入框架库引用;
主项目和脚本项目目录结构,脚本项目依赖于主项目
本次重点讲解实现脚本和定时器任务;
我们现在主项目下面建立 main 包在main包下面建立iscript包
我们建立主函数脚本接口
package net.sz.blog.test.main.iscript; import net.sz.framework.scripts.IInitBaseScript; /** * 主脚本 * <br> * author 失足程序员<br> * blog http://www.cnblogs.com/ty408/<br> * mail 492794628@qq.com<br> * phone 13882122019<br> */ public interface IAppManagerScript extends IInitBaseScript { /*程序启动完成后调用脚本函数*/ void startEnd(); /*需要停止服务器的时候调用的脚本*/ void stop(); }
我们在main包下面建立主类Test_App_Manager
package net.sz.blog.test.main; import java.util.ArrayList; import net.sz.blog.test.main.iscript.IAppManagerScript; import net.sz.framework.scripts.manager.ScriptManager; import net.sz.framework.szlog.SzLogger; /** * * <br> * author 失足程序员<br> * blog http://www.cnblogs.com/ty408/<br> * mail 492794628@qq.com<br> * phone 13882122019<br> */ public class Test_App_Manager { private static SzLogger log = SzLogger.getLogger(); /*单例脚本,脚本反向注册,而非集合调用*/ private static IAppManagerScript iAppManagerScript = null; public static IAppManagerScript getiAppManagerScript() { return iAppManagerScript; } public static void setiAppManagerScript(IAppManagerScript iAppManagerScript) { Test_App_Manager.iAppManagerScript = iAppManagerScript; } public static void main(String[] args) { /*加载所有脚本文件,默认加载项目路径 -scripts 文件下面所有问题*/ ArrayList<String> loadScripts = ScriptManager.getInstance().reload(); String join = String.join(",", loadScripts); log.error("脚本加载结果:" + join); if (iAppManagerScript != null) { /*调用启动脚本*/ iAppManagerScript.startEnd(); } } }
我们在主类中添加对主项目启动函数脚本接口的引用,等待加载脚本的时候注入;
我们在脚本项目下面建立main包添加AppManagerScript脚本文件
package net.sz.blog.test.scripts.main; import net.sz.blog.test.main.Test_App_Manager; import net.sz.blog.test.main.iscript.IAppManagerScript; import net.sz.framework.szlog.SzLogger; /** * * <br> * author 失足程序员<br> * blog http://www.cnblogs.com/ty408/<br> * mail 492794628@qq.com<br> * phone 13882122019<br> */ public class AppManagerScript implements IAppManagerScript { private static SzLogger log = SzLogger.getLogger(); @Override public void _init() { /*把脚本反向注册回主项目函数*/ Test_App_Manager.setiAppManagerScript(this); } @Override public void startEnd() { log.error("主项目单例模式脚本调用函数执行"); /* holle world! 放在脚本打印 */ log.error("holle world!"); } @Override public void stop() { } }
顺利完成了脚本的注册,输出holle world
定时器任务实现
在主项目下面和main包同级别下建立timer包
建立文件ServerInfoTimer 每一秒钟执行 需要手动注册的定时器任务执行;
我们暂时加入公共线程执行的定时器
package net.sz.blog.test.timer; import net.sz.framework.szlog.SzLogger; import net.sz.framework.szthread.TimerTaskModel; /** * * <br> * author 失足程序员<br> * blog http://www.cnblogs.com/ty408/<br> * mail 492794628@qq.com<br> * phone 13882122019<br> */ public class ServerInfoTimer extends TimerTaskModel { private static SzLogger log = SzLogger.getLogger(); public ServerInfoTimer() { super(1000);/*一秒钟无限执行*/ } @Override public void run() { log.error("我是主项目里面执行定时器"); } }
接下来我们在脚本项目中依然是main同级别建立timer包
建立TestTimerScript脚本文件,这里的定时器依然是每一秒钟执行,但是是自动执行的无需线程注册;
package net.sz.blog.test.scripts.timer; import net.sz.framework.szlog.SzLogger; import net.sz.framework.szthread.timer.iscript.ISecondsEventTimerScript; /** * * <br> * author 失足程序员<br> * blog http://www.cnblogs.com/ty408/<br> * mail 492794628@qq.com<br> * phone 13882122019<br> */ public class TestTimerScript implements ISecondsEventTimerScript { private static SzLogger log = SzLogger.getLogger(); /*自动调用*/ @Override public void run(int sec) { log.error("我是脚本里面执行定时器"); } }
我们在主函数main方法中加入ServerInfoTimer 定时器的手动注册代码
/*主动注册,选择线程执行的定时器任务*/ ThreadPool.addTimerTask(ThreadPool.GlobalThread, new ServerInfoTimer()); /* 值的注意,服务器程序准备好工作后,我们必须设置这个参数 这时因为本线程池线程分为 sys线程 和 user线程; 没有这个标识,user线程是不会执行定时器操作的; */ ThreadPool.setStarEnd(true);
看看效果先
两种定时任务执行;值的注意的是在脚本的定时器任务不能执行长时间任务,这样会占用其他定时器任务的执行时间;一般作为定时触发器;
到这里 net.sz.framework java 版本基础使用就算完成
C#版本的代码还需要进一步整合,所以就暂时不放出来;
net.sz.framework 框架 轻松搭建服务---让你更专注逻辑功能---初探的更多相关文章
- net.sz.framework 框架 轻松搭建数据服务中心----读写分离数据一致性,滑动缓存
前言 前文讲述了net.sz.framework 框架的基础实现功能,本文主讲 net.sz.framework.db 和 net.sz.framework.szthread; net.sz.fram ...
- net.sz.framework 框架 登录服务器架构 单服2 万 TPS(QPS)
前言 无论我们做什么系统,95%的系统都离不开注册,登录: 而游戏更加关键,频繁登录,并发登录,导量登录:如果登录承载不起来,那么游戏做的再好,都是徒然,进不去啊: 序言 登录所需要的承载,包含程序和 ...
- net.sz.framework 框架 ORM 消消乐超过亿条数据排行榜分析 天王盖地虎
序言 天王盖地虎, 老婆马上生孩子了,在家待产,老婆喜欢玩消消乐类似的休闲游戏,闲置状态,无聊的分析一下消消乐游戏的一些技术问题: 由于我主要是服务器研发,客户端属于半吊子,所以就分析一下消消乐排行榜 ...
- 如何快速搭建一个基于ServiceStack框架的web服务
ServiceStack是一个高性能的.NET Web Service 平台,能够简化开发高性能的REST (支持JSON,XML,JSV,HTML,MsgPack,ProtoBuf,CSV等消息格式 ...
- Python web 框架之 Django 基础搭建服务
1. 需要安装 Python 和 Django 环境,Python 环境的安装我就不在多说了 2. 安装框架 Django Django 安装,推荐先装个 pip吧,easyinstall也可以,然后 ...
- 无框架完整搭建安卓app及其服务端(一)
技术背景: 我的一个项目做的的是图片处理,用 python 实现图片处理的核心功能后,想部署到安卓app中,但是对于一个对安卓和服务器都一知半解的小白来说要现学的东西太多了. 而实际上,我们的项目要求 ...
- 使用Apache MINA框架搭建服务端
使用MINA框架搭建服务端步骤: 1.定义一个启动服务的类MinaServer,并实现接口ServletContextListener 2.定义一个处理业务逻辑的类MinaServerHandler, ...
- Zend Framework 框架搭建
通过手工方法搭建Zend Framework的MVC框架结构.首先看一下zend framework mvc的目录结构 1. 在根目录下面创建 public ,并在 public 下创建 index. ...
- KODExplorer可道云-轻松搭建属于自己/团队的私有云网盘服务
如今国内各大网盘关停的也快差不多,百度网盘限速严重.国外大牌的如 Dropbox 或 Google Drive又在长城之外,在各种VPN都被封禁的大背景下,科学上网也困难重重,麻烦到要死.那么,除了购 ...
随机推荐
- ZooKeeper 学习笔记
ZooKeeper学习笔记 1. zookeeper基本概念 zookeeper是一个分布式的,开放源码的分布式应用程序协调服务,是hadoop和Habase的重要组件,是为分布式应用提供一致性服 ...
- 如何通过注解Bean类来封装SQL插入语句
整体思路是酱紫的: 给bean上注解说明该bean对应着数据库中哪张表,给每个bean的属性都注解说明各自对应着这张表的哪个字段. 通过类反射获取表名,通过逐个反射每个属性的getter方法,获取注解 ...
- GDOI2015 解题报告
首先嘛现在发现题目这么水我还啥都没想出来正是呵呵了.接下来就口胡下GDOI的题解吧 PS:代码什么的要请联系我 题目:快戳我 Day1: T1:这个嘛,可以先找到起点所能到达的每个点然后判断该点能否到 ...
- SQL中的存储过程和函数
存储过程和函数 简单的说,存储过程就是一条或者多条SQL语句的集合.可以视为批文件,但是其作用不仅仅局限于批处理.本文主要介绍如 ...
- fir.im Weekly - 8 个不能错过的 iOS / Android 技术分享
本期 fir.im Weekly 收集了 2 月下旬新鲜出炉的 iOS /Android 技术分享.源码等,iOS 中图片技术的解压缩.逆向实战.iOS SDK 实践,Android架构思考.Andr ...
- 设计理念 : popup login 在前后台
popup 意思是一个遮罩层顶在整个网页最前方,在前台设计是这样的,当用户想在那个界面登入时,就可以有一个遮罩层出现. 在employer或admin(后台)操作界面是同个理念,在所有的界面都是有co ...
- JDK 安装过程
1.首先是下载jdk:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 2.下载完 ...
- js中盒子模型常用的属性你还记得几个?
//clientWidth;//内容宽度Width+左右填充padding//clientHeight;//内容高度height+上下填充padding//clientLeft;//左边框的宽度相当于 ...
- Unbutu14.04 启用 root 并禁用guest
系统环境: Ubuntu14.04 x64 问题描述: Ubuntu14.04的64位系统默认禁用 root 账号登录 解决方式: 1. 为root设置密码 sudo passw ...
- Java设计模式之《代理模式》及应用场景
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6525527.html 代理模式算是我接触较早的模式,代理就是中介,中间人.法律上也有代理, ...