Techninė informacija
Techninis stakas
Infrastruktūra
- GitHub: naudojamas kodo saugojimui, artefaktų valdymui, projektų valdymui (GitHub Projects) ir automatizacijų vykdymui (GitHub Actions);
- Docker ir Docker compose: naudojami konteinerių paleidimui ir valdymui virtualiose mašinose;
- Git-crypt ir GitHub Actions Secrets: paslapčių (angl. secrets) valdymui;
- Postgres su Postgis: kaip pagrindinė duomenų bazė;
- MariaDB: duomenų bazė, naudojama WordPress;
- Redis: spartinančioji atmintinė (angl. cache) ir eilių valdymas;
- S3: failų saugykla (naudojant VITC teikiamą paslaugą;
- Caddy: atvirkštinis tarpinis serveris (angl. reverse proxy);
- Better Stack Uptime: prieinamumo stebėsena;
- Sentry: klaidų ir greitaveikos stebėsena;
- Grafana, Prometheus, Loki, AlertManager: stebėsena ir žurnalo įrašų kaupimas;
- Zabbix: virtualių mašinų stebėsena;
- PostMark: elektroninių laiškų siuntimas;
- Google Analytics: svetainių lankomumo stebėsena;
- QGIS: geoerdvinių duomenų apdorojimas, peržiūra ir analizė;
- Martin: geoerdvinių vektorinių duomenų generavimas;
API (angl. Application Programming Interface)
Node.js su Moleculer sistema.
Kliento dalis
- React ir Vue: interaktyvioms naudotojų sąsajoms;
- WordPress: turinio valdymo sistema;
- 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.
- APP-BĮIP: veikia bandomosios aplinkos (atitinkamai Development ir Staging), kurias sudaro tiek BĮIP moduliai, tiek tų aplinkų duomenų bazės;
- PROD-BĮIP: šioje virtualioje mašinoje veikia gamybinė aplinka su visais BĮIP moduliais;
- BU-BĮIP: virtualioje mašinoje veikia duomenų bazės naudojamos gamybinėje aplinkoje (pvz., Postgres su PostGIS ir MariaDB);
- INFRA-BĮIP: veikia įvairūs BĮIP infrastruktūriniai įrankiai, tokie kaip Sentry, GitHub self-hosted agentas;
- 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. Detalesnį BĮIP diegimo procesą iliustruoja ši schema:
--- 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
Diegimo žingsniai
- 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ė);
- Docker image paruošimas:
- Naudojant : Reusable Workflows paruošiamas Docker image;
- Docker image patalpinamas ghcr.io registre.
- Aplinkos diegimas:
- Centrinėje BĮIP infrastruktūros konfigūracijos repizitorijoje per docker compose atitinkamoje virtualioje mašinoje paleidžiama atnaujinta diegiama BĮIP projekto dalis;
- Centrinė BĮIP infrastruktūros konfigūracijos repozitorija sukurta remiantis GitOps praktika;