1
0
Code Issues Pull Requests Projects Releases Wiki Activity GitHub Gitee

引入定时任务

This commit is contained in:
程序员小墨 2022-07-24 00:11:13 +08:00
parent bbe9753ad3
commit 766658ea11
3 changed files with 34 additions and 11 deletions

4
.env
View File

@ -6,3 +6,7 @@ DEBUG_MODE=1
# 目录开头与结尾的 [./] [/] [\] [\\] 均可带可不带 # 目录开头与结尾的 [./] [/] [\] [\\] 均可带可不带
# 默认为 data 文件夹 # 默认为 data 文件夹
DATA_FOLDER=data DATA_FOLDER=data
# 是否在程序刚一启动时就抓取一次数据
# 1为是
EXECUTE_AT_STARTUP=1

View File

@ -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);

View File

@ -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,
}); });