需求:在arenaserver下添加一个rank定时任务,每一分钟对对玩家进行一次排行。





首先在game-server/app/servers/arena文件夹下添加cron文件夹。

在game-server/app/servers/arena/cron文件夹下编写详细的运行的任务的代码rankCron.js。比如:

var utils = require('../../../util/utils');
module.exports = function(app) {
return new Cron(app);
};
var Cron = function(app) {
this.app = app;
}; Cron.prototype.rank = function() {
utils.show('arena rank');
};

然后在game-server/config/文件夹下添加定时任务配置文件crons.json,详细配置文件例如以下所看到的:

{
"development":{
"arena": [
{"id": 1, "time": "0 0/1 * * * *", "action": "rankCron.rank"}
]
},
"production":{
"arena": [
{"id": 1, "time": "0 0/1 * * * *", "action": "rankCron.rank"}
]
}
}

结果如图:

在配置文件crons.json中,id是定时任务在详细server的唯一标识。且不能在同一server中反复。

time是定时任务运行的详细时间。时间的定义跟linux的定时任务类似,一共包含7个字段。每一个字段的详细定义例如以下:

*     *     *     *   *    *        command to be executed
- - - - - -
| | | | | |
| | | | | +----- day of week (0 - 6) (Sunday=0)
| | | | +------- month (0 - 11)
| | | +--------- day of month (1 - 31)
| | +----------- hour (0 - 23)
| +------------- min (0 - 59)
+------------- second (0 - 59)

比如:"0 30 10 * * *",这就代表每天10:30运行对应任务。"0 0/1 * * * *"表示每一分钟运行对应任务。

serverId是一个可选字段,假设有写该字段则该任务仅仅在该server下运行。假设没有该字段则该定时任务在全部同类server中运行。

action是详细运行任务方法,chatCron.sendMoney则代表运行game-server/app/servers/chat/cron/chatCron.js中的sendMoney方法。

附:linux定时任务

用crontab -e 加入要运行的命令

下格式:

* * * * * /需运行命令的路径

前5个字段分别表示:

  分钟:0-59

  小时:1-23

  日期:1-31

  月份:1-12

  星期:0-6(0表示周日)



还能够用一些特殊符号:

  *:表示不论什么时刻

  ,:表示切割

 -:表示一个段,如第二端里: 1-5,就表示1到5点

  /n: 表示每一个n的单位运行一次。如第二段里。*/1, 就表示每隔1个小时运行一次命令。也能够写成1-23/1.



  pomelo里面用*/1报错,改成0/1就能够了

pomelo加入定时任务的更多相关文章

  1. Asp.Net Core 使用Quartz基于界面画接口管理做定时任务

    今天抽出一点点时间来造一个小轮子,是关于定时任务这块的. 这篇文章主要从一下几点介绍: 创建数据库管理表 创建web项目 引入quarzt nuget 包 写具体配置操作,实现定时任务处理 第一步:创 ...

  2. Asp.Ner Core定时任务

    AspNet Core定时任务 纪念人类首张黑洞照片发布 第一种方式BackgroundService 基于后台服务类BackgroundService实现,类所在命名空间Microsoft.Exte ...

  3. 在dotnet core实现类似crontab的定时任务

    前段需要在业务中实现某些时间段的简单定时任务,类似crontab的调度,因为业务会放在docker中,所以不想用直接用crontab,在网上搜了一下,发现一个开源的实现 Pomelo.AspNetCo ...

  4. .Net Core 定时任务TimeJob

    转载自:https://blog.csdn.net/u013711462/article/details/53449799 定时任务 Pomelo.AspNetCore.TimedJob Pomelo ...

  5. Java定时任务的常用实现

    Java的定时任务有以下几种常用的实现方式: 1)Timer 2)ScheduledThreadPoolExecutor 3)Spring中集成Cron Quartz 接下来依次介绍这几类具体实现的方 ...

  6. [转]Java实现定时任务的三种方法

    在应用里经常都有用到在后台跑定时任务的需求.举个例子,比如需要在服务后台跑一个定时任务来进行非实时计算,清除临时数据.文件等.在本文里,我会给大家介绍3种不同的实现方法: 普通thread实现 Tim ...

  7. 使用python crontab设置linux定时任务

    熟悉linux的朋友应该知道在linux中可以使用crontab设置定时任务.可以通过命令crontab -e编写任务.当然也可以直接写配置文件设置任务. 但是有时候希望通过脚本自动设置,比如我们应用 ...

  8. C#定时任务组件之FluentScheduler

    FluentScheduler是.NET开源处理定时任务组件 1.任务的创建注册 public static void TaskActionByMinutes(Action action, int c ...

  9. 浅谈 linux 例行性工作 crontab (linux定时任务)

    定时任务大家都挺说过,就好比你手机上的闹钟,到了指定的时候就会响起. 今天在对redis缓存进行定时储存时又操作了一把,发现一些细节,写的不好.大家就将就看吧, 首先 简单介绍一下linux 例行性工 ...

随机推荐

  1. python列表的增删改查用法

    列表,元组 查 索引(下标) ,都是从0开始 切片 .count 查某个元素的出现次数 .index 根据内容找其对应的位置 "haidilao ge" in a 增加 a.app ...

  2. (转)uibutton边框颜色

    UIButton *testButton = [UIButton buttonWithType:UIButtonTypeSystem]; [testButton setFrame:CGRectMake ...

  3. PAT Basic 1056

    1056 组合数的和 给定 N 个非 0 的个位数字,用其中任意 2 个数字都可以组合成 1 个 2 位的数字.要求所有可能组合出来的 2 位数字的和.例如给定 2.5.8,则可以组合出:25.28. ...

  4. 爬虫开发python工具包介绍 (3)

    本文来自网易云社区 作者:王涛         :arg str url: URL to fetch         :arg str method: HTTP method, e.g. " ...

  5. eclipse错误日志

    一.普通错误:(必现) 1.空指针: 2. 数组下标溢出,越界 3. 数组下标定义为双精度不妥,应该是整数 4. 类型转换错误(与手机分辨率有关) 二.  数据库错误:(必现) 1. 数据库,报错(数 ...

  6. bootshiro---开源的后台管理框架--基于springboot2+ shiro+jwt的真正rest api资源无状态认证权限管理框架,开发人员无需关注权限问题,后端开发完api,前端页面配置即可

    https://gitee.com/tomsun28/bootshiro

  7. 卷积层feature map输出到文本

    本系列文章由 @yhl_leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/52166388 以VGG_16的网络为例 ...

  8. fdisk分区自动挂载

    理解/etc/fstab文件配置 首先打开这个文件我们查看下本身内容 vi /etc/fstab   或者   vim /etc/fstab 2 介绍下fstab配置 文件配置每一行属于一个配置,每个 ...

  9. [UOJ#220][BZOJ4651][Noi2016]网格

    [UOJ#220][BZOJ4651][Noi2016]网格 试题描述 跳蚤国王和蛐蛐国王在玩一个游戏. 他们在一个 n 行 m 列的网格上排兵布阵.其中的 c 个格子中 (0≤c≤nm),每个格子有 ...

  10. BZOJ 3782 上学路线 ——动态规划 Lucas定理 中国剩余定理

    我们枚举第一个经过的坏点,然后DP即可. 状态转移方程不是难点,难点在于组合数的处理. 将狼踩尽的博客中有很详细的证明过程,但是我只记住了结论 $n=a_1 * p^k+a_2*p^k-1...$ $ ...