Adgang til Node-RED
- Åbn din browser og gå til:
https://<SERVER_IP> - En browser-SSL-advarsel er forventet (selvsigneret certifikat)
- Godkendelse er påkrævet (Basic Auth-popup)
- Godkendelsesmetode: HTTP Basic Auth
- Legitimationsoplysninger gemmes sikkert i:
/root/.cloudzy-creds
Vigtige filer og mapper
- Hovedinstallationsmappen er
/root/node-red. - Docker-orkestrationsfilen er
/root/node-red/docker-compose.yml. - Vedvarende Node-RED-data gemmes i
/var/lib/docker/volumes/node-red_node-red-data/_data. - Nginx-konfigurationsfilen findes på
/etc/nginx/sites-available/node-red. - Legitimationsoplysninger til grundlæggende godkendelse gemmes i
/etc/nginx/auth/node-red.htpasswd. - TLS-certifikater gemmes i
/etc/nginx/ssl.
Service Management
Tjek containerstatus:
docker ps
View logs:
docker compose -f /root/node-red/docker-compose.yml logs -f
Genstart Node-RED:
docker compose -f /root/node-red/docker-compose.yml restart
Restart Nginx:
systemctl restart nginx
Node-RED Admin-bruger (alternativ til Basic Auth)
Node-RED har sit eget interne godkendelsessystem, som kan erstatte HTTP Basic Auth.
1. Locate settings.js
Hovedkonfigurationsfilen ligger inde i Node-RED Docker-volumenet: /var/lib/docker/volumes/node-red_node-red-data/_data/settings.js
2. Enable adminAuth
Open settings.js og fjern kommentering af (eller tilføj) adminAuth sektionen. Den bør se nogenlunde sådan ud:
adminAuth: {
type: "credentials",
users: [
{
username: "admin",
password: "<HASHED_PASSWORD>",
permissions: "*"
}]
},
3. Generér et password-hash
Du kan generere hash'et inde fra Node-RED-containeren:
docker exec -it node-red-node-red-1 node-red admin hash-pw
Du bliver bedt om at indtaste din adgangskode i klartekst.
Kopiér det resulterende hash og indsæt det som password value in settings.js.
4. Genstart Node-RED
After editing settings.js:
docker compose -f /root/node-red/docker-compose.yml restart
5. Deaktiver HTTP Basic Auth i Nginx (valgfrit)
Rediger Nginx-sitefilen: /etc/nginx/sites-available/node-red
Fjern eller kommenter disse linjer ud:
auth_basic "Restricted";
auth_basic_user_file /etc/nginx/auth/node-red.htpasswd;
Reload Nginx:
systemctl restart nginx
Aktivér SSL med et domæne
1. Peg dit domæne på serverens IP-adresse.
2. Rediger Nginx-konfigurationen og erstat begge server_name <IP>; med dit domæne (<your-domain>) for både HTTP- (port 80) og HTTPS-blokkene (port 443):
vim /etc/nginx/sites-available/node-red
3. Install Certbot:
apt install -y certbot python3-certbot-nginx
4. Kør følgende kommando for at generere et gyldigt Let's Encrypt-certifikat:
certbot certonly --nginx --non-interactive --agree-tos --email [email protected] -d yourdomain.com
5. Erstat SSL-stierne i Nginx-konfigurationen:
vim /etc/apache2/sites-available/node-red
# Before:
# ssl_certificate /etc/nginx/ssl/fullchain.pem;
# ssl_certificate_key /etc/nginx/ssl/privkey.pem;
# After:
# ssl_certificate /etc/letsencrypt/live/yourdomain.com/fullchain.pem;
# ssl_certificate_key /etc/letsencrypt/live/yourdomain.com/privkey.pem;
6. Genstart Nginx for at anvende ændringerne:
systemctl restart nginx
7. Åbn din browser og gå til: https://yourdomain.com