705a2f6ea0
- PairType 定义移至 types/kline.ts (spot/um/cm) - Kline 接口新增 type 字段,全链路透传 - klines 5列复合主键 (exchange, symbol, type, interval, time) - 拆出 BinanceFuturesRestClient (USDMClient) - exchanges/index.ts 注册 binance_futures - trading_pairs 唯一约束加 type,种子数据加合约对 - 12个连续聚合视图 SELECT/GROUP BY/INDEX 加 type - 清理 bnkline.ts 废弃代码和 pair.ts 空函数
53 lines
1.9 KiB
TypeScript
53 lines
1.9 KiB
TypeScript
import { logger } from "../utils/logger";
|
|
import { getAllPairs, updatePairLastBackfillTime } from '../service/pair';
|
|
import { upsertOrUpdateKlines } from "../service/kline";
|
|
import { createRestClient } from '../exchanges';
|
|
|
|
function getNowMinuteMS() {
|
|
const minuteMS = 1000 * 60;
|
|
return Math.floor(Date.now() / minuteMS) * minuteMS
|
|
}
|
|
|
|
const allPairs = await getAllPairs();
|
|
|
|
for (const pair of allPairs) {
|
|
const exchangeId = pair.type === 'um' ? 'binance_futures' : 'binance';
|
|
const client = createRestClient(exchangeId);
|
|
let lastBackfillTime = pair.last_backfill_time.getTime();
|
|
try {
|
|
while (lastBackfillTime < getNowMinuteMS()) {
|
|
console.log('lastBackfillTime', lastBackfillTime);
|
|
const klines = await client.fetchKlines(
|
|
pair.symbol,
|
|
lastBackfillTime,
|
|
500
|
|
);
|
|
console.log(`拉取到 ${klines.length} 条 K 线`);
|
|
if (klines.length > 0) {
|
|
await upsertOrUpdateKlines(klines);
|
|
const lastK = klines[klines.length - 1];
|
|
if (lastK) {
|
|
await updatePairLastBackfillTime(lastK?.symbol, new Date(lastK.openTime), pair.type);
|
|
if (lastBackfillTime === lastK.openTime) {
|
|
break;
|
|
}
|
|
lastBackfillTime = lastK.openTime;
|
|
}
|
|
}
|
|
await new Promise((resolve) => {
|
|
setTimeout(resolve, Math.random() * 1000);
|
|
});
|
|
}
|
|
} catch (err) {
|
|
console.error("拉取失败:", err);
|
|
}
|
|
}
|
|
|
|
// 所有币种回补完成以后等待1秒关闭pgsql连接退出此进程
|
|
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
const { AppDataSource } = await import("../db/data-source");
|
|
if (AppDataSource.isInitialized) {
|
|
await AppDataSource.destroy();
|
|
console.log("pgsql 连接已关闭");
|
|
}
|
|
process.exit(0); |