-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrun_wrapper.sh
More file actions
executable file
·66 lines (52 loc) · 1.65 KB
/
run_wrapper.sh
File metadata and controls
executable file
·66 lines (52 loc) · 1.65 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/bin/bash
# Script wrapper pour le trading bot
SCRIPT_DIR="/home/yotsi/enhanced_trading_bot"
VENV_PATH="$SCRIPT_DIR/venv/bin/python"
LOG_FILE="$SCRIPT_DIR/logs/cron.log"
# Fonction de logging
log_message() {
echo "[$(date '+%Y-%m-%d %H:%M:%S')] $1" >> "$LOG_FILE"
}
# Vérifications préalables
log_message "=== DÉBUT EXECUTION CRON ==="
# Vérifier que le dossier existe
if [ ! -d "$SCRIPT_DIR" ]; then
log_message "❌ ERREUR: Dossier non trouvé: $SCRIPT_DIR"
exit 1
fi
# Vérifier que l'environnement virtuel existe
if [ ! -f "$VENV_PATH" ]; then
log_message "❌ ERREUR: Environnement virtuel non trouvé: $VENV_PATH"
exit 1
fi
# Vérifier la connexion internet
if ! ping -c 1 8.8.8.8 &> /dev/null; then
log_message "❌ ERREUR: Pas de connexion internet"
exit 1
fi
# Aller dans le bon dossier
cd "$SCRIPT_DIR" || {
log_message "❌ ERREUR: Impossible d'accéder au dossier $SCRIPT_DIR"
exit 1
}
# Vérifier la température du CPU (optionnel)
if [ -f "/sys/class/thermal/thermal_zone0/temp" ]; then
TEMP=$(cat /sys/class/thermal/thermal_zone0/temp | head -c 2)
if [ "$TEMP" -gt 80 ]; then
log_message "⚠️ ATTENTION: Température CPU élevée: ${TEMP}°C"
fi
fi
# Exécuter le bot
log_message "🚀 Lancement du trading bot..."
START_TIME=$(date +%s)
"$VENV_PATH" run_bot.py >> "$LOG_FILE" 2>&1
EXIT_CODE=$?
END_TIME=$(date +%s)
DURATION=$((END_TIME - START_TIME))
if [ $EXIT_CODE -eq 0 ]; then
log_message "✅ Bot terminé avec succès (${DURATION}s)"
else
log_message "❌ Bot terminé avec erreur (code: $EXIT_CODE, durée: ${DURATION}s)"
fi
log_message "=== FIN EXECUTION CRON ==="
log_message ""