Browse Source

接入es 查询结构物统计数据

dev
CODE 1 year ago
parent
commit
6f33d67cf4
  1. 9
      api/.vscode/launch.json
  2. 2
      api/app/lib/controllers/alarm/data.js
  3. 31
      api/app/lib/controllers/project/group.js
  4. 3
      api/app/lib/index.js
  5. 55
      api/app/lib/service/es.js
  6. 13
      api/config.js
  7. 1
      api/package.json

9
api/.vscode/launch.json

@ -21,6 +21,7 @@
//
// "-g postgres://FashionAdmin:123456@10.8.30.156:5432/POMS",
"-k 10.8.30.72:29092,10.8.30.73:29092,10.8.30.74:29092",
"-e http://10.8.30.60:9200",
"--iotaProxy http://10.8.30.157:17007",
"--redisHost localhost",
"--redisPort 6379",
@ -42,7 +43,7 @@
// "--qndmn http://resources.anxinyun.cn",
// "--qndmn http://rhvqdivo5.hn-bkt.clouddn.com",
// click
"--clickHouseUrl http://10.8.30.71",
"--clickHouseUrl http://10.8.30.95",
"--clickHousePort 30123",
// click
// "--clickHouseUrl http://10.8.30.161",
@ -50,11 +51,11 @@
// "--clickHouseUrl http://10.8.30.156",
// "--clickHousePort 8123",
// "--clickHouseUrl https://clickhouse01.anxinyun.cn/play",
//
// click
// "--clickHouseUrl http://10.8.30.156",
// "--clickHousePort 8123",
//
// * 2
// "--clickHouseUser ",
// "--clickHousePassword ",
@ -66,7 +67,7 @@
// "--clickHouseDataAlarm default",
// "--clickHouseIot iot",
//
"--clickHouseAnxincloud anxinyun1",
"--clickHouseAnxincloud anxinyun88",
"--clickHousePepEmis pepca8",
"--clickHouseProjectManage peppm8",
"--clickHouseVcmp video_access_dev",

2
api/app/lib/controllers/alarm/data.js

@ -20,7 +20,7 @@ async function groupList (ctx) {
}
for (let g of groupRes) {
g.unit = await await clickHouse.anxinyun.query(`
g.unit = await clickHouse.anxinyun.query(`
SELECT DISTINCT
t_alarm_group_unit.id AS id,t_alarm_group_unit.name AS name,t_alarm_group_unit.group_id AS groupId
FROM t_alarm_group_unit

31
api/app/lib/controllers/project/group.js

@ -119,7 +119,11 @@ async function groupStatic (ctx) {
// 获取全部的 poms 项目id 并构建关系
let pomsProjectIds = new Set()
let groupMap = {
}
for (let group of progectGroupList) {
groupMap[group.id] = groupMap[group.id] || {}
for (let projectId of group.pomsProjectIds) {
pomsProjectIds.add(projectId)
}
@ -138,15 +142,30 @@ async function groupStatic (ctx) {
for (let projectId of project.anxinProjectId) {
anxinProjectIds.add(projectId)
}
groupMap[group.id].anxinProjectCount = anxinProjectCount
}
let anxinProjectIdArr = Array.from(anxinProjectIds)
// // 统计安心云项目下的结构物个数
// let strucRes = await clickHouse.anxinyun.query(
// `
// SELECT
// `
// )
// 统计安心云项目下的结构物个数
const strucCountRes = await clickHouse.anxinyun.query(
`
SELECT project, COUNT(*) AS count
FROM t_project_structure
WHERE project IN (${[...anxinProjectIdArr].join(',')}, -1)
GROUP BY project
`
).toPromise()
let rslt = []
for (let pg of progectGroupList) {
let anxinProjectCount = 0
for (let projectId of pg.pomsProjectIds) {
if (anxinProjectIdArr.includes(projectId)) {
anxinProjectCount++
}
}
let strucCount = 0
}
ctx.status = 200;
ctx.body = []

3
api/app/lib/index.js

@ -8,6 +8,7 @@ const redisConnect = require('./service/redis')
const socketConect = require('./service/socket')
const mqttVideoServer = require('./service/mqttServer')
const paasRequest = require('./service/paasRequest');
const es = require('./service/es');
const authenticator = require('./middlewares/authenticator');
const clickHouseClient = require('./service/clickHouseClient')
const kafka = require('./service/kafka')
@ -30,6 +31,8 @@ module.exports.entry = function (app, router, opts) {
// 实例其他平台请求方法
paasRequest(app, opts)
es(app, opts)
// kafka(app, opts)
// clickHouse 数据库 client

55
api/app/lib/service/es.js

@ -0,0 +1,55 @@
'use strict';
const fs = require('fs');
const path = require('path');
const es = require('elasticsearch');
let initClient = (config, opts) => {
let logOptions;
if (opts.dev) {
let filename = path.join(process.cwd(), 'log', 'elasticsearch-development.log');
let dir = path.dirname(filename);
if (!fs.existsSync(dir)) {
fs.mkdirSync(dir);
}
logOptions = {
type: 'file',
level: 'info',
path: filename
};
} else {
logOptions = {
type: 'stdio',
level: 'error'
};
}
let client = new es.Client({
host: config.rootURL,
log: logOptions,
apiVersion: '5.5'
});
return client;
};
function factory (app, opts) {
if (opts.es) {
try {
app.fs.esclient = {}
let esclient = Object.keys(opts.es).reduce((p, esmodule) => {
console.log(`加载 ES ${esmodule}`);
let moduleCfg = opts.es[esmodule];
let client = initClient(moduleCfg, opts);
p[esmodule] = client;
p[esmodule].config = moduleCfg;
return p;
}, {});
app.fs.esclient = esclient;
} catch (error) {
console.error(error)
process.exit(-1);
}
}
}
module.exports = factory;

13
api/config.js

@ -12,6 +12,7 @@ args.option(['p', 'port'], '启动端口');
args.option(['g', 'pg'], 'postgre 服务 URL');
args.option(['f', 'fileHost'], '文件中心本地化存储: WebApi 服务器地址(必填), 该服务器提供文件上传Web服务');
args.option(['k', 'kafka'], 'kafka 服务 URL');
args.option(['e', 'es'], 'es 服务 URL');
args.option('iotaProxy', '以太代理')
@ -122,6 +123,10 @@ const VCMP_APP_SECRET = process.env.VCMP_APP_SECRET || flags.vcmpAppSecret
const CAIYUN_API = process.env.CAIYUN_API || flags.caiyunApi || 'https://api.caiyunapp.com/v2';
const CAIYUN_KEY = process.env.CAIYUN_KEY || flags.caiyunKey || '1l0eNveMANMXEIJI';
// ES
const ES_PLATFORM_NAME = process.env.ES_PLATFORM_NAME || flags.esPlatformName || 'anxinyun';
const ANXINCLOUD_ES_NODES_REST = process.env.ANXINCLOUD_ES_NODES_REST || flags.es;
if (
!POMS_DB
|| !IOTA_REDIS_SERVER_HOST || !IOTA_REDIS_SERVER_PORT
@ -270,6 +275,14 @@ const product = {
db: CLICKHOUST_CAM_WORKFLOW
},
]
},
es: {
alarm: {
//告警记录
rootURL: ANXINCLOUD_ES_NODES_REST.split(','),
index: `${ES_PLATFORM_NAME}_alarms`,
type: flags.esType ? flags.esType : '_doc'
},
}
}
}

1
api/package.json

@ -19,6 +19,7 @@
"better-xlsx": "^0.7.6",
"clickhouse": "^2.6.0",
"crypto-js": "^4.0.0",
"elasticsearch": "^13.3.1",
"file-saver": "^2.0.2",
"fs-web-server-scaffold": "^2.0.2",
"ioredis": "^5.0.4",

Loading…
Cancel
Save