🎉📚 Optimized logs and CSS for Raspberry Pi performance:

This commit is contained in:
Till Tomczak 2025-06-02 07:12:50 +02:00
parent a08fe8fec4
commit 43c8c195dd
23 changed files with 1006 additions and 145 deletions

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -0,0 +1 @@

View File

@ -99,3 +99,5 @@
2025-06-01 23:53:31 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert 2025-06-01 23:53:31 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert
2025-06-01 23:55:32 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert 2025-06-01 23:55:32 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert
2025-06-01 23:56:38 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert 2025-06-01 23:56:38 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert
2025-06-02 07:05:23 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert
2025-06-02 07:10:47 - [analytics] analytics - [INFO] INFO - 📈 Analytics Engine initialisiert

View File

@ -2387,3 +2387,35 @@ WHERE jobs.status = ?) AS anon_1]
2025-06-01 23:57:22 - [app] app - [INFO] INFO - Admin-Check für Funktion admin_page: User authenticated: True, User ID: 1, Is Admin: True 2025-06-01 23:57:22 - [app] app - [INFO] INFO - Admin-Check für Funktion admin_page: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 23:57:22 - [app] app - [INFO] INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True 2025-06-01 23:57:22 - [app] app - [INFO] INFO - Admin-Check für Funktion api_admin_system_health: User authenticated: True, User ID: 1, Is Admin: True
2025-06-01 23:57:29 - [app] app - [INFO] INFO - Benutzer admin@mercedes-benz.com hat sich abgemeldet 2025-06-01 23:57:29 - [app] app - [INFO] INFO - Benutzer admin@mercedes-benz.com hat sich abgemeldet
2025-06-02 07:05:22 - [app] app - [INFO] INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-06-02 07:05:25 - [app] app - [INFO] INFO - SQLite für Raspberry Pi optimiert (reduzierte Cache-Größe, SD-Karten I/O)
2025-06-02 07:05:25 - [app] app - [INFO] INFO - ✅ Timeout Force-Quit Manager geladen
2025-06-02 07:05:25 - [app] app - [INFO] INFO - ✅ Zentraler Shutdown-Manager initialisiert
2025-06-02 07:05:25 - [app] app - [INFO] INFO - 🔄 Starte Datenbank-Setup und Migrationen...
2025-06-02 07:05:25 - [app] app - [INFO] INFO - Datenbank mit Optimierungen initialisiert
2025-06-02 07:05:25 - [app] app - [INFO] INFO - ✅ JobOrder-Tabelle bereits vorhanden
2025-06-02 07:05:25 - [app] app - [INFO] INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-06-02 07:05:25 - [app] app - [INFO] INFO - ✅ Datenbank-Setup und Migrationen erfolgreich abgeschlossen
2025-06-02 07:05:25 - [app] app - [INFO] INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-06-02 07:05:30 - [app] app - [INFO] INFO - ✅ Steckdosen-Initialisierung: 0/2 Drucker erfolgreich
2025-06-02 07:05:30 - [app] app - [WARNING] WARNING - ⚠️ 2 Drucker konnten nicht initialisiert werden
2025-06-02 07:05:30 - [app] app - [INFO] INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-06-02 07:05:30 - [app] app - [INFO] INFO - Job-Scheduler gestartet
2025-06-02 07:05:30 - [app] app - [INFO] INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-06-02 07:05:30 - [app] app - [INFO] INFO - Windows-Debug-Modus: Auto-Reload deaktiviert
2025-06-02 07:10:47 - [app] app - [INFO] INFO - Optimierte SQLite-Engine erstellt: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend\database\myp.db
2025-06-02 07:10:48 - [app] app - [INFO] INFO - SQLite für Raspberry Pi optimiert (reduzierte Cache-Größe, SD-Karten I/O)
2025-06-02 07:10:48 - [app] app - [INFO] INFO - ✅ Timeout Force-Quit Manager geladen
2025-06-02 07:10:48 - [app] app - [INFO] INFO - ✅ Zentraler Shutdown-Manager initialisiert
2025-06-02 07:10:48 - [app] app - [INFO] INFO - 🔄 Starte Datenbank-Setup und Migrationen...
2025-06-02 07:10:48 - [app] app - [INFO] INFO - Datenbank mit Optimierungen initialisiert
2025-06-02 07:10:48 - [app] app - [INFO] INFO - ✅ JobOrder-Tabelle bereits vorhanden
2025-06-02 07:10:49 - [app] app - [INFO] INFO - Admin-Benutzer admin (admin@mercedes-benz.com) existiert bereits. Passwort wurde zurückgesetzt.
2025-06-02 07:10:49 - [app] app - [INFO] INFO - ✅ Datenbank-Setup und Migrationen erfolgreich abgeschlossen
2025-06-02 07:10:49 - [app] app - [INFO] INFO - 🖨️ Starte automatische Steckdosen-Initialisierung...
2025-06-02 07:10:53 - [app] app - [INFO] INFO - ✅ Steckdosen-Initialisierung: 0/2 Drucker erfolgreich
2025-06-02 07:10:53 - [app] app - [WARNING] WARNING - ⚠️ 2 Drucker konnten nicht initialisiert werden
2025-06-02 07:10:53 - [app] app - [INFO] INFO - 🔄 Debug-Modus: Queue Manager deaktiviert für Entwicklung
2025-06-02 07:10:53 - [app] app - [INFO] INFO - Job-Scheduler gestartet
2025-06-02 07:10:53 - [app] app - [INFO] INFO - Starte Debug-Server auf 0.0.0.0:5000 (HTTP)
2025-06-02 07:10:53 - [app] app - [INFO] INFO - Windows-Debug-Modus: Auto-Reload deaktiviert

View File

@ -103,3 +103,5 @@
2025-06-01 23:53:31 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation) 2025-06-01 23:53:31 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation)
2025-06-01 23:55:32 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation) 2025-06-01 23:55:32 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation)
2025-06-01 23:56:38 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation) 2025-06-01 23:56:38 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation)
2025-06-02 07:05:23 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation)
2025-06-02 07:10:47 - [backup] backup - [INFO] INFO - BackupManager initialisiert (minimal implementation)

View File

@ -397,3 +397,11 @@
2025-06-01 23:56:38 - [dashboard] dashboard - [INFO] INFO - Dashboard-Background-Worker gestartet 2025-06-01 23:56:38 - [dashboard] dashboard - [INFO] INFO - Dashboard-Background-Worker gestartet
2025-06-01 23:56:38 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server wird mit threading initialisiert (eventlet-Fallback) 2025-06-01 23:56:38 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server wird mit threading initialisiert (eventlet-Fallback)
2025-06-01 23:56:38 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server initialisiert (async_mode: threading) 2025-06-01 23:56:38 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server initialisiert (async_mode: threading)
2025-06-02 07:05:25 - [dashboard] dashboard - [INFO] INFO - Dashboard-Background-Worker gestartet
2025-06-02 07:05:25 - [dashboard] dashboard - [INFO] INFO - Dashboard-Background-Worker gestartet
2025-06-02 07:05:25 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server wird mit threading initialisiert (eventlet-Fallback)
2025-06-02 07:05:25 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server initialisiert (async_mode: threading)
2025-06-02 07:10:48 - [dashboard] dashboard - [INFO] INFO - Dashboard-Background-Worker gestartet
2025-06-02 07:10:48 - [dashboard] dashboard - [INFO] INFO - Dashboard-Background-Worker gestartet
2025-06-02 07:10:48 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server wird mit threading initialisiert (eventlet-Fallback)
2025-06-02 07:10:48 - [dashboard] dashboard - [INFO] INFO - Dashboard WebSocket-Server initialisiert (async_mode: threading)

View File

@ -99,3 +99,5 @@
2025-06-01 23:53:31 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet 2025-06-01 23:53:31 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet
2025-06-01 23:55:32 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet 2025-06-01 23:55:32 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet
2025-06-01 23:56:38 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet 2025-06-01 23:56:38 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet
2025-06-02 07:05:23 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet
2025-06-02 07:10:47 - [database] database - [INFO] INFO - Datenbank-Wartungs-Scheduler gestartet

View File

@ -96,3 +96,5 @@
2025-06-01 23:53:32 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand) 2025-06-01 23:53:32 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand)
2025-06-01 23:55:33 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand) 2025-06-01 23:55:33 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand)
2025-06-01 23:56:38 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand) 2025-06-01 23:56:38 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand)
2025-06-02 07:05:25 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand)
2025-06-02 07:10:48 - [email_notification] email_notification - [INFO] INFO - 📧 Offline-E-Mail-Benachrichtigung initialisiert (kein echter E-Mail-Versand)

View File

@ -196,3 +196,7 @@
2025-06-01 23:55:33 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet 2025-06-01 23:55:33 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet
2025-06-01 23:56:38 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet 2025-06-01 23:56:38 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet
2025-06-01 23:56:38 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet 2025-06-01 23:56:38 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet
2025-06-02 07:05:25 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet
2025-06-02 07:05:25 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet
2025-06-02 07:10:48 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet
2025-06-02 07:10:48 - [maintenance] maintenance - [INFO] INFO - Wartungs-Scheduler gestartet

View File

@ -196,3 +196,7 @@
2025-06-01 23:55:33 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt 2025-06-01 23:55:33 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt
2025-06-01 23:56:38 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt 2025-06-01 23:56:38 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt
2025-06-01 23:56:38 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt 2025-06-01 23:56:38 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt
2025-06-02 07:05:25 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt
2025-06-02 07:05:25 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt
2025-06-02 07:10:48 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt
2025-06-02 07:10:48 - [multi_location] multi_location - [INFO] INFO - Standard-Standort erstellt

View File

@ -98,3 +98,5 @@
2025-06-01 23:53:32 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert 2025-06-01 23:53:32 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert
2025-06-01 23:55:33 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert 2025-06-01 23:55:33 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert
2025-06-01 23:56:38 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert 2025-06-01 23:56:38 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert
2025-06-02 07:05:25 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert
2025-06-02 07:10:48 - [permissions] permissions - [INFO] INFO - 🔐 Permission Template Helpers registriert

View File

@ -2818,3 +2818,33 @@
2025-06-01 23:57:04 - [printer_monitor] printer_monitor - [INFO] INFO - ✅ Status-Update abgeschlossen für 2 Drucker 2025-06-01 23:57:04 - [printer_monitor] printer_monitor - [INFO] INFO - ✅ Status-Update abgeschlossen für 2 Drucker
2025-06-01 23:57:10 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 6/6: 192.168.0.105 2025-06-01 23:57:10 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-06-01 23:57:16 - [printer_monitor] printer_monitor - [INFO] INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s 2025-06-01 23:57:16 - [printer_monitor] printer_monitor - [INFO] INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s
2025-06-02 07:05:23 - [printer_monitor] printer_monitor - [INFO] INFO - 🖨️ Drucker-Monitor initialisiert
2025-06-02 07:05:23 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-06-02 07:05:25 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-06-02 07:05:25 - [printer_monitor] printer_monitor - [INFO] INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-06-02 07:05:25 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-06-02 07:05:25 - [printer_monitor] printer_monitor - [INFO] INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-06-02 07:05:27 - [printer_monitor] printer_monitor - [WARNING] WARNING - ❌ Tapo P110 (192.168.0.103): Steckdose konnte nicht ausgeschaltet werden
2025-06-02 07:05:30 - [printer_monitor] printer_monitor - [WARNING] WARNING - ❌ Tapo P110 (192.168.0.104): Steckdose konnte nicht ausgeschaltet werden
2025-06-02 07:05:30 - [printer_monitor] printer_monitor - [INFO] INFO - 🎯 Steckdosen-Initialisierung abgeschlossen: 0/2 erfolgreich
2025-06-02 07:05:31 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 2/6: 192.168.0.104
2025-06-02 07:05:37 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 3/6: 192.168.0.100
2025-06-02 07:05:43 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 4/6: 192.168.0.101
2025-06-02 07:05:49 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 5/6: 192.168.0.102
2025-06-02 07:05:55 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-06-02 07:06:01 - [printer_monitor] printer_monitor - [INFO] INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.2s
2025-06-02 07:10:47 - [printer_monitor] printer_monitor - [INFO] INFO - 🖨️ Drucker-Monitor initialisiert
2025-06-02 07:10:47 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Automatische Tapo-Erkennung in separatem Thread gestartet
2025-06-02 07:10:49 - [printer_monitor] printer_monitor - [INFO] INFO - 🚀 Starte Steckdosen-Initialisierung beim Programmstart...
2025-06-02 07:10:49 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Starte automatische Tapo-Steckdosenerkennung...
2025-06-02 07:10:49 - [printer_monitor] printer_monitor - [INFO] INFO - 🔄 Teste 6 Standard-IPs aus der Konfiguration
2025-06-02 07:10:49 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 1/6: 192.168.0.103
2025-06-02 07:10:51 - [printer_monitor] printer_monitor - [WARNING] WARNING - ❌ Tapo P110 (192.168.0.103): Steckdose konnte nicht ausgeschaltet werden
2025-06-02 07:10:53 - [printer_monitor] printer_monitor - [WARNING] WARNING - ❌ Tapo P110 (192.168.0.104): Steckdose konnte nicht ausgeschaltet werden
2025-06-02 07:10:53 - [printer_monitor] printer_monitor - [INFO] INFO - 🎯 Steckdosen-Initialisierung abgeschlossen: 0/2 erfolgreich
2025-06-02 07:10:55 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 2/6: 192.168.0.104
2025-06-02 07:11:01 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 3/6: 192.168.0.100
2025-06-02 07:11:07 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 4/6: 192.168.0.101
2025-06-02 07:11:13 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 5/6: 192.168.0.102
2025-06-02 07:11:19 - [printer_monitor] printer_monitor - [INFO] INFO - 🔍 Teste IP 6/6: 192.168.0.105
2025-06-02 07:11:25 - [printer_monitor] printer_monitor - [INFO] INFO - ✅ Steckdosen-Erkennung abgeschlossen: 0/6 Steckdosen gefunden in 36.1s

View File

@ -13635,3 +13635,446 @@
2025-06-01 23:57:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000002605A632BE0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)')) 2025-06-01 23:57:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000002605A632BE0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-01 23:57:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten 2025-06-01 23:57:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-01 23:57:41 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee 2025-06-01 23:57:41 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:05:23 - [scheduler] scheduler - [INFO] INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-06-02 07:05:30 - [scheduler] scheduler - [INFO] INFO - Scheduler-Thread gestartet
2025-06-02 07:05:30 - [scheduler] scheduler - [INFO] INFO - Scheduler gestartet
2025-06-02 07:05:30 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:05:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC3B9450>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:05:32 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:05:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC37F5C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:05:34 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:05:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC45C180>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:05:36 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:05:38 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4C8EF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:38 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:05:38 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:05:40 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:40 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:05:40 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:05:42 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425590>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:42 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:05:42 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:05:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426030>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:05:45 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:05:47 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426580>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:47 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:05:47 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:05:49 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4267A0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:05:49 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:05:49 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:05:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426BE0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:05:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:05:51 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:05:53 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4268B0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:05:53 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:05:53 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:05:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426140>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:05:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:05:55 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:05:57 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426690>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:05:57 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:05:57 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:06:00 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425260>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:00 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:06:00 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:06:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425590>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:06:02 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:06:04 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425AE0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:04 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:06:05 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:06:07 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:07 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:06:07 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:06:09 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425370>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:09 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:06:09 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:06:11 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427130>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:11 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:06:11 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:06:13 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426E00>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:13 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:06:13 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:06:15 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427350>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:15 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:06:15 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:06:17 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426F10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:17 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:06:17 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:06:19 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426CF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:19 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:06:19 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:06:22 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426250>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:22 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:06:22 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:06:24 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:06:24 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:06:24 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:06:26 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:06:26 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:06:26 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:06:28 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425AE0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:06:28 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:06:28 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:06:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424C00>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:06:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:06:30 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:06:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:06:32 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:06:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4259D0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:06:34 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:06:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4269C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:06:36 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:06:38 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4259D0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:38 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:06:39 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:06:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426690>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:06:41 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:06:43 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424C00>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:43 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:06:43 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:06:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425AE0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:06:45 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:06:48 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:48 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:06:48 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:06:50 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:50 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:06:50 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:06:52 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426250>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:52 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:06:52 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:06:54 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426CF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:54 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:06:54 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:06:56 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426F10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:06:56 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:06:56 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:06:58 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427240>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:06:58 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:06:58 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:07:00 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4267A0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:00 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:07:00 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:07:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426AD0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:07:02 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:07:05 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427350>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:05 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:07:05 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:07:07 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4257B0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:07 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:07:07 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:07:09 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425BF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:09 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:07:09 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:07:11 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4247C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:11 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:07:11 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:07:13 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4258C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:13 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:07:14 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:07:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425AE0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:07:16 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:07:18 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426360>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:18 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:07:18 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:07:20 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426030>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:20 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:07:20 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:07:23 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426470>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:23 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:07:23 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:07:25 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426580>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:25 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:07:25 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:07:27 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427570>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:27 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:07:27 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:07:29 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426BE0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:29 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:07:29 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:07:31 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4268B0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:31 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:07:31 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:07:33 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426030>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:33 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:07:33 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:07:35 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:35 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:07:35 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:07:37 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425260>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:37 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:07:37 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:07:40 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424E20>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:07:40 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:07:40 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:07:42 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425590>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:42 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:07:42 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:07:44 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425F20>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:44 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:07:44 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:07:46 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC425370>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:46 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:07:46 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:07:48 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427130>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:48 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:07:49 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:07:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426AD0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:07:51 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:07:53 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427240>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:53 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:07:53 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:07:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426F10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:07:55 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:07:58 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426CF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:07:58 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:07:58 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:08:00 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426250>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:00 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:08:00 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:08:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:08:02 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:08:04 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:04 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:08:04 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:08:06 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424D10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:06 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:08:06 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:08:08 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426030>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:08 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:08:08 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:08:10 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426690>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:10 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:08:10 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:08:12 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4259D0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:12 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:08:12 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:08:14 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426580>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:14 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:08:14 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:08:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4279B0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:08:16 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:08:19 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426580>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:19 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:08:19 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:08:21 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4259D0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:21 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:08:21 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:08:23 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426690>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:23 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:08:24 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:08:26 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424C00>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:26 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:08:26 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:08:28 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424D10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:28 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:08:28 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:08:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:08:30 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:08:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:08:32 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:08:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426140>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:08:34 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:08:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426470>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:08:36 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:08:39 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4269C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:39 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:08:39 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:08:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424D10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:08:41 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:08:43 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426030>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:43 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:08:43 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:08:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426140>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:08:45 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:08:47 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4249E0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:47 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:08:47 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:08:49 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:08:49 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:08:49 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:08:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4269C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:08:51 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:08:53 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:53 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:08:53 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:08:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426140>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:08:55 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:08:58 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:08:58 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:08:59 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:09:01 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426140>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:01 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:09:01 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:09:03 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427460>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:03 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:09:03 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:09:05 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:05 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:09:05 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:09:07 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426690>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:07 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:09:07 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:09:09 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427680>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:09 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:09:09 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:09:12 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426580>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:12 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:09:12 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:09:14 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4279B0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:14 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:09:14 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:09:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426360>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:09:16 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:09:18 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4269C0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:09:18 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:09:18 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:09:20 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426470>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:09:20 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:09:20 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:09:22 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:09:22 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:09:22 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:09:24 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427790>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:09:24 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:09:24 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:09:26 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424AF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:26 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:09:26 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:09:28 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424D10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:28 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:09:28 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:09:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427790>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:09:30 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:09:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:09:33 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:09:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4267A0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:36 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:09:36 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:09:38 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427790>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:38 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:09:38 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:09:40 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC424D10>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:40 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:09:40 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:09:42 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC426690>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:42 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:09:42 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:09:44 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC427680>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:44 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:09:44 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:09:46 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x0000024BCC4245A0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:09:46 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:09:46 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:10:47 - [scheduler] scheduler - [INFO] INFO - Task check_jobs registriert: Intervall 30s, Enabled: True
2025-06-02 07:10:53 - [scheduler] scheduler - [INFO] INFO - Scheduler-Thread gestartet
2025-06-02 07:10:53 - [scheduler] scheduler - [INFO] INFO - Scheduler gestartet
2025-06-02 07:10:53 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:10:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E409450>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:10:55 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:10:55 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:10:57 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E3CF5C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:10:57 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:10:57 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:10:59 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E515BA0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:10:59 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:10:59 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:11:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4032F0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:02 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:11:02 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:11:04 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E476BE0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:04 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:11:04 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:11:06 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477350>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:06 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:11:06 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:11:08 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477790>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:08 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:11:08 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:11:10 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477AC0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:10 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:11:10 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:11:12 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477680>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:12 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:11:12 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:11:14 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4749E0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:14 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:11:14 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:11:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4748D0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:16 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:11:16 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee
2025-06-02 07:11:18 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477460>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:18 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 12 nicht einschalten
2025-06-02 07:11:18 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 13: e2
2025-06-02 07:11:21 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4747C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:21 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 13 nicht einschalten
2025-06-02 07:11:21 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 14: e2
2025-06-02 07:11:23 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E475040>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:23 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 14 nicht einschalten
2025-06-02 07:11:23 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 15: test
2025-06-02 07:11:25 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E475BF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:25 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 15 nicht einschalten
2025-06-02 07:11:25 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 16: test
2025-06-02 07:11:27 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E475590>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:27 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 16 nicht einschalten
2025-06-02 07:11:28 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 7: test
2025-06-02 07:11:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E476470>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:30 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 7 nicht einschalten
2025-06-02 07:11:30 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 8: test
2025-06-02 07:11:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E476140>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:32 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 8 nicht einschalten
2025-06-02 07:11:32 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 1: test
2025-06-02 07:11:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E475590>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:34 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 1 nicht einschalten
2025-06-02 07:11:34 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 2: test
2025-06-02 07:11:37 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E475BF0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:37 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 2 nicht einschalten
2025-06-02 07:11:37 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 3: test
2025-06-02 07:11:39 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E475040>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:39 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 3 nicht einschalten
2025-06-02 07:11:39 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 4: test
2025-06-02 07:11:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4747C0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:41 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 4 nicht einschalten
2025-06-02 07:11:41 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 5: test
2025-06-02 07:11:43 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477460>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:43 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 5 nicht einschalten
2025-06-02 07:11:43 - [scheduler] scheduler - [INFO] INFO - 🚀 Starte geplanten Job 6: test
2025-06-02 07:11:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.103: HTTPConnectionPool(host='192.168.0.103', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4748D0>, 'Connection to 192.168.0.103 timed out. (connect timeout=2)'))
2025-06-02 07:11:45 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Job 6 nicht einschalten
2025-06-02 07:11:45 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 9: zi
2025-06-02 07:11:47 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477570>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:47 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 9 nicht einschalten
2025-06-02 07:11:47 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 10: zi
2025-06-02 07:11:49 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E477680>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:49 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 10 nicht einschalten
2025-06-02 07:11:49 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 11: fee
2025-06-02 07:11:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Fehler beim einschalten der Tapo-Steckdose 192.168.0.104: HTTPConnectionPool(host='192.168.0.104', port=80): Max retries exceeded with url: /app (Caused by ConnectTimeoutError(<urllib3.connection.HTTPConnection object at 0x000001DF9E4749E0>, 'Connection to 192.168.0.104 timed out. (connect timeout=2)'))
2025-06-02 07:11:51 - [scheduler] scheduler - [ERROR] ERROR - ❌ Konnte Steckdose für Sofort-Job 11 nicht einschalten
2025-06-02 07:11:51 - [scheduler] scheduler - [INFO] INFO - ⚡ Starte Sofort-Job 12: fee

View File

@ -98,3 +98,5 @@
2025-06-01 23:53:32 - [security] security - [INFO] INFO - 🔒 Security System initialisiert 2025-06-01 23:53:32 - [security] security - [INFO] INFO - 🔒 Security System initialisiert
2025-06-01 23:55:33 - [security] security - [INFO] INFO - 🔒 Security System initialisiert 2025-06-01 23:55:33 - [security] security - [INFO] INFO - 🔒 Security System initialisiert
2025-06-01 23:56:38 - [security] security - [INFO] INFO - 🔒 Security System initialisiert 2025-06-01 23:56:38 - [security] security - [INFO] INFO - 🔒 Security System initialisiert
2025-06-02 07:05:25 - [security] security - [INFO] INFO - 🔒 Security System initialisiert
2025-06-02 07:10:48 - [security] security - [INFO] INFO - 🔒 Security System initialisiert

View File

@ -184,3 +184,5 @@
2025-06-01 23:53:32 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert 2025-06-01 23:53:32 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert
2025-06-01 23:55:33 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert 2025-06-01 23:55:33 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert
2025-06-01 23:56:38 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert 2025-06-01 23:56:38 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert
2025-06-02 07:05:25 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert
2025-06-02 07:10:48 - [shutdown_manager] shutdown_manager - [INFO] INFO - 🔧 Shutdown-Manager initialisiert

View File

@ -890,3 +890,21 @@
2025-06-01 23:56:38 - [startup] startup - [INFO] INFO - 🪟 Windows-Modus: Aktiviert 2025-06-01 23:56:38 - [startup] startup - [INFO] INFO - 🪟 Windows-Modus: Aktiviert
2025-06-01 23:56:38 - [startup] startup - [INFO] INFO - 🔒 Windows-sichere Log-Rotation: Aktiviert 2025-06-01 23:56:38 - [startup] startup - [INFO] INFO - 🔒 Windows-sichere Log-Rotation: Aktiviert
2025-06-01 23:56:38 - [startup] startup - [INFO] INFO - ================================================== 2025-06-01 23:56:38 - [startup] startup - [INFO] INFO - ==================================================
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - ==================================================
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - 🚀 MYP Platform Backend wird gestartet...
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - 🐍 Python Version: 3.13.3 (tags/v3.13.3:6280bb5, Apr 8 2025, 14:47:33) [MSC v.1943 64 bit (AMD64)]
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - 💻 Betriebssystem: nt (win32)
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - 📁 Arbeitsverzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - ⏰ Startzeit: 2025-06-02T07:05:25.336182
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - 🪟 Windows-Modus: Aktiviert
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - 🔒 Windows-sichere Log-Rotation: Aktiviert
2025-06-02 07:05:25 - [startup] startup - [INFO] INFO - ==================================================
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - ==================================================
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - 🚀 MYP Platform Backend wird gestartet...
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - 🐍 Python Version: 3.13.3 (tags/v3.13.3:6280bb5, Apr 8 2025, 14:47:33) [MSC v.1943 64 bit (AMD64)]
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - 💻 Betriebssystem: nt (win32)
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - 📁 Arbeitsverzeichnis: C:\Users\TTOMCZA.EMEA\Dev\Projektarbeit-MYP\backend
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - ⏰ Startzeit: 2025-06-02T07:10:48.570452
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - 🪟 Windows-Modus: Aktiviert
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - 🔒 Windows-sichere Log-Rotation: Aktiviert
2025-06-02 07:10:48 - [startup] startup - [INFO] INFO - ==================================================

View File

@ -423,3 +423,11 @@
2025-06-01 23:56:37 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen) 2025-06-01 23:56:37 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-06-01 23:56:37 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Globaler subprocess-Patch angewendet 2025-06-01 23:56:37 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Globaler subprocess-Patch angewendet
2025-06-01 23:56:37 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Alle Windows-Fixes erfolgreich angewendet 2025-06-01 23:56:37 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-06-02 07:05:22 - [windows_fixes] windows_fixes - [INFO] INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-06-02 07:05:22 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-06-02 07:05:22 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Globaler subprocess-Patch angewendet
2025-06-02 07:05:22 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Alle Windows-Fixes erfolgreich angewendet
2025-06-02 07:10:47 - [windows_fixes] windows_fixes - [INFO] INFO - 🔧 Wende Windows-spezifische Fixes an...
2025-06-02 07:10:47 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Subprocess automatisch gepatcht für UTF-8 Encoding (run + Popen)
2025-06-02 07:10:47 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Globaler subprocess-Patch angewendet
2025-06-02 07:10:47 - [windows_fixes] windows_fixes - [INFO] INFO - ✅ Alle Windows-Fixes erfolgreich angewendet

View File

@ -1,182 +1,208 @@
/* Raspberry Pi optimierte Glassmorphism-Ersatz Effekte für MYP Application */ /* Vereinfachte Glassmorphism-Effekte für MYP Application */
/* ===== VEREINFACHTE BASIS EFFEKTE (ohne backdrop-filter) ===== */ /* ===== BASIS GLASS EFFEKTE ===== */
.glass-base { .glass-base {
background: rgba(255, 255, 255, 0.95); background: rgba(255, 255, 255, 0.85);
border: 1px solid rgba(229, 231, 235, 0.6); backdrop-filter: blur(10px);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); -webkit-backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.3);
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
transition: all 0.2s ease;
} }
.glass-strong { .glass-strong {
background: rgba(255, 255, 255, 0.98); background: rgba(255, 255, 255, 0.9);
border: 1px solid rgba(229, 231, 235, 0.8); backdrop-filter: blur(12px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06); -webkit-backdrop-filter: blur(12px);
border: 1px solid rgba(255, 255, 255, 0.4);
box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
} }
.glass-subtle { .glass-subtle {
background: rgba(255, 255, 255, 0.92); background: rgba(255, 255, 255, 0.8);
border: 1px solid rgba(229, 231, 235, 0.4); backdrop-filter: blur(8px);
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.03); -webkit-backdrop-filter: blur(8px);
} border: 1px solid rgba(255, 255, 255, 0.2);
/* ===== DARK MODE VEREINFACHT ===== */
.dark .glass-base {
background: rgba(15, 23, 42, 0.95);
border: 1px solid rgba(51, 65, 85, 0.6);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
.dark .glass-strong {
background: rgba(30, 41, 59, 0.98);
border: 1px solid rgba(71, 85, 105, 0.8);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
.dark .glass-subtle {
background: rgba(15, 23, 42, 0.9);
border: 1px solid rgba(51, 65, 85, 0.4);
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}
/* ===== EINFACHE KARTEN (ohne Hover-Transforms) ===== */
.glass-card {
background: rgba(255, 255, 255, 0.98);
border: 1px solid rgba(229, 231, 235, 0.6);
border-radius: 12px;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
padding: 1.5rem;
}
.glass-card:hover {
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
} }
/* ===== DARK MODE GLASS ===== */
.dark .glass-base {
background: rgba(15, 23, 42, 0.8);
border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}
.dark .glass-strong {
background: rgba(30, 41, 59, 0.85);
border: 1px solid rgba(255, 255, 255, 0.15);
box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4);
}
.dark .glass-subtle {
background: rgba(15, 23, 42, 0.7);
border: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}
/* ===== GLASS KARTEN ===== */
.glass-card {
background: rgba(255, 255, 255, 0.9);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border: 1px solid rgba(229, 231, 235, 0.5);
border-radius: 12px;
box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
padding: 1.5rem;
transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.glass-card:hover {
transform: translateY(-1px);
box-shadow: 0 12px 20px rgba(0, 0, 0, 0.12);
}
.dark .glass-card { .dark .glass-card {
background: rgba(30, 41, 59, 0.95); background: rgba(30, 41, 59, 0.85);
border: 1px solid rgba(71, 85, 105, 0.6); border: 1px solid rgba(100, 116, 139, 0.3);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2); box-shadow: 0 8px 16px rgba(0, 0, 0, 0.25);
} }
.dark .glass-card:hover { .dark .glass-card:hover {
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3); box-shadow: 0 12px 20px rgba(0, 0, 0, 0.35);
} }
/* ===== VEREINFACHTE NAVIGATION ===== */ /* ===== GLASS NAVIGATION ===== */
.glass-nav { .glass-nav {
background: rgba(255, 255, 255, 0.98); background: rgba(255, 255, 255, 0.9);
border: 1px solid rgba(226, 232, 240, 0.6); backdrop-filter: blur(12px);
border-bottom: 1px solid rgba(203, 213, 225, 0.8); -webkit-backdrop-filter: blur(12px);
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.03); border: 1px solid rgba(226, 232, 240, 0.4);
border-bottom: 1px solid rgba(203, 213, 225, 0.5);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
} }
.dark .glass-nav { .dark .glass-nav {
background: rgba(15, 23, 42, 0.95); background: rgba(15, 23, 42, 0.85);
border: 1px solid rgba(51, 65, 85, 0.6); border: 1px solid rgba(51, 65, 85, 0.5);
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
} }
/* ===== EINFACHE BUTTONS (ohne Transform) ===== */ /* ===== GLASS BUTTONS ===== */
.glass-btn { .glass-btn {
background: rgba(255, 255, 255, 0.95); background: rgba(255, 255, 255, 0.8);
border: 1px solid rgba(226, 232, 240, 0.6); backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
border: 1px solid rgba(226, 232, 240, 0.5);
border-radius: 8px; border-radius: 8px;
padding: 0.75rem 1.5rem; padding: 0.75rem 1.5rem;
color: #0f172a; color: #0f172a;
font-weight: 600; font-weight: 600;
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.03); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
transition: transform 0.2s ease, background 0.2s ease;
} }
.glass-btn:hover { .glass-btn:hover {
background: rgba(255, 255, 255, 1); transform: translateY(-1px);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); background: rgba(255, 255, 255, 0.9);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
} }
.glass-btn-primary { .glass-btn-primary {
background: rgba(0, 115, 206, 0.95); background: rgba(0, 115, 206, 0.9);
color: white; color: white;
box-shadow: 0 1px 4px rgba(0, 115, 206, 0.2); box-shadow: 0 2px 8px rgba(0, 115, 206, 0.2);
} }
.glass-btn-primary:hover { .glass-btn-primary:hover {
background: rgba(0, 115, 206, 1); background: rgba(0, 115, 206, 0.95);
box-shadow: 0 2px 8px rgba(0, 115, 206, 0.3); box-shadow: 0 4px 12px rgba(0, 115, 206, 0.3);
} }
.dark .glass-btn { .dark .glass-btn {
background: rgba(30, 41, 59, 0.95); background: rgba(30, 41, 59, 0.8);
color: #e2e8f0; color: #e2e8f0;
border: 1px solid rgba(100, 116, 139, 0.6); border: 1px solid rgba(100, 116, 139, 0.5);
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
} }
.dark .glass-btn:hover { .dark .glass-btn:hover {
background: rgba(30, 41, 59, 1); background: rgba(30, 41, 59, 0.9);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
} }
/* ===== EINFACHE MODALS ===== */ /* ===== GLASS MODALS ===== */
.glass-modal { .glass-modal {
background: rgba(255, 255, 255, 0.98); background: rgba(255, 255, 255, 0.95);
border: 1px solid rgba(226, 232, 240, 0.8); backdrop-filter: blur(16px);
-webkit-backdrop-filter: blur(16px);
border: 1px solid rgba(226, 232, 240, 0.6);
border-radius: 16px; border-radius: 16px;
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
} }
.dark .glass-modal { .dark .glass-modal {
background: rgba(15, 23, 42, 0.98); background: rgba(15, 23, 42, 0.95);
border: 1px solid rgba(51, 65, 85, 0.8); border: 1px solid rgba(51, 65, 85, 0.6);
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4);
} }
/* ===== VEREINFACHTE FORM ELEMENTE ===== */ /* ===== GLASS FORM ELEMENTE ===== */
.glass-input { .glass-input {
background: rgba(255, 255, 255, 0.95); background: rgba(255, 255, 255, 0.8);
border: 1px solid rgba(226, 232, 240, 0.6); backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
border: 1px solid rgba(226, 232, 240, 0.5);
border-radius: 6px; border-radius: 6px;
padding: 0.75rem 1rem; padding: 0.75rem 1rem;
color: #0f172a; color: #0f172a;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.02); box-shadow: 0 2px 4px rgba(0, 0, 0, 0.04);
transition: border-color 0.2s ease, box-shadow 0.2s ease;
} }
.glass-input:focus { .glass-input:focus {
outline: none; outline: none;
border-color: rgba(0, 115, 206, 0.6); border-color: rgba(0, 115, 206, 0.5);
box-shadow: 0 0 0 2px rgba(0, 115, 206, 0.1); box-shadow: 0 2px 8px rgba(0, 115, 206, 0.1);
} }
.dark .glass-input { .dark .glass-input {
background: rgba(30, 41, 59, 0.95); background: rgba(30, 41, 59, 0.8);
border: 1px solid rgba(100, 116, 139, 0.6); border: 1px solid rgba(100, 116, 139, 0.5);
color: #e2e8f0; color: #e2e8f0;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1); box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
} }
.dark .glass-input:focus { .dark .glass-input:focus {
border-color: rgba(59, 130, 246, 0.6); border-color: rgba(59, 130, 246, 0.5);
box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1); box-shadow: 0 2px 8px rgba(59, 130, 246, 0.15);
} }
/* ===== EINFACHE DROPDOWN ===== */ /* ===== GLASS DROPDOWN ===== */
.glass-dropdown { .glass-dropdown {
background: rgba(255, 255, 255, 0.98); background: rgba(255, 255, 255, 0.9);
border: 1px solid rgba(226, 232, 240, 0.6); backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border: 1px solid rgba(255, 255, 255, 0.3);
border-radius: 8px; border-radius: 8px;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
} }
.dark .glass-dropdown { .dark .glass-dropdown {
background: rgba(15, 23, 42, 0.98); background: rgba(15, 23, 42, 0.9);
border: 1px solid rgba(51, 65, 85, 0.6); border: 1px solid rgba(255, 255, 255, 0.1);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
} }
/* ===== UTILITY CLASSES ===== */ /* ===== UTILITY CLASSES ===== */
.glass-overlay { .glass-overlay {
background: rgba(255, 255, 255, 0.8); background: rgba(255, 255, 255, 0.1);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
} }
.dark .glass-overlay { .dark .glass-overlay {
background: rgba(0, 0, 0, 0.8); background: rgba(0, 0, 0, 0.2);
} }
/* ===== RESPONSIVE ANPASSUNGEN ===== */ /* ===== RESPONSIVE ANPASSUNGEN ===== */
@ -189,11 +215,41 @@
.glass-modal { .glass-modal {
border-radius: 12px; border-radius: 12px;
} }
.glass-base,
.glass-strong,
.glass-subtle {
backdrop-filter: blur(6px);
-webkit-backdrop-filter: blur(6px);
}
} }
/* ===== REDUZIERTE BEWEGUNG ===== */ /* ===== REDUZIERTE BEWEGUNG ===== */
@media (prefers-reduced-motion: reduce) { @media (prefers-reduced-motion: reduce) {
* { .glass-card,
.glass-btn,
.glass-input {
transition: none !important; transition: none !important;
} }
} }
/* ===== HOHER KONTRAST MODUS ===== */
@media (prefers-contrast: high) {
.glass-base,
.glass-strong,
.glass-card {
border-width: 2px;
backdrop-filter: blur(4px);
-webkit-backdrop-filter: blur(4px);
}
}
/* ===== PERFORMANCE OPTIMIERUNGEN ===== */
.glass-base,
.glass-strong,
.glass-subtle,
.glass-card,
.glass-btn,
.glass-modal {
will-change: transform;
}

View File

@ -65,55 +65,50 @@
box-shadow: 0 8px 20px var(--dark-shadow); box-shadow: 0 8px 20px var(--dark-shadow);
} }
/* Vereinfachte Container */ /* Raspberry Pi optimierte Container */
.professional-container { .professional-container {
background: var(--light-surface); background: var(--light-surface);
border: 1px solid var(--light-border); border: 1px solid var(--light-border);
border-radius: 0.75rem; border-radius: 0.75rem;
box-shadow: 0 2px 8px var(--light-shadow); box-shadow: 0 1px 4px var(--light-shadow);
transition: transform 0.2s ease, box-shadow 0.2s ease;
} }
.dark .professional-container { .dark .professional-container {
background: var(--dark-surface); background: var(--dark-surface);
border: 1px solid var(--dark-border); border: 1px solid var(--dark-border);
box-shadow: 0 4px 12px var(--dark-shadow); box-shadow: 0 2px 8px var(--dark-shadow);
} }
.professional-container:hover { .professional-container:hover {
transform: translateY(-1px); box-shadow: 0 2px 8px var(--light-shadow-strong);
box-shadow: 0 4px 16px var(--light-shadow-strong);
} }
.dark .professional-container:hover { .dark .professional-container:hover {
box-shadow: 0 8px 20px var(--dark-shadow-strong); box-shadow: 0 8px 20px var(--dark-shadow-strong);
} }
/* Vereinfachte Glassmorphism-Effekte */ /* Raspberry Pi optimierte Glassmorphism-Ersatz */
.mb-glass { .mb-glass {
background: rgba(255, 255, 255, 0.9); background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(8px); border: 1px solid rgba(229, 231, 235, 0.6);
border: 1px solid rgba(229, 231, 235, 0.4); box-shadow: 0 1px 4px rgba(0, 0, 0, 0.03);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
transition: transform 0.2s ease, background 0.2s ease;
} }
.dark .mb-glass { .dark .mb-glass {
background: rgba(15, 23, 42, 0.85); background: rgba(15, 23, 42, 0.95);
border: 1px solid rgba(255, 255, 255, 0.1); border: 1px solid rgba(51, 65, 85, 0.6);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
} }
.mb-glass:hover { .mb-glass:hover {
background: rgba(255, 255, 255, 0.95); background: rgba(255, 255, 255, 1);
transform: translateY(-1px);
} }
.dark .mb-glass:hover { .dark .mb-glass:hover {
background: rgba(15, 23, 42, 0.9); background: rgba(15, 23, 42, 1);
} }
/* Vereinfachte Buttons */ /* Raspberry Pi optimierte Buttons */
.btn-professional { .btn-professional {
background: linear-gradient(135deg, var(--mb-primary) 0%, var(--mb-primary-dark) 100%); background: linear-gradient(135deg, var(--mb-primary) 0%, var(--mb-primary-dark) 100%);
color: white; color: white;
@ -124,17 +119,15 @@
font-size: 0.875rem; font-size: 0.875rem;
text-transform: uppercase; text-transform: uppercase;
letter-spacing: 0.025em; letter-spacing: 0.025em;
transition: transform 0.2s ease, box-shadow 0.2s ease; box-shadow: 0 1px 4px rgba(0, 115, 206, 0.2);
box-shadow: 0 2px 8px rgba(0, 115, 206, 0.2);
} }
.btn-professional:hover { .btn-professional:hover {
transform: translateY(-1px); box-shadow: 0 2px 8px rgba(0, 115, 206, 0.3);
box-shadow: 0 4px 12px rgba(0, 115, 206, 0.3);
} }
.btn-professional:active { .btn-professional:active {
transform: translateY(0); box-shadow: 0 1px 2px rgba(0, 115, 206, 0.3);
} }
/* Secondary Button */ /* Secondary Button */
@ -160,7 +153,6 @@
.btn-secondary-professional:hover { .btn-secondary-professional:hover {
background: var(--light-surface-hover); background: var(--light-surface-hover);
border-color: var(--mb-primary); border-color: var(--mb-primary);
transform: translateY(-1px);
} }
.dark .btn-secondary-professional:hover { .dark .btn-secondary-professional:hover {
@ -188,8 +180,7 @@
.input-professional:focus { .input-professional:focus {
border-color: var(--mb-primary); border-color: var(--mb-primary);
box-shadow: 0 0 0 3px rgba(0, 115, 206, 0.1); box-shadow: 0 0 0 2px rgba(0, 115, 206, 0.1);
transform: translateY(-1px);
} }
.input-professional::placeholder { .input-professional::placeholder {
@ -200,19 +191,17 @@
color: var(--dark-text-muted); color: var(--dark-text-muted);
} }
/* Vereinfachte Cards */ /* Raspberry Pi optimierte Cards */
.card-professional { .card-professional {
background: var(--light-surface); background: var(--light-surface);
border: 1px solid var(--light-border); border: 1px solid var(--light-border);
border-radius: 0.75rem; border-radius: 0.75rem;
padding: 1.5rem; padding: 1.5rem;
box-shadow: 0 2px 8px var(--light-shadow); box-shadow: 0 1px 4px var(--light-shadow);
transition: transform 0.2s ease, box-shadow 0.2s ease;
} }
.card-professional:hover { .card-professional:hover {
transform: translateY(-2px); box-shadow: 0 2px 8px var(--light-shadow-strong);
box-shadow: 0 4px 16px var(--light-shadow-strong);
} }
.dark .card-professional { .dark .card-professional {
@ -221,30 +210,28 @@
box-shadow: 0 4px 12px var(--dark-shadow); box-shadow: 0 4px 12px var(--dark-shadow);
} }
/* Vereinfachte Statistics Cards */ /* Raspberry Pi optimierte Statistics Cards */
.stat-card { .stat-card {
background: var(--light-surface); background: var(--light-surface);
border: 1px solid var(--light-border); border: 1px solid var(--light-border);
border-radius: 0.75rem; border-radius: 0.75rem;
padding: 1.5rem; padding: 1.5rem;
text-align: center; text-align: center;
transition: transform 0.2s ease, box-shadow 0.2s ease; box-shadow: 0 1px 4px var(--light-shadow);
box-shadow: 0 2px 8px var(--light-shadow);
} }
.dark .stat-card { .dark .stat-card {
background: var(--dark-surface); background: var(--dark-surface);
border-color: var(--dark-border); border-color: var(--dark-border);
box-shadow: 0 4px 12px var(--dark-shadow); box-shadow: 0 2px 8px var(--dark-shadow);
} }
.stat-card:hover { .stat-card:hover {
transform: translateY(-1px); box-shadow: 0 2px 8px var(--light-shadow-strong);
box-shadow: 0 4px 16px var(--light-shadow-strong);
} }
.dark .stat-card:hover { .dark .stat-card:hover {
box-shadow: 0 8px 20px var(--dark-shadow-strong); box-shadow: 0 4px 12px var(--dark-shadow-strong);
} }
.stat-number { .stat-number {
@ -271,7 +258,7 @@
color: var(--dark-text-muted); color: var(--dark-text-muted);
} }
/* Vereinfachte Status Badges */ /* Raspberry Pi optimierte Status Badges */
.status-professional { .status-professional {
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
@ -282,13 +269,10 @@
font-weight: 600; font-weight: 600;
text-transform: uppercase; text-transform: uppercase;
letter-spacing: 0.05em; letter-spacing: 0.05em;
transition: transform 0.2s ease;
border: 1px solid transparent; border: 1px solid transparent;
} }
.status-professional:hover { /* Status hover-effect entfernt für bessere Performance */
transform: scale(1.02);
}
/* Status Indicators */ /* Status Indicators */
.status-online { .status-online {
@ -387,8 +371,7 @@
.nav-item-professional:hover { .nav-item-professional:hover {
background: var(--light-surface-hover); background: var(--light-surface-hover);
color: var(--light-text-primary); color: var(--light-text-primary);
transform: translateX(4px); box-shadow: 0 1px 4px var(--light-shadow);
box-shadow: 0 2px 8px var(--light-shadow);
} }
.dark .nav-item-professional:hover { .dark .nav-item-professional:hover {
@ -464,8 +447,6 @@
.table-professional tbody tr:hover { .table-professional tbody tr:hover {
background: var(--light-surface-hover); background: var(--light-surface-hover);
transform: scale(1.005);
box-shadow: 0 2px 8px var(--light-shadow);
} }
.dark .table-professional tbody tr:hover { .dark .table-professional tbody tr:hover {

View File

@ -0,0 +1,260 @@
/**
* Mercedes-Benz MYP Platform - Ausgewogene Raspberry Pi Performance Optimierungen
* Optimierte Performance bei Erhaltung des visuellen Designs
*/
/* ===== SCHONENDE BROWSER OPTIMIERUNGEN ===== */
/* Reduzierte GPU-Layer Optimierung */
.professional-hero,
.professional-container,
.card-professional,
.stat-card,
.glass-card,
.glass-modal {
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
/* Entferne will-change nur bei problematischen Elementen */
.glass-base,
.glass-strong,
.glass-subtle {
will-change: auto !important;
}
/* Sanfte Scroll-Performance */
html {
scroll-behavior: auto;
}
body {
overflow-x: hidden;
-webkit-overflow-scrolling: touch;
}
/* ===== MODERATE ANIMATIONEN REDUZIERUNG ===== */
/* Verkürze Transitionen statt sie zu entfernen */
*,
*::before,
*::after {
animation-duration: 0.2s !important;
transition-duration: 0.15s !important;
}
/* Spezielle verkürzte Hover-Effekte */
.optimized-hover {
transition: opacity 0.1s ease, background-color 0.1s ease, box-shadow 0.1s ease !important;
}
.optimized-hover:hover {
opacity: 0.95;
}
/* ===== REDUZIERTE GLASSMORPHISM (nicht komplett entfernt) ===== */
/* Leichtere Glassmorphism-Effekte für bessere Performance */
.glass-base,
.glass-strong,
.glass-subtle,
.glass-card,
.glass-nav,
.glass-btn,
.glass-modal,
.glass-input,
.glass-dropdown,
.mb-glass {
backdrop-filter: blur(4px) !important;
-webkit-backdrop-filter: blur(4px) !important;
}
/* Dark Mode: Noch reduzierter */
.dark .glass-base,
.dark .glass-strong,
.dark .glass-subtle,
.dark .glass-card,
.dark .glass-nav,
.dark .glass-btn,
.dark .glass-modal,
.dark .glass-input,
.dark .glass-dropdown,
.dark .mb-glass {
backdrop-filter: blur(2px) !important;
-webkit-backdrop-filter: blur(2px) !important;
}
/* ===== MODERATE TRANSFORM OPTIMIERUNGEN ===== */
/* Reduziere nur problematische Transform-Hover-Effekte */
.professional-hero:hover,
.professional-container:hover {
transform: translateY(-1px) !important; /* Minimal statt -2px */
}
.card-professional:hover,
.stat-card:hover {
transform: none !important; /* Diese waren am problematischsten */
}
/* Behalte wichtige Navigation-Effekte */
.nav-item-professional:hover {
transform: translateX(2px) !important; /* Reduziert von 4px */
}
/* ===== LEICHTE SHADOW OPTIMIERUNGEN ===== */
/* Reduziere nur die schwersten Shadows */
.professional-hero,
.professional-container,
.card-professional,
.stat-card {
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06) !important;
}
.dark .professional-hero,
.dark .professional-container,
.dark .card-professional,
.dark .stat-card {
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15) !important;
}
/* ===== FONT RENDERING OPTIMIERUNG ===== */
body, * {
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-rendering: optimizeSpeed;
}
/* ===== MEMORY OPTIMIERUNGEN ===== */
/* Image Optimierung */
img {
image-rendering: auto;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
/* SVG Optimierung */
svg {
shape-rendering: optimizeSpeed;
}
/* ===== MOBILE/TABLET OPTIMIERUNGEN ===== */
@media (max-width: 1024px) {
/* Weitere Reduzierung für kleinere Geräte */
*,
*::before,
*::after {
animation-duration: 0.1s !important;
transition-duration: 0.1s !important;
}
/* Entferne backdrop-filter nur auf schwächeren Geräten */
.glass-base,
.glass-strong,
.glass-subtle,
.glass-card,
.glass-nav,
.glass-btn,
.glass-modal,
.glass-input,
.glass-dropdown,
.mb-glass {
backdrop-filter: none !important;
-webkit-backdrop-filter: none !important;
}
}
/* ===== REDUCED MOTION SUPPORT ===== */
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 0.01ms !important;
animation-iteration-count: 1 !important;
transition-duration: 0.01ms !important;
scroll-behavior: auto !important;
}
/* Entferne Glaseffekte für Nutzer mit reduced motion */
.glass-base,
.glass-strong,
.glass-subtle,
.glass-card,
.glass-nav,
.glass-btn,
.glass-modal,
.glass-input,
.glass-dropdown,
.mb-glass {
backdrop-filter: none !important;
-webkit-backdrop-filter: none !important;
}
}
/* ===== SELEKTIVE CPU INTENSIVE PROPERTIES OVERRIDE ===== */
/* Entferne nur die schwersten Filter */
.glass-professional {
backdrop-filter: blur(6px) !important;
-webkit-backdrop-filter: blur(6px) !important;
}
/* Vereinfache Border-Radius nur bei den größten Elementen */
.professional-hero {
border-radius: 12px !important;
}
/* ===== PRINT OPTIMIERUNGEN ===== */
@media print {
* {
background: white !important;
color: black !important;
box-shadow: none !important;
text-shadow: none !important;
animation: none !important;
transition: none !important;
backdrop-filter: none !important;
-webkit-backdrop-filter: none !important;
}
}
/* ===== ANTI-FLICKER MASSNAHMEN ===== */
/* Verhindere Flackern bei Hover-Übergängen */
.card-professional,
.stat-card,
.professional-container,
.nav-item-professional {
transition: all 0.15s ease-out !important;
}
/* Sanftere Button-Transitionen */
.btn-professional,
.btn-secondary-professional {
transition: background-color 0.1s ease, box-shadow 0.1s ease !important;
}
/* ===== FINALER PERFORMANCE-BALANCE ===== */
/* Stelle sicher, dass die schwersten Performance-Killer reduziert sind */
.glass-overlay {
backdrop-filter: blur(2px) !important;
-webkit-backdrop-filter: blur(2px) !important;
}
.animate-slide-up,
.animate-hover-lift,
.animate-scale-in {
animation-duration: 0.2s !important;
transition: opacity 0.1s ease !important;
}
.hover-lift:hover {
transform: translateY(-1px) !important; /* Reduziert von -2px */
}

View File

@ -30,6 +30,8 @@
<link href="{{ url_for('static', filename='css/components.css') }}" rel="stylesheet"> <link href="{{ url_for('static', filename='css/components.css') }}" rel="stylesheet">
<link href="{{ url_for('static', filename='css/professional-theme.css') }}" rel="stylesheet"> <link href="{{ url_for('static', filename='css/professional-theme.css') }}" rel="stylesheet">
<link href="{{ url_for('static', filename='css/optimization-animations.css') }}" rel="stylesheet"> <link href="{{ url_for('static', filename='css/optimization-animations.css') }}" rel="stylesheet">
<!-- Raspberry Pi Performance Optimierungen - MUSS nach anderen CSS-Dateien geladen werden -->
<link href="{{ url_for('static', filename='css/raspberry-pi-optimizations.css') }}" rel="stylesheet">
<!-- Preload critical resources --> <!-- Preload critical resources -->
<link rel="preload" href="{{ url_for('static', filename='js/ui-components.js') }}" as="script"> <link rel="preload" href="{{ url_for('static', filename='js/ui-components.js') }}" as="script">