引入定时任务
This commit is contained in:
parent
bbe9753ad3
commit
766658ea11
4
.env
4
.env
@ -6,3 +6,7 @@ DEBUG_MODE=1
|
|||||||
# 目录开头与结尾的 [./] [/] [\] [\\] 均可带可不带
|
# 目录开头与结尾的 [./] [/] [\] [\\] 均可带可不带
|
||||||
# 默认为 data 文件夹
|
# 默认为 data 文件夹
|
||||||
DATA_FOLDER=data
|
DATA_FOLDER=data
|
||||||
|
|
||||||
|
# 是否在程序刚一启动时就抓取一次数据
|
||||||
|
# 1为是
|
||||||
|
EXECUTE_AT_STARTUP=1
|
21
index.js
21
index.js
@ -1,15 +1,18 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
const dotenv = require('dotenv');
|
||||||
|
const schedule = require('node-schedule');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 环境变量
|
* 环境变量
|
||||||
*/
|
*/
|
||||||
const dotenv = require('dotenv');
|
|
||||||
process.env = {}; // 清除系统自带的环境变量
|
process.env = {}; // 清除系统自带的环境变量
|
||||||
dotenv.config('./.env'); // 导入 .env 文件中的环境变量
|
dotenv.config('./.env'); // 导入 .env 文件中的环境变量
|
||||||
// console.log(process.env);
|
// console.log(process.env);
|
||||||
|
|
||||||
// 调试模式
|
// 调试模式
|
||||||
const DEBUG_MODE = !!process.env.DEBUG_MODE;
|
const DEBUG_MODE = process.env.DEBUG_MODE == true;
|
||||||
|
const EXECUTE_AT_STARTUP = process.env.EXECUTE_AT_STARTUP == true;
|
||||||
|
|
||||||
if (DEBUG_MODE) {
|
if (DEBUG_MODE) {
|
||||||
console.log('DEBUG_MODE is on');
|
console.log('DEBUG_MODE is on');
|
||||||
@ -27,5 +30,19 @@ const get_hotband = require('./src/get_hotband');
|
|||||||
*/
|
*/
|
||||||
console.log("Start running ...");
|
console.log("Start running ...");
|
||||||
|
|
||||||
|
// 程序主函数
|
||||||
|
function start() {
|
||||||
// 爬取热搜数据
|
// 爬取热搜数据
|
||||||
get_hotband.main();
|
get_hotband.main();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 调试模式下,程序一启动就首先运行一次
|
||||||
|
if (EXECUTE_AT_STARTUP) {
|
||||||
|
process.stdout.write("程序启动时,立即运行一次\t");
|
||||||
|
start();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 每分钟的第 5 秒执行一次
|
||||||
|
// 这里指定第 5 秒是为了稍微与微博服务器热榜更新时间错开,避免因为微秒级误差造成拉取两次相同的热榜数据
|
||||||
|
// refer: https://www.npmjs.com/package/node-schedule
|
||||||
|
const scheduleJob = schedule.scheduleJob('05 * * * * *', start);
|
||||||
|
@ -6,6 +6,7 @@ const { dirname } = require('path');
|
|||||||
const path = require('path');
|
const path = require('path');
|
||||||
|
|
||||||
const DATA_FOLDER = path.join(dirname(__dirname), process.env.DATA_FOLDER ?? 'data');
|
const DATA_FOLDER = path.join(dirname(__dirname), process.env.DATA_FOLDER ?? 'data');
|
||||||
|
console.log("DATA_FOLDER", DATA_FOLDER);
|
||||||
|
|
||||||
// 请求微博热搜 APi 接口
|
// 请求微博热搜 APi 接口
|
||||||
async function getApiResult(url) {
|
async function getApiResult(url) {
|
||||||
@ -70,8 +71,6 @@ function saveJSON({ now, fileNameSuffix, object, compress = true, uncompress = t
|
|||||||
}
|
}
|
||||||
|
|
||||||
async function main() {
|
async function main() {
|
||||||
console.log("DATA_FOLDER", DATA_FOLDER);
|
|
||||||
|
|
||||||
let requestTimestamp = Date.now();
|
let requestTimestamp = Date.now();
|
||||||
let now = new Date(requestTimestamp + 8 * 3600 * 1000).toISOString();
|
let now = new Date(requestTimestamp + 8 * 3600 * 1000).toISOString();
|
||||||
|
|
||||||
@ -79,9 +78,9 @@ async function main() {
|
|||||||
// console.log("result", result);
|
// console.log("result", result);
|
||||||
|
|
||||||
if (result.ok != 1) {
|
if (result.ok != 1) {
|
||||||
console.log("请求成功,但服务器处理失败。");
|
console.log(new Date(Date.now() + 8 * 60 * 60 * 1000).toISOString(), "请求成功,但服务器处理失败。");
|
||||||
} else {
|
} else {
|
||||||
console.log("请求成功。");
|
console.log(new Date(Date.now() + 8 * 60 * 60 * 1000).toISOString(), "请求成功");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存原始数据
|
* 保存原始数据
|
||||||
@ -188,7 +187,8 @@ async function main() {
|
|||||||
fileNameSuffix: `final`,
|
fileNameSuffix: `final`,
|
||||||
object: convert,
|
object: convert,
|
||||||
compress: true,
|
compress: true,
|
||||||
uncompress: true
|
// uncompress: true,
|
||||||
|
uncompress: false,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
@ -230,8 +230,10 @@ async function main() {
|
|||||||
now: now,
|
now: now,
|
||||||
fileNameSuffix: `simplify`,
|
fileNameSuffix: `simplify`,
|
||||||
object: data,
|
object: data,
|
||||||
compress: true,
|
// compress: true,
|
||||||
uncompress: true
|
// uncompress: true,
|
||||||
|
compress: false,
|
||||||
|
uncompress: false,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user