Disclaimer: The explanation provided on this website (Hotmaps Wiki) are indicative and for research purposes only. No responsibility is taken for the accuracy of the provided information, explanations and figures or for using them for unintended purposes.
Data privacy: By clicking OK below, you accept that this website may use cookies.
Esta página contiene toda la información necesaria para que los desarrolladores contribuyan a la plataforma Hotmaps o comprendan cómo está funcionando.
La integración de nuevos conjuntos de datos públicos se maneja de la siguiente manera:
Integración de datos
Si un conjunto de datos falla durante la integración, se crea un problema en Taiga (plataforma de gestión de proyectos). El problema muestra el error que se generó y el desarrollador debe solucionarlo y enviar nuevamente su trabajo a Git para que el script pueda intentar integrarlo nuevamente la noche siguiente.
El código fuente del script de integración está disponible en este enlace: Integración de datos
Para agregar conjuntos de datos a la lista de conjuntos de datos públicos, deben enviarse a un nuevo repositorio de Git en GitLab. Aquí está la Organización de GitLab donde se deben enviar los conjuntos de datos : Conjuntos de datos en GitLab .
Una vez al día, se comprueban los repositorios en busca de nuevas confirmaciones y, si es así, se integran. El proceso de integración comprueba si los datos se ajustan a la especificación o no.
Aquí está la especificación: Hotmaps_Data-upload-on-Gitlab_2017-12-04_V4.pdf
El código de la aplicación se encuentra en GitHub bajo la organización Hotmaps . Esta organización posee varios repositorios
Si desea agregar algún código a Hotmaps, tiene dos posibilidades: si desea actualizar la interfaz o el backend directamente, debe modificar el repositorio de cliente o servicio de la caja de herramientas. Si desea agregar su propio módulo de cálculo, puede crear su propio repositorio siguiendo el archivo Léame del repositorio base_calculation_module
Si desea realizar algún trabajo en el repositorio de Git, no trabaje directamente con la rama maestra. Cree una nueva rama desde la rama de desarrollo, haga su trabajo en esta rama y cuando se pruebe su característica, puede fusionar su trabajo con la rama de desarrollo como se muestra en el siguiente gráfico.
Git_workflow
Para enviar algo a algún repositorio de Hotmaps, debe ser miembro del equipo de Hotmaps, si no lo es, aún puede realizar una bifurcación de nuestra herramienta para desarrollar su propia herramienta.
Puede encontrar más información sobre cómo trabajar en estos documentos:
ReverseProxy_architecture_latest
Todos los servicios y componentes se utilizan a través de su propio contenedor Docker. Todos estos contenedores se definen en un solo archivo docker-compose. La imagen de arriba representa la arquitectura de TI de Hotmaps.
Algunas organizaciones asociadas limitaron la comunicación al puerto 80 únicamente. Para evitar los problemas ocasionados por esta limitación, se realizó la creación de un proxy inverso. Este proxy inverso ofrece un único punto de entrada y luego distribuye la solicitud enviada por el cliente al servicio en cuestión. El proxy inverso se compone de tres componentes:
Existen tres redes:
Cada módulo de cálculo tiene su propio contenedor Docker.
Hotmaps utiliza acoplable software y estibador-Componer herramienta para manejar contenedores. Un archivo docker-compose.yml contiene toda la configuración de la arquitectura Docker (configuración de contenedores, redes, enlaces, ...). Esto permite que los contenedores se ejecuten con un simple comando:
docker-compose up
Hay más información sobre docker-compose en el sitio web de Docker: Redactar referencia de línea de comandos y Redactar referencia de archivo .
Solo hay un contenedor que se ejecuta por separado de los demás: es la base de datos porque necesita estar activa todo el tiempo. Es por eso que no está en el archivo de configuración de docker-compose.
Por el momento, el servidor está alojado en HES-SO en Suiza. Hay 2 máquinas disponibles: una para desarrollo (desarrollo y pruebas) y otra para producción (la caja de herramientas real, disponible en www.hotmaps.eu ).
Ambas máquinas tienen la misma especificación:
Con frecuencia realizamos pruebas de rendimiento en el servidor de desarrollo para garantizar una cierta cantidad de usuarios concurrentes.
Como ejemplo, a continuación se muestran los resultados de la primera versión beta frente a las pruebas de versiones futuras. La nueva versión incluye algunas mejoras de rendimiento.
Este ejemplo muestra las pruebas de rendimiento de usuarios concurrentes utilizando la misma función: "curva de duración para la selección de hectáreas". La línea en negrita muestra el límite donde el servidor comienza a generar errores. La selección de hectáreas es un buen ejemplo, ya que muestra las consultas que requieren más recursos.
Versión beta de marzo de 2019
| Número de usuarios simulados | Tiempo medio | Mediana | Tiempo máximo | Tiempo mínimo | Porcentaje de errores | | --------------------- | ------------ | ------ | -------- | -------- | -------------------- | | 1 | 1042 | 1042 | 1042 | 1042 | 0 | | 20 | 3608 | 3858 | 4475 | 2156 | 0 | | 50 | 7337 | 7595 | 11791 | 1568 | 0 | | 100 | 13897 | 13644 | 24492 | 1875 | 0 | | 200 | 27135 | 26380 | 51967 | 3045 | 0 | | 300 | 41237 | 43083 | 73245 | 3223 | 10,67 |
Versión final (agosto de 2020)
| Número de usuarios simulados | Tiempo medio | Mediana | Tiempo máximo | Tiempo mínimo | Porcentaje de errores | | --------------------- | ------------ | ------ | -------- | -------- | -------------------- | | 1 | 1025 | 970 | 1151 | 956 | 0 | | 20 | 1671 | 1732 | 2085 | 1113 | 0 | | 50 | 3527 | 3622 | 5593 | 982 | 0 | | 100 | 6648 | 6764 | 11854 | 1118 | 0 | | 200 | 12904 | 12801 | 24163 | 1192 | 0 | | 300 | 19521 | 19382 | 38116 | 1060 | 0 |
Daniel Hunacek, Lucien Zuber, Matthieu Dayer, en Hotmaps Wiki, Sección de desarrolladores (septiembre de 2020)
Esta página fue escrita por Daniel Hunacek, Lucien Zuber y Matthieu Dayer ( HES-SO ).
☑ Esta página fue revisada por Mostafa Fallahnejad ( EEG - TU Wien ).
Copyright © 2016-2020: Daniel Hunacek, Lucien Zuber y Matthieu Dayer
Licencia internacional Creative Commons Attribution 4.0
Este trabajo está autorizado bajo una licencia internacional Creative Commons CC BY 4.0.
Identificador de licencia SPDX: CC-BY-4.0
Texto de licencia: https://spdx.org/licenses/CC-BY-4.0.html
Queremos transmitir nuestro más profundo agradecimiento al Proyecto Hotmaps Horizonte 2020 (Acuerdo de subvención número 723677), que proporcionó los fondos para llevar a cabo la presente investigación.
This page was automatically translated. View in another language:
English (original) Bulgarian* Czech* Danish* German* Greek* Estonian* Finnish* French* Irish* Croatian* Hungarian* Italian* Lithuanian* Latvian* Maltese* Dutch* Polish* Portuguese (Portugal, Brazil)* Romanian* Slovak* Slovenian* Swedish*
* machine translated
Last edited by web, 2020-09-30 11:29:36