2019-05-21 09:40:15 +04:00
|
|
|
#!/bin/bash
|
|
|
|
# -*- coding: utf-8 mode: sh -*- vim:sw=4:sts=4:et:ai:si:sta:fenc=utf-8
|
|
|
|
source "$(dirname "$0")/lib/ulib/ulib" || exit 1
|
|
|
|
urequire DEFAULTS
|
|
|
|
|
|
|
|
function display_help() {
|
|
|
|
uecho "$scriptname: se connecter à la base MySQL
|
|
|
|
|
|
|
|
USAGE
|
|
|
|
$scriptname [DATABASE]
|
2022-02-17 08:55:34 +04:00
|
|
|
$scriptname -d [-uUSER [-pPASSWORD]] DATABASES... >backup.sql
|
|
|
|
$scriptname -c [-uUSER [-pPASSWORD]] <backup.sql
|
2019-05-21 09:40:15 +04:00
|
|
|
|
|
|
|
OPTIONS
|
|
|
|
-h, -s, --service SERVICE
|
2019-06-19 14:50:34 +04:00
|
|
|
Spécifier le nom du service. La valeur par défaut est db
|
2019-06-19 15:51:31 +04:00
|
|
|
-c, --mysql-cmd
|
2019-06-19 14:50:34 +04:00
|
|
|
Lancer 'mysql -hSERVICE_IP' avec les arguments supplémentaires fournis
|
|
|
|
sur la ligne de commande
|
2019-06-19 23:22:17 +04:00
|
|
|
-d, --mysqldump-cmd
|
|
|
|
Lancer 'mysqldump --databases --add-drop-database -hSERVICE_IP' avec
|
|
|
|
les arguments supplémentaires fournis sur la ligne de commande
|
2020-06-09 18:01:13 +04:00
|
|
|
-k, --klean
|
|
|
|
Lancer la commande 'klean' dans le container spécifié (supprime toutes
|
|
|
|
les données et relance le container)
|
2019-06-19 14:50:34 +04:00
|
|
|
-u, --user USER
|
|
|
|
-p, --password PASSWORD
|
2019-06-19 23:22:17 +04:00
|
|
|
Paramètres supplémentaires utilisés uniquement avec les options -c et -d"
|
2019-05-21 09:40:15 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
service=db
|
2022-06-17 15:21:28 +04:00
|
|
|
ipnum=
|
2019-06-19 15:51:31 +04:00
|
|
|
mysql_cmd=
|
2019-06-19 23:22:17 +04:00
|
|
|
mysqldump_cmd=
|
2020-06-09 18:01:13 +04:00
|
|
|
klean=
|
2019-06-19 14:50:34 +04:00
|
|
|
user=
|
|
|
|
password=
|
2019-05-21 09:40:15 +04:00
|
|
|
args=(
|
|
|
|
--help '$exit_with display_help'
|
|
|
|
-h:,-s:,--service: service=
|
2022-06-17 15:21:28 +04:00
|
|
|
-i:,--ipnum: ipnum=
|
2019-06-19 15:51:31 +04:00
|
|
|
-c,--mysql-cmd mysql_cmd=1
|
2019-06-19 23:22:17 +04:00
|
|
|
-d,--mysqldump-cmd mysqldump_cmd=1
|
2020-06-09 18:01:13 +04:00
|
|
|
-k,--klean klean=1
|
2019-06-19 14:50:34 +04:00
|
|
|
-u:,--user: user=
|
|
|
|
-p:,--password: password=
|
2019-05-21 09:40:15 +04:00
|
|
|
)
|
|
|
|
parse_args "$@"; set -- "${args[@]}"
|
|
|
|
|
|
|
|
[ -n "$service" ] || die "Vous devez spécifier le nom du service"
|
|
|
|
|
|
|
|
found=
|
|
|
|
first=1
|
|
|
|
while true; do
|
|
|
|
if [ -f composer.json ]; then
|
|
|
|
found=1
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
first=
|
|
|
|
cd ..
|
|
|
|
if [ "$(pwd)" == "$HOME" ]; then
|
|
|
|
die "Cette commande ne peut être lancée que depuis un projet Composer"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if [ -z "$first" ]; then
|
|
|
|
enote "Le répertoire du projet est $(ppath . ~)"
|
|
|
|
fi
|
|
|
|
|
|
|
|
###
|
|
|
|
|
2019-07-15 09:11:52 +04:00
|
|
|
function die_not_found() { die "$service: service introuvable. vérifiez que le projet est actuellement up"; }
|
2019-05-24 11:49:11 +04:00
|
|
|
setx cid=docker-compose ps -q "$service" 2>/dev/null || die_not_found
|
|
|
|
[ -n "$cid" ] || die_not_found
|
|
|
|
edebug "$service id: $cid"
|
|
|
|
|
|
|
|
function die_not_found() { die "$service: $cid: ip introuvable"; }
|
2022-06-17 15:21:28 +04:00
|
|
|
setx ip=docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}},{{end}}' "$cid" || die_not_found
|
|
|
|
[ -n "$ip" ] || die_not_found
|
|
|
|
ipdesc="${ip%,}"
|
|
|
|
if [ -z "$ipnum" ] && [[ "$ipdesc" == *,* ]]; then
|
|
|
|
enote "Le service est accessible sur plusieurs adresses ip: $ipdesc"
|
|
|
|
enote "Pensez à spécifier l'option -i pour désigner l'adresse à utiliser le cas échéant"
|
|
|
|
fi
|
|
|
|
if [ -n "$ipnum" ]; then
|
|
|
|
let ipnum=ipnum-1
|
|
|
|
while [ $ipnum -gt 0 ]; do
|
|
|
|
ip="${ip#*,}"
|
|
|
|
let ipnum=ipnum-1
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
ip="${ip%%,*}"
|
2019-05-24 11:49:11 +04:00
|
|
|
[ -n "$ip" ] || die_not_found
|
|
|
|
edebug "$service ip: $ip"
|
2019-05-21 09:40:15 +04:00
|
|
|
|
2019-06-19 15:51:31 +04:00
|
|
|
if [ -n "$mysql_cmd" ]; then
|
2019-06-19 14:50:34 +04:00
|
|
|
mysql -h"$ip" ${user:+-u"$user"} ${password:+-p"$password"} "$@"
|
2019-06-19 15:51:31 +04:00
|
|
|
|
2019-06-19 23:22:17 +04:00
|
|
|
elif [ -n "$mysqldump_cmd" ]; then
|
|
|
|
mysqldump --databases --add-drop-database -h"$ip" ${user:+-u"$user"} ${password:+-p"$password"} "$@"
|
|
|
|
|
2020-06-09 18:01:13 +04:00
|
|
|
elif [ -n "$klean" ]; then
|
|
|
|
estep "klean"
|
|
|
|
docker exec "$cid" klean
|
|
|
|
estep "wait 10sec..."
|
|
|
|
sleep 10
|
|
|
|
estep "start"
|
|
|
|
docker-compose start "$service"
|
|
|
|
|
2019-06-19 14:50:34 +04:00
|
|
|
else
|
2020-06-05 16:39:44 +04:00
|
|
|
[ -f bin/conndev.php ] || die "Impossible de trouver le script compagnon conndev.php"
|
|
|
|
|
2019-06-19 15:51:31 +04:00
|
|
|
mysql_cmd="$(php bin/conndev.php "$ip" "$@")"
|
|
|
|
edebug "mysql_cmd: $mysql_cmd"
|
2019-05-21 09:40:15 +04:00
|
|
|
|
2019-06-19 15:51:31 +04:00
|
|
|
eval "$mysql_cmd"
|
2019-06-19 14:50:34 +04:00
|
|
|
fi
|