Ανάπτυξη και ρύθμιση παραμέτρων ελέγχου ταυτότητας με κόκκινο κόμβο στο docker-compose
Ανάπτυξη του node-red στο docker-compose με ενεργοποιημένη την εξουσιοδότηση και χρήση του τόμου docker.
Δημιουργήστε το αρχείο docker-compose.yml:
version: "3.7"
services:
node-red:
image: nodered/node-red
environment:
- TZ=Europe/Moscow
ports:
- "11880:1880" # 11880 - порт для подключения к контейнеру, 1880 - порт на котором работает node-red внутри контейнера.
volumes:
- "node-red:/data" # node-red - каталог который выделит docker для хранения данных, /data - каталог внутри контейнера.
restart: always
volumes:
node-red: # создание каталога node-red на хосте.
Εκκινούμε το κοντέινερ σε λειτουργία εντοπισμού σφαλμάτων (η πρώτη εκκίνηση θα πρέπει να είναι χωρίς το κλειδί «-d`, για να δείτε τα σφάλματα όταν εμφανίζονται):
$ docker-compose up node-red
Creating node-red_node-red_1_3e3e59f5e044 ... done
Attaching to node-red_node-red_1_bca4cb987984
node-red_1_bca4cb987984 |
node-red_1_bca4cb987984 | > [email protected] start /usr/src/node-red
node-red_1_bca4cb987984 | > node $NODE_OPTIONS node_modules/node-red/red.js $FLOWS "--userDir" "/data"
...
Σταματήστε το κοντέινερ και εκτελέστε την εντολή για να δείτε την ένταση:
$ docker volume ls
DRIVER VOLUME NAME
local node-red_node-red
Εξετάζουμε λεπτομερείς πληροφορίες σχετικά με τον όγκο:
$ docker volume inspect node-red_node-red
[
{
"CreatedAt": "2020-05-02T18:37:33Z",
"Driver": "local",
"Labels": {
"com.docker.compose.project": "node-red",
"com.docker.compose.version": "1.23.0",
"com.docker.compose.volume": "node-red"
},
"Mountpoint": "/var/lib/docker/volumes/node-red_node-red/_data", # расоложение нашего каталога
"Name": "node-red_node-red",
"Options": null,
"Scope": "local"
}
]
Μεταβείτε στον κατάλογο τόμου. Αυτός ο κατάλογος περιέχει ήδη τα αρχεία που δημιούργησε το docker κατά την ανάπτυξη του κοντέινερ.
$ sudo ls /var/lib/docker/volumes/node-red_node-red/_data
lib package.json settings.js
Μας ενδιαφέρει ο φάκελος ρυθμίσεις.js. Ανοίξτε το και ψάξτε για ένα κομμάτι κώδικα adminAuth. Ας το αποσχολιάζουμε.
// Securing Node-RED
// -----------------
// To password protect the Node-RED editor and admin API, the following
// property can be used. See http://nodered.org/docs/security.html for details.
adminAuth: {
type: "credentials",
users: [{
username: "admin",
password: "$2a$08$zZWtXTja0fB1pzD4sHCMyOCMYz2Z6dNbM6tl8sJogENOMcxWV9DN.",
permissions: "*"
}]
},
Στο κλειδί κωδικός: πρέπει να εισαγάγετε τον κατακερματισμό κωδικού πρόσβασης με κόκκινο κόμβο.
Λήψη κατακερματισμού κωδικού πρόσβασης με κόκκινο κόμβο
Εγκαταστήστε το πακέτο node-red-admin σε οποιοδήποτε μηχάνημα που εκτελεί το node.js.
npm i node-red-admin -g
Εκτελέστε το πακέτο και ορίστε έναν κωδικό πρόσβασης:
node-red-admin hash-pw
Εκκινήστε το δοχείο και συνδεθείτε στη θύρα 11880.
http://192.168.0.100:11880/
Θα πρέπει να εμφανιστεί ένα παράθυρο εξουσιοδότησης.
Εισαγάγετε τον κωδικό πρόσβασής σας.
Εάν όλα λειτουργούν, επανεκκινήστε το δοχείο με το κλειδί -d.
$ docker-compose up -d node-red
Κάπως έτσι.
Πηγή: www.habr.com