细节优化

This commit is contained in:
🌌 2023-10-05 15:20:40 +08:00
parent 52c5079489
commit 4604a5985f
6 changed files with 65 additions and 25 deletions

View File

@ -8,6 +8,8 @@ port: 2536
chromium_path: chromium_path:
# puppeteer接口地址 # puppeteer接口地址
puppeteer_ws: puppeteer_ws:
# puppeteer截图超时时间
puppeteer_timeout:
# 米游社接口代理地址,国际服用 # 米游社接口代理地址,国际服用
proxyAddress: proxyAddress:

View File

@ -32,7 +32,7 @@
"node-xlsx": "^0.23.0", "node-xlsx": "^0.23.0",
"oicq": "link:lib/modules/oicq", "oicq": "link:lib/modules/oicq",
"pm2": "^5.3.0", "pm2": "^5.3.0",
"puppeteer": "^21.3.4", "puppeteer": "^21.3.6",
"redis": "^4.6.10", "redis": "^4.6.10",
"sequelize": "^6.33.0", "sequelize": "^6.33.0",
"sqlite3": "^5.1.6", "sqlite3": "^5.1.6",

View File

@ -1,6 +1,6 @@
import plugin from '../../lib/plugins/plugin.js' import plugin from '../../lib/plugins/plugin.js'
export class newcomer extends plugin { export class newcomer extends plugin {
constructor () { constructor() {
super({ super({
name: '欢迎新人', name: '欢迎新人',
dsc: '新人入群欢迎', dsc: '新人入群欢迎',
@ -11,14 +11,14 @@ export class newcomer extends plugin {
} }
/** 接受到消息都会执行一次 */ /** 接受到消息都会执行一次 */
async accept () { async accept() {
if (this.e.user_id == this.e.self_id) return
/** 定义入群欢迎内容 */ /** 定义入群欢迎内容 */
let msg = '欢迎新人!' let msg = '欢迎新人!'
/** 冷却cd 30s */ /** 冷却cd 30s */
let cd = 30 let cd = 30
if (this.e.user_id == this.e.bot.uin) return
/** cd */ /** cd */
let key = `Yz:newcomers:${this.e.group_id}` let key = `Yz:newcomers:${this.e.group_id}`
if (await redis.get(key)) return if (await redis.get(key)) return
@ -34,7 +34,7 @@ export class newcomer extends plugin {
} }
export class outNotice extends plugin { export class outNotice extends plugin {
constructor () { constructor() {
super({ super({
name: '退群通知', name: '退群通知',
dsc: 'xx退群了', dsc: 'xx退群了',
@ -45,8 +45,8 @@ export class outNotice extends plugin {
this.tips = '退群了' this.tips = '退群了'
} }
async accept () { async accept() {
if (this.e.user_id == this.e.bot.uin) return if (this.e.user_id == this.e.self_id) return
let name, msg let name, msg
if (this.e.member) { if (this.e.member) {
@ -61,4 +61,4 @@ export class outNotice extends plugin {
logger.mark(`[退出通知]${this.e.logText} ${msg}`) logger.mark(`[退出通知]${this.e.logText} ${msg}`)
await this.reply(msg) await this.reply(msg)
} }
} }

View File

@ -10,7 +10,7 @@ export class quit extends plugin {
} }
async accept () { async accept () {
if (this.e.user_id != this.e.bot.uin) return if (this.e.user_id != this.e.self_id) return
let other = cfg.other let other = cfg.other
if (other.autoQuit <= 0) return if (other.autoQuit <= 0) return
@ -18,7 +18,7 @@ export class quit extends plugin {
/** 判断主人,主人邀请不退群 */ /** 判断主人,主人邀请不退群 */
let gl = await this.e.group.getMemberMap() let gl = await this.e.group.getMemberMap()
for (let qq of cfg.masterQQ) { for (let qq of cfg.masterQQ) {
if (gl.has(Number(qq))) { if (gl.has(Number(qq) || String(qq))) {
logger.mark(`[主人拉群] ${this.e.group_id}`) logger.mark(`[主人拉群] ${this.e.group_id}`)
return return
} }

View File

@ -18,3 +18,6 @@ args:
- --disable-setuid-sandbox - --disable-setuid-sandbox
- --no-sandbox - --no-sandbox
- --no-zygote - --no-zygote
# puppeteer截图超时时间
puppeteerTimeout:

View File

@ -9,9 +9,11 @@ import { Data } from '#miao'
const _path = process.cwd() const _path = process.cwd()
// mac地址 // mac地址
let mac = '' let mac = ''
// 超时计时器
let overtimeList = []
export default class Puppeteer extends Renderer { export default class Puppeteer extends Renderer {
constructor(config) { constructor (config) {
super({ super({
id: 'puppeteer', id: 'puppeteer',
type: 'image', type: 'image',
@ -41,12 +43,14 @@ export default class Puppeteer extends Renderer {
/** chromium其他路径 */ /** chromium其他路径 */
this.config.wsEndpoint = config.puppeteerWS || cfg?.bot?.puppeteer_ws this.config.wsEndpoint = config.puppeteerWS || cfg?.bot?.puppeteer_ws
} }
/** puppeteer超时超时时间 */
this.puppeteerTimeout = config.puppeteerTimeout || cfg?.bot?.puppeteer_timeout || 0
} }
/** /**
* 初始化chromium * 初始化chromium
*/ */
async browserInit() { async browserInit () {
if (this.browser) return this.browser if (this.browser) return this.browser
if (this.lock) return false if (this.lock) return false
this.lock = true this.lock = true
@ -64,7 +68,7 @@ export default class Puppeteer extends Renderer {
const browserUrl = (await redis.get(this.browserMacKey)) || this.config.wsEndpoint const browserUrl = (await redis.get(this.browserMacKey)) || this.config.wsEndpoint
if (browserUrl) { if (browserUrl) {
logger.info(`puppeteer Chromium from ${browserUrl}`) logger.info(`puppeteer Chromium from ${browserUrl}`)
const browserWSEndpoint = await puppeteer.connect({ browserWSEndpoint: browserUrl }).catch((err) => { const browserWSEndpoint = await puppeteer.connect({ browserWSEndpoint: browserUrl }).catch(() => {
logger.error('puppeteer Chromium 缓存的实例已关闭') logger.error('puppeteer Chromium 缓存的实例已关闭')
redis.del(this.browserMacKey) redis.del(this.browserMacKey)
}) })
@ -117,7 +121,7 @@ export default class Puppeteer extends Renderer {
} }
/** 监听Chromium实例是否断开 */ /** 监听Chromium实例是否断开 */
this.browser.on('disconnected', (e) => { this.browser.on('disconnected', () => {
logger.error('Chromium 实例关闭或崩溃!') logger.error('Chromium 实例关闭或崩溃!')
this.browser = false this.browser = false
}) })
@ -127,23 +131,31 @@ export default class Puppeteer extends Renderer {
// 获取Mac地址 // 获取Mac地址
getMac () { getMac () {
const mac = '00:00:00:00:00:00' let mac = '00:00:00:00:00:00'
try { try {
const network = os.networkInterfaces() const network = os.networkInterfaces()
let macFlag = false
for (const a in network) { for (const a in network) {
for (const i of network[a]) { for (const i of network[a]) {
if (i.mac && i.mac != mac) { if (i.mac && i.mac !== mac) {
return i.mac macFlag = true
mac = i.mac
break
} }
} }
if (macFlag) {
break
}
} }
} catch (e) { } catch (e) {
} }
mac = mac.replace(/:/g, '')
return mac return mac
} }
/** /**
* `chromium` 截图 * `chromium` 截图
* @param name
* @param data 模板参数 * @param data 模板参数
* @param data.tplFile 模板路径必传 * @param data.tplFile 模板路径必传
* @param data.saveId 生成html名称为空name代替 * @param data.saveId 生成html名称为空name代替
@ -154,9 +166,9 @@ export default class Puppeteer extends Renderer {
* @param data.multiPage 是否分页截图默认false * @param data.multiPage 是否分页截图默认false
* @param data.multiPageHeight 分页状态下页面高度默认4000 * @param data.multiPageHeight 分页状态下页面高度默认4000
* @param data.pageGotoParams 页面goto时的参数 * @param data.pageGotoParams 页面goto时的参数
* @return img/[]img 不做segment包裹 * @return img 不做segment包裹
*/ */
async screenshot(name, data = {}) { async screenshot (name, data = {}) {
if (!await this.browserInit()) { if (!await this.browserInit()) {
return false return false
} }
@ -173,6 +185,23 @@ export default class Puppeteer extends Renderer {
let ret = [] let ret = []
this.shoting.push(name) this.shoting.push(name)
const puppeteerTimeout = this.puppeteerTimeout
let overtime
let overtimeFlag = false
if (puppeteerTimeout > 0) {
// TODO 截图超时处理
overtime = setTimeout(() => {
if (!overtimeFlag) {
logger.error(`[图片生成][${name}] 截图超时,当前等待队列:${this.shoting.join(',')}`)
this.restart(true)
this.shoting = []
overtimeList.forEach(item => {
clearTimeout(item)
})
}
}, puppeteerTimeout)
}
try { try {
const page = await this.browser.newPage() const page = await this.browser.newPage()
let pageGotoParams = lodash.extend({ timeout: 120000 }, data.pageGotoParams || {}) let pageGotoParams = lodash.extend({ timeout: 120000 }, data.pageGotoParams || {})
@ -254,6 +283,12 @@ export default class Puppeteer extends Renderer {
this.browser = false this.browser = false
ret = [] ret = []
return false return false
} finally {
if (overtime) {
overtimeFlag = true
clearTimeout(overtime)
overtimeList = []
}
} }
this.shoting.pop() this.shoting.pop()
@ -263,22 +298,22 @@ export default class Puppeteer extends Renderer {
return false return false
} }
this.restart() this.restart(false)
return data.multiPage ? ret : ret[0] return data.multiPage ? ret : ret[0]
} }
/** 重启 */ /** 重启 */
restart() { restart (force = false) {
/** 截图超过重启数时,自动关闭重启浏览器,避免生成速度越来越慢 */ /** 截图超过重启数时,自动关闭重启浏览器,避免生成速度越来越慢 */
if (this.renderNum % this.restartNum === 0) { if (this.renderNum % this.restartNum === 0 || force) {
if (this.shoting.length <= 0) { if (this.shoting.length <= 0 || force) {
setTimeout(async () => { setTimeout(async () => {
if (this.browser) { if (this.browser) {
await this.browser.close().catch((err) => logger.error(err)) await this.browser.close().catch((err) => logger.error(err))
} }
this.browser = false this.browser = false
logger.info('puppeteer Chromium 关闭重启...') logger.info(`puppeteer Chromium ${force ? '强制' : ''}关闭重启...`)
}, 100) }, 100)
} }
} }