V tomto článku nastavím pracovné prostredie pre vývoj hry „Epics“ a rozdelím aj samotnú hru na časti vhodné na použitie v OpenFaaS. Všetky manipulácie urobím na Linuxe, Kubernetes nasadím do minikube pomocou VirtualBoxu. Môj pracovný stroj má 2 jadrá procesora a 12 GB RAM, ako systémový disk používam SSD. Ako hlavný vývojový systém budem používať debian 8, s nainštalovanými balíčkami emacs, sudo, git a virtualbox, všetko ostatné sa nainštaluje stiahnutím z GitHubu a iných zdrojov. Tieto aplikácie nainštalujeme do /usr/local/bin, pokiaľ nie je uvedené inak. Začnime!
Príprava pracovného prostredia
Inštaluje sa Go
Postupujeme podľa pokynov z oficiálnej webovej stránky:
Vývojári odporúčajú vytvoriť 2 menné priestory, s ktorými budete pracovať:
$ kubectl apply -f https://raw.githubusercontent.com/openfaas/faas-netes/master/namespaces.yml
namespace/openfaas created
namespace/openfaas-fn created
Pridajte úložisko pre kormidlo:
$ helm repo add openfaas https://openfaas.github.io/faas-netes/
"openfaas" has been added to your repositories
Graf má možnosť nastaviť heslo pred inštaláciou, poďme ho použiť a uložme si prístupové údaje ako k8s tajomstvo:
$ helm repo update
Hang tight while we grab the latest from your chart repositories...
...Successfully got an update from the "openfaas" chart repository
Update Complete. Happy Helming!
$ helm upgrade openfaas --install openfaas/openfaas --namespace openfaas --set functionNamespace=openfaas-fn --set generateBasicAuth=false
Release "openfaas" does not exist. Installing it now.
NAME: openfaas
LAST DEPLOYED: Fri Dec 25 10:28:22 2019
NAMESPACE: openfaas
STATUS: deployed
REVISION: 1
TEST SUITE: None
NOTES:
To verify that openfaas has started, run:
kubectl -n openfaas get deployments -l "release=openfaas, app=openfaas"
$ kubectl rollout status -n openfaas deploy/gateway
deployment "gateway" successfully rolled out
$ kubectl port-forward -n openfaas svc/gateway 8080:8080 &
[1] 6985
Forwarding from 127.0.0.1:8080 -> 8080
$ echo -n $PASSWORD | faas-cli login --username admin --password-stdin
Calling the OpenFaaS server to validate the credentials...
Handling connection for 8080
WARNING! Communication is not secure, please consider using HTTPS. Letsencrypt.org offers free SSL/TLS certificates.
credentials saved for admin http://127.0.0.1:8080
$ faas-cli list
Function Invocations Replicas
Inštalácia Mongodb
Všetko inštalujeme pomocou kormidla:
$ helm repo add stable https://kubernetes-charts.storage.googleapis.com/
"stable" has been added to your repositories
$ helm install stable/mongodb --generate-name
NAME: mongodb-1577466908
LAST DEPLOYED: Fri Dec 25 11:15:11 2019
NAMESPACE: default
STATUS: deployed
REVISION: 1
TEST SUITE: None
NOTES:
** Please be patient while the chart is being deployed **
MongoDB can be accessed via port 27017 on the following DNS name from within your cluster:
mongodb-1577466908.default.svc.cluster.local
To get the root password run:
export MONGODB_ROOT_PASSWORD=$(kubectl get secret --namespace default mongodb-1577466908 -o jsonpath="{.data.mongodb-root-password}" | base64 --decode)
To connect to your database run the following command:
kubectl run --namespace default mongodb-1577466908-client --rm --tty -i --restart='Never' --image bitnami/mongodb --command -- mongo admin --host mongodb-1577466908 --authenticationDatabase admin -u root -p $MONGODB_ROOT_PASSWORD
To connect to your database from outside the cluster execute the following commands:
kubectl port-forward --namespace default svc/mongodb-1577466908 27017:27017 &
mongo --host 127.0.0.1 --authenticationDatabase admin -p $MONGODB_ROOT_PASSWORD
skontrolujte:
kubectl run --namespace default mongodb-1577466908-client --rm --tty -i --restart='Never' --image bitnami/mongodb --command -- mongo admin --host mongodb-1577466908 --authenticationDatabase admin -u root -p $(kubectl get secret --namespace default mongodb-1577466908 -o jsonpath="{.data.mongodb-root-password}" | base64 --decode)
If you don't see a command prompt, try pressing enter.
> db.version();
4.0.14
Stlačením ctrl+D opustíte kontajner.
Nastavenie emacsu
V zásade už bolo všetko nakonfigurované podľa v tomto článku, tak nebudem zachádzať do detailov.
Rozdelenie hry na funkcie
Interakcia s funkciami prebieha cez protokol http, end-to-end autentifikáciu medzi rôznymi funkciami zabezpečuje JWT. Mongodb sa používa na ukladanie tokenov, ako aj stavu hry, údajov hráča, sekvencií ťahov všetkých hier a ďalších informácií. Pozrime sa bližšie na najzaujímavejšie funkcie.
registrácia
Vstup tejto funkcie je JSON s prezývkou hry a heslom. Pri volaní tejto funkcie sa skontroluje, či sa tento alias nenachádza v databáze, ak je kontrola úspešná, do databázy sa vloží alias a hash hesla. Pre aktívnu účasť v hre je potrebná registrácia.
Vstup
Vstup funkcie je JSON s prezývkou hry a heslom; ak je v databáze prezývka a heslo je úspešne overené s heslom predtým uloženým v databáze, vráti sa JWT, ktorý sa musí odovzdať iným funkciám, keď sú volal. Do databázy sa vkladajú aj rôzne servisné záznamy, napríklad čas posledného prihlásenia atď.
Pozrite si zoznam hier
Každý neoprávnený používateľ si môže vyžiadať zoznam všetkých hier okrem aktívnych. Oprávnenému používateľovi sa zobrazí aj zoznam aktívnych hier. Výsledkom funkcie je JSON obsahujúci zoznamy hier (ID hry, človekom čitateľný názov atď.).
Tvorba hry
Funkcia funguje len s oprávnenými používateľmi, na vstupe je akceptovaný maximálny počet hráčov, ako aj parametre hry (napríklad, ktoré postavy v tejto hre aktivovať, maximálny počet hráčov atď.). Samostatným parametrom hry je prítomnosť hesla na pripojenie, ktoré vám umožňuje vytvárať neverejné hry. Štandardne sa vytvorí verejná hra. Výsledkom funkcie je JSON, ktorý obsahuje pole úspešnosti vytvorenia, jedinečný identifikátor hry a ďalšie parametre.
Zapojenie sa do hry
Funkcia funguje len s oprávnenými používateľmi, vstupom je ID hry a jej heslo, ak ide o neverejnú hru, výstup je JSON s parametrami hry. Oprávnený používateľ, ktorý sa do hry zapojil, ako aj tvorca hry sa ďalej nazývajú účastníci hry.
Prezeranie herných udalostí
Každý neoprávnený používateľ môže požiadať o zoznam udalostí pre neaktívne hry a autorizovaný používateľ môže získať zoznam udalostí pre akúkoľvek aktívnu hru. Doplnkovým parametrom funkcie môže byť číslo udalosti, ktoré už používateľ má. V tomto prípade sa do zoznamu vrátia len tie udalosti, ktoré sa vyskytli neskôr. Pravidelným spúšťaním tejto funkcie oprávnený používateľ sleduje, čo sa deje v hre. Táto funkcia tiež vracia požiadavku na akciu, na ktorú môže používateľ reagovať pomocou funkcie odoslania udalosti hry.
Odosielanie hernej udalosti
Funkcia funguje len pre účastníkov hry: je možné spustiť hru, urobiť ťah, hlasovať, napísať textovú správu, ktorá sa zobrazí v zozname herných udalostí atď.
Oprávnený používateľ, ktorý hru vytvoril, začne distribuovať roly všetkým účastníkom hry, vrátane seba, svoju rolu musia potvrdiť pomocou rovnakej funkcie. Po potvrdení všetkých rolí sa hra automaticky prepne do nočného režimu.
Herné štatistiky
Funkcia funguje len pre účastníkov hry, zobrazuje stav hry, zoznam a počet hráčov (prezývky), roly a ich stav (prebehnutý alebo neuskutočnený ťah), ako aj ďalšie informácie. Rovnako ako pri predchádzajúcej funkcii všetko funguje len pre účastníkov hry.
Pravidelne spúšťané funkcie
Ak hra nebola spustená po určitú dobu určenú pri vytváraní hry, automaticky sa odstráni zo zoznamu aktívnych hier pomocou funkcie clear.
Ďalšou periodickou úlohou je nútené prepínanie herného režimu z noci na deň a späť pri hrách, pri ktorých sa tak nestalo počas kola (napríklad hráč, ktorý potrebuje reagovať na hernú udalosť, z nejakého dôvodu neposlal svoje riešenie ).