perf: 优化站点ip检查

This commit is contained in:
xiaojunnuo
2025-05-28 13:57:31 +08:00
parent 3a147141b1
commit a463711b03
11 changed files with 219 additions and 139 deletions
@@ -12,6 +12,7 @@ import { isComm, isPlus } from '@certd/plus-core';
import { UserSuiteService } from '@certd/commercial-core';
import { UserSettingsService } from "../../mine/service/user-settings-service.js";
import { UserSiteMonitorSetting } from "../../mine/service/models.js";
import {SiteIpService} from "./site-ip-service.js";
@Provide()
@Scope(ScopeEnum.Request, { allowDowngrade: true })
@@ -31,6 +32,8 @@ export class SiteInfoService extends BaseService<SiteInfoEntity> {
@Inject()
userSettingsService: UserSettingsService;
@Inject()
siteIpService: SiteIpService;
//@ts-ignore
getRepository() {
@@ -128,6 +131,13 @@ export class SiteInfoService extends BaseService<SiteInfoEntity> {
};
await this.update(updateData);
//检查ip
if( site.ipCheck){
await this.siteIpService.checkAll(site)
}
if (!notify) {
return;
}
@@ -156,7 +166,7 @@ export class SiteInfoService extends BaseService<SiteInfoEntity> {
}
/**
* 检查,但不发邮件
* 检查
* @param id
* @param notify
* @param retryTimes
@@ -250,4 +260,16 @@ export class SiteInfoService extends BaseService<SiteInfoEntity> {
async saveSetting(userId: number, bean: UserSiteMonitorSetting) {
await this.userSettingsService.saveSetting(userId, bean);
}
async ipCheckChange(req: {id: any; ipCheck: any}) {
await this.update({
id: req.id,
ipCheck: req.ipCheck,
});
if(req.ipCheck){
const site = await this.info(req.id);
await this.siteIpService.sync(site)
}
}
}
@@ -1,18 +1,17 @@
import { Inject, Provide, Scope, ScopeEnum } from "@midwayjs/core";
import { BaseService, SysSettingsService } from "@certd/lib-server";
import { InjectEntityModel } from "@midwayjs/typeorm";
import { Repository } from "typeorm";
import { SiteInfoEntity } from "../entity/site-info.js";
import { NotificationService } from "../../pipeline/service/notification-service.js";
import { UserSuiteService } from "@certd/commercial-core";
import { UserSettingsService } from "../../mine/service/user-settings-service.js";
import { SiteIpEntity } from "../entity/site-ip.js";
import {Inject, Provide, Scope, ScopeEnum} from "@midwayjs/core";
import {BaseService, SysSettingsService} from "@certd/lib-server";
import {InjectEntityModel} from "@midwayjs/typeorm";
import {Repository} from "typeorm";
import {SiteInfoEntity} from "../entity/site-info.js";
import {NotificationService} from "../../pipeline/service/notification-service.js";
import {UserSuiteService} from "@certd/commercial-core";
import {UserSettingsService} from "../../mine/service/user-settings-service.js";
import {SiteIpEntity} from "../entity/site-ip.js";
import dns from "dns";
import { logger, safePromise } from "@certd/basic";
import {logger, safePromise} from "@certd/basic";
import dayjs from "dayjs";
import { siteTester } from "./site-tester.js";
import { PeerCertificate } from "tls";
import { SiteInfoService } from "./site-info-service.js";
import {siteTester} from "./site-tester.js";
import {PeerCertificate} from "tls";
@Provide()
@Scope(ScopeEnum.Request, { allowDowngrade: true })
@@ -31,9 +30,6 @@ export class SiteIpService extends BaseService<SiteIpEntity> {
@Inject()
userSettingsService: UserSettingsService;
@Inject()
siteInfoService: SiteInfoService;
//@ts-ignore
getRepository() {
@@ -83,11 +79,11 @@ export class SiteIpService extends BaseService<SiteIpEntity> {
});
}
await this.checkAll(entity.id);
await this.checkAll(entity);
}
async check(ipId: number, domain?: string, port?: number) {
async check(ipId: number, domain: string, port: number) {
if(!ipId){
return
}
@@ -95,11 +91,6 @@ export class SiteIpService extends BaseService<SiteIpEntity> {
if (!entity) {
return;
}
if (domain == null || port == null){
const siteEntity = await this.siteInfoService.info(entity.siteId);
domain = siteEntity.domain;
port = siteEntity.httpsPort;
}
try {
await this.update({
id: entity.id,
@@ -151,8 +142,8 @@ export class SiteIpService extends BaseService<SiteIpEntity> {
}
}
async checkAll(siteId: number) {
const siteInfo = await this.siteInfoService.info(siteId);
async checkAll(siteInfo: SiteInfoEntity) {
const siteId = siteInfo.id;
const ips = await this.repository.find({
where: {
siteId: siteId
@@ -162,13 +153,14 @@ export class SiteIpService extends BaseService<SiteIpEntity> {
const port = siteInfo.httpsPort;
const promiseList = [];
for (const ip of ips) {
promiseList.push(async () => {
const func = async () => {
try {
await this.check(ip.id, domain, port);
} catch (e) {
logger.error("check site ip error", e);
}
});
}
promiseList.push(func());
}
Promise.all(promiseList);
}
@@ -52,16 +52,12 @@ export class SiteTester {
if (req.ipAddress) {
//使用固定的ip
const ipAddress = req.ipAddress;
options.lookup = (hostname: string, options: any, callback: any) => {
//判断ip是v4 还是v6
console.log("options", options);
console.log("ipaddress", ipAddress);
if (ipAddress.indexOf(":") > -1) {
callback(null, ipAddress, 6);
} else {
callback(null, ipAddress, 4);
}
};
options.headers={
host: options.host,
//sni
servername: options.host
}
options.host = ipAddress;
}
options.agent = new https.Agent({ keepAlive: false });