Techninė informacija

Techninis stakas

Infrastruktūra

  1. GitHub: naudojamas kodo saugojimui, artefaktų valdymui, projektų valdymui (GitHub Projects) ir automatizacijų vykdymui (GitHub Actions);
  2. Docker ir Docker compose: naudojami konteinerių paleidimui ir valdymui virtualiose mašinose;
  3. Git-crypt ir GitHub Actions Secrets: paslapčių (angl. secrets) valdymui;
  4. Postgres su Postgis: kaip pagrindinė duomenų bazė;
  5. MariaDB: duomenų bazė, naudojama WordPress;
  6. Redis: spartinančioji atmintinė (angl. cache) ir eilių valdymas;
  7. S3: failų saugykla (naudojant VITC teikiamą paslaugą;
  8. Caddy: atvirkštinis tarpinis serveris (angl. reverse proxy);
  9. Better Stack Uptime: prieinamumo stebėsena;
  10. Sentry: klaidų ir greitaveikos stebėsena;
  11. Grafana, Prometheus, Loki, AlertManager: stebėsena ir žurnalo įrašų kaupimas;
  12. Zabbix: virtualių mašinų stebėsena;
  13. PostMark: elektroninių laiškų siuntimas;
  14. Google Analytics: svetainių lankomumo stebėsena;
  15. QGIS: geoerdvinių duomenų apdorojimas, peržiūra ir analizė;
  16. Martin: geoerdvinių vektorinių duomenų generavimas;

API (angl. Application Programming Interface)

Node.js su Moleculer sistema.

Kliento dalis

  1. React: visoms kliento sąsajoms;
  2. Vue: žemėlapių naršyklės kliento sąsajos;
  3. WordPress: turinio valdymo sistema;
  4. Medžioklės žurnalas mobilioji programėlė naudoja React-Native ir Fastlane diegimų automatizacijoms;

Virtualios mašinos

Naudojamos VITC teikiamos ir valdomos virtualios mašinos.

  1. APP-BĮIP: veikia bandomosios aplinkos (atitinkamai Development ir Staging), kurias sudaro tiek BĮIP moduliai, tiek tų aplinkų duomenų bazės;
  2. PROD-BĮIP: šioje virtualioje mašinoje veikia gamybinė aplinka su visais BĮIP moduliais;
  3. BU-BĮIP: virtualioje mašinoje veikia duomenų bazės naudojamos gamybinėje aplinkoje (pvz., Postgres su PostGIS ir MariaDB);
  4. INFRA-BĮIP: veikia įvairūs BĮIP infrastruktūriniai įrankiai, tokie kaip Sentry, GitHub self-hosted agentas;
  5. BACKUP-BĮIP: ši virtuali mašina naudojama atsarginėms kopijoms, pvz., duomenų bazių;

Diegimo procesas

Visi BĮIP atliekami diegimai yra automatizuoti naudojant GitHub actions.

Diegimo žingsniai

---
title: BĮIP diegimo procesas
---
%%{init: {'theme':'neutral'}}%%
flowchart TD
    subgraph app1["BĮIP modulio dalis 1"]
        a1["Automatinis testavimas"] --> a2["Docker image paruošimas"]
    end
    subgraph app2["BĮIP modulio dalis 2"]
        b1["Automatinis testavimas"] --> b2["Docker image paruošimas"]
    end
    subgraph infra["Infrastruktūros repozitorija"]
        i1["Aplinkos diegimas"]
    end
    app1 --> infra
    app2 --> infra
  1. Automatinis testavimas:
    • BĮIP projekto dalis automatiškai testuojama naudojant GitHub Actions (pvz., automatiniai testai, statinė kodo analizė su CodeQL, viešai žinomus pažeidžiamumų analizė);
  2. Docker image paruošimas:
    • Naudojant : Reusable Workflows paruošiamas Docker image;
    • Docker image patalpinamas ghcr.io registre.
  3. Aplinkos diegimas:
    • Centrinėje BĮIP infrastruktūros konfigūracijos repozitorijoje, naudojant Docker Compose, paleidžiama atnaujinta BĮIP projekto dalis atitinkamoje virtualioje mašinoje;
    • Centrinė BĮIP infrastruktūros konfigūracijos repozitorija remiasi GitOps praktikomis;