Развертывание и настройка аутентификации node-red на docker-compose

от автора

Развертывание и настройка аутентификации node-red на docker-compose

Развертывания node-red на docker-compose с включением авторизации и использованием docker volume.

Создаем файл 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 | > node-red-docker@1.0.3 start /usr/src/node-red node-red_1_bca4cb987984 | > node $NODE_OPTIONS node_modules/node-red/red.js $FLOWS "--userDir" "/data" ...

Останавливаем контейнер и запускаем команду для просмотра volume:

$ docker volume ls DRIVER              VOLUME NAME local               node-red_node-red

Просматриваем детальную информацию по volume:

$ 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"     } ] 

Переходим в каталог volume. В этом каталоге уже находятся фйлы которые docker создал при развертывании контейнера.

$ sudo ls /var/lib/docker/volumes/node-red_node-red/_data lib  package.json  settings.js

Нас интересует файл settings.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: "*"         }]     }, 

В ключ password: надо вставить hash пароля node-red.

Получение hash пароля node-red

На любую машину с node.js установить пакет node-red-admin.

npm i node-red-admin -g

Запустить пакет и задать пароль:

node-red-admin hash-pw

Запускаем контейнер и подключаемся к порту 11880.

http://192.168.0.100:11880/

Должно появиться окно авторизации.

image

Вводим логин-пароль.

Если все работает, перезапускаем контейнер с ключом -d.

$ docker-compose up -d node-red

Как-то так.

ссылка на оригинал статьи https://habr.com/ru/post/508574/


Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *