Skip to content

Latest commit

 

History

History
141 lines (84 loc) · 5.12 KB

File metadata and controls

141 lines (84 loc) · 5.12 KB


Monitorando conexões de ferramentas clientes do PI System

O desenvolvimento tem como finalidade mostrar quantas conexões diferentes houve nas duas principais ferramentas de visualização de dados da OSISoft.

License MIT

conexoes-clientes

Recursos utilizados

  • Node-Red - Versão 1.1.0
  • Grafana - Versão 7.1.0
  • PI Web API - Versão 2015 R3

Desenvolvimento

A ideia principal era saber quantos usuários diferentes estavam se conectando diariamente no PI Server para definição de estratégia de licenciamento. Então foi feito levantamento de quantos usuários diferentes estavam se conectando diariamente no PI Server para obter dados usando as ferramentas Datalink e Processbook. Como o primeiro passo foi levantar as conexões e assim fazer o somatório os eventos de conexão,esta coleta foi feita a partir da opção abaixo e no campo mensagem com os seguintes filtros:

  • Processbook -> SuccessfulProcbook.EXE

  • Excel -> SuccessfulEXCEL.EXE

conexoes-clientes

Com isso temos como resultado a imagem abaixo:

conexoes-clientes

Bom, desta forma conseguimos resolver e quantificar a quantidade de usuários que se conectam nas ferramentas clientes diariamente. Mas foi levantado a possibilidade de monitormos, em tempo, real essa quantidade.

Tínhamos pela frente o desafio de como obter estas informações em tempo e onde mostrar isso. Uma coisa já estava definido era que iríamos visualizar estas informações juntamente com o dashboard de monitoramento da estrutura de TI Industrial que já havia sido feita utilizando o Grafana.

Então partimos para o desenvolvimento que foi divido em três partes:

  1. obter as informação e salvar em um arquivo em um formato amigável
  2. extrair as informações destes arquivos e contabilizar as conexões
  3. enviar estas informações para o AF para que possa ser visualizado

Obter informações e salvar em um arquivo

Nesta etapa foi usando o seguinte comando para poder obter as informações e salvar em um arquivo

  • Processbook:

    D:\PI\adm\pigetmsg -msg SuccessfulProcbook.EXE -st "t" -et "*" > c:\dev\Processbook.csv

  • Datalink:

    D:\PI\adm\pigetmsg -msg SuccessfulEXCEL.EXE -st "t" -et "*" > c:\dev\DataLink.csv

Executando esses comando individualmente ele salva os arquivos conforme configurado. Agora o passo seria deixar isso sendo executado dinamicamente. Então foi criado um arquivo .bat para poder executar esse comandos juntos. Logo após criado o arquivo .bat foi criando uma tarefa agendada do Windows que executa esta rotina a cada 5 minutos, conforme imagem abaixo:

conexoes-clientes

extrair as informações e contabilizar conexões e enviar para o AF

Foi usando o node-red para poder fazer a leitura dos arquivos e fazer a contagem das conexões:

conexoes-clientes

dados = msg.payload
d = msg.payload.length

acesso = []
usuario = []

for(x = 0; x < d; x+=1){
    
    dt = dados[x].col1
    
    dt1 = dt.indexOf('DOMINIO')
    
    if(dt1 > 0){
        
        us = dados[x -1].col1
        us = us.split(' ')
        us = us[1] + " " + us[2]
        dt = dt.split('Username : ')
        dt = dt[1].split('. Method')
        usuario.push(dt[0])
        
        ss = {
            
            usuario: dt[0],
            horario: us
            
        } 
        
        acesso.push(ss)
        //usuarios.push(dt[0])
        
    }

}

cont = new Set(usuario)

msg.payload = [...cont].length
msg.topic = acesso




return msg;

Com estas informações no AF Server conseguimos acessar através de qualquer ferramenta cliente:

conexoes-clientes

No nosso caso foi utilizado o Grafana como ferramenta de visualização:

conexoes-clientes

conexoes-clientes

Conclusão

Com isso podemos fazer acompanhamento em tempo real da conexões clientes o que ajuda muito na gestão da infraestrutura de TI Industrial.

Help

Caso precisem te ajuda ou tenham alguma sugestão, deixe seu comentário Aqui.