更新到数据库

This commit is contained in:
散仙
2024-11-25 00:31:05 +08:00
parent 4ae76f5eed
commit 5115851c1f
5 changed files with 92 additions and 67 deletions

1
.gitignore vendored
View File

@@ -2,3 +2,4 @@ access.log
node_modules node_modules
package-lock.json package-lock.json
data data
config.json

16
main.js
View File

@@ -1,9 +1,7 @@
import fs from 'fs' import fs from 'fs'
import { Tail } from 'tail' import { Tail } from 'tail'
import { updateDatabase } from './put_database.js'
const tail = new Tail('/opt/log/caddy/access.log')
// 指标(日榜, 周榜, 月榜, 总榜)
const 作品 = new Map() const 作品 = new Map()
const 游戏 = new Map() const 游戏 = new Map()
const 截图 = new Map() const 截图 = new Map()
@@ -15,7 +13,6 @@ const imagesRegex = /\/api\/images\?similar=(\d+)/
var 当前日期 = 格式.format(new Date()).replace(/\//g, '-') var 当前日期 = 格式.format(new Date()).replace(/\//g, '-')
var 正在存档 = false var 正在存档 = false
const 存档 = async (message = '存档中..') => { const 存档 = async (message = '存档中..') => {
if (正在存档) return if (正在存档) return
正在存档 = true 正在存档 = true
@@ -28,7 +25,7 @@ const 存档 = async (message = '存档中..') => {
正在存档 = false 正在存档 = false
} }
export default function () {
if (fs.existsSync(`./data/${当前日期}.json`)) { if (fs.existsSync(`./data/${当前日期}.json`)) {
console.log(当前日期, '启动时读入数据..') console.log(当前日期, '启动时读入数据..')
const file = fs.readFileSync(`./data/${当前日期}.json`, 'utf8') const file = fs.readFileSync(`./data/${当前日期}.json`, 'utf8')
@@ -40,10 +37,13 @@ if (fs.existsSync(`./data/${当前日期}.json`)) {
} }
} }
console.log(当前日期, '开始收集日志..') console.log(当前日期, '开始收集日志..')
setInterval(() => 存档('10 分钟存档一次..'), 600000) setInterval(() => {
存档('10 分钟存档一次..')
updateDatabase(Object.fromEntries(截图))
}, 600000)
const tail = new Tail('/opt/log/caddy/access.log')
tail.on('line', async (line) => { tail.on('line', async (line) => {
const item = JSON.parse(line) const item = JSON.parse(line)
if (item.level !== 'debug') return if (item.level !== 'debug') return
@@ -97,3 +97,5 @@ process.on('SIGINT', async () => {
await 存档('退出前储存数据..') await 存档('退出前储存数据..')
process.exit() process.exit()
}) })
}

View File

@@ -5,12 +5,13 @@
"type": "module", "type": "module",
"main": "main.js", "main": "main.js",
"scripts": { "scripts": {
"test": "echo \"Error: no test specified\" && exit 1" "start": "node server.js"
}, },
"author": "satori", "author": "satori",
"license": "GPL-3.0-only", "license": "GPL-3.0-only",
"dependencies": { "dependencies": {
"express": "^4.21.1", "express": "^4.21.1",
"mysql2": "^3.11.4",
"tail": "^2.2.6" "tail": "^2.2.6"
} }
} }

19
put_database.js Normal file
View File

@@ -0,0 +1,19 @@
import mysql from 'mysql2/promise'
import fs from 'fs'
export async function updateDatabase(list, field) {
const { mysql: config } = JSON.parse(fs.readFileSync('config.json', 'utf8'))
const conn = await mysql.createConnection(config)
await conn.query(`CREATE TEMPORARY TABLE temp_updates (id INT PRIMARY KEY, ${field} INT)`)
for (let i = 0; i < list.length; i += 10000) {
const values = list.slice(i, i + 10000).map(({ id, ...rest }) => [id, rest[field]])
await conn.query(`INSERT INTO temp_updates (id, ${field}) VALUES ?`, [values])
}
await conn.query(`UPDATE web_images t JOIN temp_updates tu ON t.id = tu.id SET t.${field} = tu.${field}`)
console.log('更新完成')
await conn.end()
}

View File

@@ -1,5 +1,6 @@
import fs from 'fs' import fs from 'fs'
import express from 'express' import express from 'express'
import main from './main.js'
const app = express() const app = express()
@@ -41,3 +42,4 @@ app.get('/api', (req, res) => {
}) })
app.listen(6005, () => console.log('http://localhost:6005')) app.listen(6005, () => console.log('http://localhost:6005'))
main()