Skip to content

SGC-analistas/Rutina_noche

Repository files navigation

SGC

SGC_noche

Rutina realizada para enviar correos con el funcionamiento de las estaciones de la RSNC, RNAC, DRL, SUB, INTER

SI ESTA EN EL PROC 4, NO ES NECESARIO REVISAR LA SECCIÓN DE INSTALACIÓN

1. Instalación en linux

Asegurate de hacer lo siguiente para poder correr basemap, para que se pueda abrir pdfs con evince y los excel con libreoffice.

Requerimientos previos

Se corre en sistemas linux.

- Python

Python Versión 3.6 o Versión 3.7

- Servidor SMTP

Tener un servidor SMTP (Simple Mail Transfer Protocol) el cual es un protocolo básico que permite que los emails viajen a través de Internet.

- libgeos

sudo apt-get install libgeos-dev #para basemap
cd /usr/lib
sudo ln -s libgeos-3.3.3.so libgeos.so
sudo ln -s libgeos-3.3.3.so libgeos.so.1

- evince

sudo apt-get install evince # para abrir pdfs

- libreoffice

sudo apt-get install libreoffice #para abrir excel

Instalación con pip

conda deactivate #En caso de que haya un ambiente de anaconda activo
pip install virtualenv 
virtualenv .noche_venv
source .noche_venv/bin/activate
pip install -r requirements.txt

Instalación con anaconda

conda env create -f noche_env.yml
conda activate noche_env

2. Arquitectura

1. Archivos:

  • funest.py: Archivo que contiene la clase SGC_Performance. Tiene un método llamado create_json que genera los json de funcionamiento.

  • utils_noche.py: Contiene todas las funciones útiles que se usan para crear json,txt,mapas,excel, correos.

  • run_noche.py: Archivo de ejecución para la rutina de la noche. Importa las funciones de utils_noche.py

2. noche_store:

  • correo: Carpeta donde se guarda los archivos para enviar correos: destinatarios, formatos de mensajes y las credenciales de rsncol
  • excel: Carpeta donde se guarda los 2 excel que se envían: FUNDIARIO_GENE.xls y INFORMENOCHE2.xls. Este último archivo debe estar actualizado a la fecha que se vaya a correr
  • fonts: Carpeta donde se guarda las fuentes del SGC
  • histogramas: Carpeta donde se guarda los pdfs de histogramas
  • jsons: Carpeta donde se guarda los jsons que se generan
  • logos: Carpeta donde se guarda los logos que se adicionan en los pdfs
  • maps: Carpeta donde se guarda los pdfs de mapas
  • on_stations: CARPETA DONDE SE GUARDAN LOS ARCHIVOS .in QUE CONTIENE LAS ESTACIONES A LAS QUE SE VA A CALCULAR LA RUTINA DE LA NOCHE
  • pdf_noche: Carpeta donde se guarda los pdfs que observan los analistas al correr la noche
  • problemas: Carpeta donde se guarda los problemas que se generan
  • txt: Carpeta donde se guarda los txt de funcionamiento

3. Demostración en el proc4

Desde cualquier usuario del proc4, puede correr la rutina de la noche.

bash /opt/Rutina_Noche/noche.sh

Nota : Recuerde que en opt/Rutina_Noche/SGC_noche/noche_store/on_stations estan los archivos.in donde pueden añadir y eliminar estaciones de la respectiva red.

1. Fecha:

Solicita la fecha para ver el funcionamiento de estaciones en ese día.

fecha YYYYMMDD:  20200801

2. Json:

Una vez digitada empezará a cargar el archivo json. El tiempo que demora la generación del archivo depende del número de gaps en las estaciones en las distintas redes. En general, demora de 2 a 3 minutos.. Se hizo lo posible por disminuir el tiempo calculando los porcentajes en paralelo.

...loading json: 20200801

Nota : Si el archivo.json ya ha sido creado, el pregunta si lo queire volver a crear, o quiere continuar con la información que ya existe.

3. Txt:

De manera inmediata, con el editor nano se abren los archivos txt de las respectivas redes. En este punto se puede revisar que los porcentajes de las estaciones concuerden con el checklist. En caso de que todo este bien se hace lo siguiente:

Ctrl + o  | Enter   # Para guardar
Ctrl + x            # para salir

txt_noche

Luego, se abre el siguiente archivo txt de la siguiente red. Así hasta terminar las respectivas redes.

4. Mapas & histogramas:

En este punto se crean los respectivos mapas e histogramas. En esta versión la generación de mapas depende del servidor arcgisonline. Por tanto, por ahora SE NECESITA INTERNET PARA QUE SE GENEREN LOS MAPAS. El tiempo que demora la generación de los mapas depende del internet, se hace en paralelo para mejorar rendimiento.

...loading maps: 20200801

Luego, de manera inmediata se abre un archivo pdf. El único objetivo de este es que el analista sea capaz de visualizar en una sola pasada todos los mapas y todos los histogramas de las redes. Si todo esta bien solo cerrar el pdf.

map_noche

5. Excel:

Se abren dos archivos excel:

  • FUNDIARIO_GENE.xls : Archivo que guarda el historial de funcionamiento de la red.
  • INFORMENOCHE2.xls : Archivo que contiene el funcionamiento del presente día en que se corre la rutina.

fundiario

informenoche

La idea es copiar el porcentaje de funcionamiento de las estaciones de la RSNC del archivo INFORMENOCHE2.xls en la respectiva fecha del archivo FUNDIARIO_GENE.xls. Revisar que el orden de las estaciones corresponda en cada excel.

Una vez todo este bien, cerrar los archivos guardando los cambios.

6. Correo:

Se envian los correos. Aparece lo siguiente en la terminal:

¿Desea enviar correos?
         1 [si]      0 [no]

En caso de 1 [si] se envían los respectivos correos a los destinatarios según el archivo destinatario_noche.json en la ruta noche_store/correo.

correo_noche

En caso de 0 [no] aparece lo siguiente:

¿Desea informar el problema?.
         1 [si]      0 [no]

En caso de 1 [si] se abre un archivo txt donde puede escribir cuál es el problema. Luego Cntrl + O para guardar y Cntrl + x para guardar. Luego se envia un correo con el problema a los destinatarios según el archivo destinatario_problema.json en la ruta noche_store/correo.

En caso de 0 [no] se anula todo, y termina la rutina.

Autores

creación: 2020/02/01

última actualización: 2020/09/17

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published