@ -5,7 +5,10 @@
base_chemin_mv="/tmp/ramdisk/qemu-adm"
base_chemin_mv="/tmp/ramdisk/qemu-adm"
bin_qemu="/usr/bin/qemu-system-x86_64"
bin_qemu="/usr/bin/qemu-system-x86_64"
bin_qemu_img="/usr/bin/qemu-img"
bin_qemu_img="/usr/bin/qemu-img"
chemin_services_demons="/usr/local/etc/systemd/system"
chemin_services_production="/etc/systemd/system"
nom_script=$(basename $0)
nom_script=$(basename $0)
nom_complet_script="$(dirname $0)/${nom_script}"
die()
die()
{
{
@ -14,8 +17,8 @@ die()
verifMVExiste()
verifMVExiste()
{
{
if [ -e "${base_chemin_mv}/${nom_mv}" ]; then
if [ -e "${base_chemin_mv}/${nom_fichier_ mv}" ]; then
die "Le répertoire de la machine virtuelle ${base_chemin_mv}/${nom_mv} existe déjà." 4
die "Le répertoire de la machine virtuelle ${base_chemin_mv}/${nom_fichier_ mv} existe déjà." 4
fi
fi
}
}
@ -38,7 +41,7 @@ initEnv()
esac
esac
;;
;;
"repMV")
"repMV")
mkdir -p ${base_chemin_mv}/${nom_mv}
mkdir -p ${base_chemin_mv}
;;
;;
esac
esac
}
}
@ -132,13 +135,7 @@ presenceParametre()
creeMV()
creeMV()
{
{
nom_mv="$(basename ${1})"
localiserMV ${1}
if [[ "$(dirname ${1})" != "." ]];then
base_chemin_mv="$(dirname ${1})"
fi
chemin_mv="${base_chemin_mv}/${nom_mv}/qemu-${nom_mv}.mv"
echo "nom_mv=${nom_mv}" # Debogage
echo "base_chemin_mv=${base_chemin_mv}" # Debogage
commandes_a_executer+=("nouvMV nom ${nom_mv}")
commandes_a_executer+=("nouvMV nom ${nom_mv}")
shift # On retire le nom de la machine virtuelle passé en argument
shift # On retire le nom de la machine virtuelle passé en argument
echo 1 "$#" # Debogage
echo 1 "$#" # Debogage
@ -225,7 +222,7 @@ creeMV()
die "Le disque n'est pas renseigné.\nSyntaxe attendue : <chemin disque>|(<chemin disque>|<nom disque>):(raw|qcow2):<capacité>)." 5
die "Le disque n'est pas renseigné.\nSyntaxe attendue : <chemin disque>|(<chemin disque>|<nom disque>):(raw|qcow2):<capacité>)." 5
fi
fi
if [[ "$(dirname ${1})" == "." ]];then
if [[ "$(dirname ${1})" == "." ]];then
disque_nom="${base_chemin_mv}/${nom_mv}/${ disque_nom}"
disque_nom="${base_chemin_mv}/${disque_nom}"
fi
fi
@ -448,11 +445,14 @@ creeMV()
genCmdIntRzo(){
genCmdIntRzo(){
# Création d'une interface non étiqueté (access)
# Création d'une interface non étiqueté (access)
if [[ "${pont_init}" -eq 1 && "${vlan_init}" -eq 1 && "${interface_init}" -eq 1 ]]; then
if [[ "${pont_init}" -eq 1 && "${vlan_init}" -eq 1 && "${interface_init}" -eq 1 ]]; then
commandes_a_executer+=( "ip tuntap add ${interface} mode tap" )
# Commandes à executer au demarrage
commandes_a_executer+=( "ip link set ${interface} up" )
commandes_a_executer_on+=( "ip tuntap add ${interface} mode tap" )
commandes_a_executer+=( "ip link set ${interface} master ${pont}" )
commandes_a_executer_on+=( "ip link set ${interface} up" )
commandes_a_executer+=( "bridge vlan del dev ${interface} vid 1 PVID untagged master" )
commandes_a_executer_on+=( "ip link set ${interface} master ${pont}" )
commandes_a_executer+=( "bridge vlan add dev ${interface} vid ${vlan} pvid untagged master" )
commandes_a_executer_on+=( "bridge vlan del dev ${interface} vid 1 PVID untagged master" )
commandes_a_executer_on+=( "bridge vlan add dev ${interface} vid ${vlan} pvid untagged master" )
# Commandes à exectuer à l'arrêt
commandes_a_executer_off+=( "ip link del ${interface}" )
# Réinitialisation des variables témoins
# Réinitialisation des variables témoins
pont_init=0
pont_init=0
@ -461,13 +461,15 @@ genCmdIntRzo(){
# Création d'une interface étiqueté (trunk)
# Création d'une interface étiqueté (trunk)
elif [[ "${pont_init}" -eq 1 && "${ieee8021q_init}" -eq 1 && "${interface_init}" -eq 1 ]]; then
elif [[ "${pont_init}" -eq 1 && "${ieee8021q_init}" -eq 1 && "${interface_init}" -eq 1 ]]; then
commandes_a_executer+=( "ip tuntap add ${interface} mode tap" )
commandes_a_executer_on +=( "ip tuntap add ${interface} mode tap" )
commandes_a_executer+=( "ip link set ${interface} up" )
commandes_a_executer_on +=( "ip link set ${interface} up" )
commandes_a_executer+=( "ip link set ${interface} master ${pont}" )
commandes_a_executer_on +=( "ip link set ${interface} master ${pont}" )
commandes_a_executer+=( "bridge vlan del dev ${interface} vid 1 PVID untagged master" )
commandes_a_executer_on +=( "bridge vlan del dev ${interface} vid 1 PVID untagged master" )
for ((id_label_vlan=0 ; "${nb_params_label}" - "${id_label_vlan}" ; id_label_vlan++)); do
for ((id_label_vlan=0 ; "${nb_params_label}" - "${id_label_vlan}" ; id_label_vlan++)); do
commandes_a_executer+=( "bridge vlan add dev ${interface} vid ${label_vlan[${id_label_vlan}]} tagged master" )
commandes_a_executer_on +=( "bridge vlan add dev ${interface} vid ${label_vlan[${id_label_vlan}]} tagged master" )
done
done
# Commandes à exectuer à l'arrêt
commandes_a_executer_off+=( "ip link del ${interface}" )
# Réinitialisation des variables témoins
# Réinitialisation des variables témoins
pont_init=0
pont_init=0
@ -475,45 +477,41 @@ genCmdIntRzo(){
interface_init=0
interface_init=0
fi
fi
echo "commandes_a_executer=${commandes_a_executer[@]}" # Debogage
}
}
# Fonction exécuté en premier. Récupère les paramètres du fichier de configuration du conteneur
# Fonction exécuté en premier. Récupère les paramètres du fichier de configuration du conteneur
recupParams(){
recupParams(){
verif_params=${1}
declare -a params_int=( $(grep -B 3 "^-device" ${chemin_mv}) )
declare -a params_int=( $(grep -B 3 "^-device" ${chemin_mv}) )
nb_params="${#params_int[*]}"
nb_params="${#params_int[*]}"
echo "nb_params=${nb_params}" # Debogage
for ((id_param_fichier=0 ; "${nb_params}" - "${id_param_fichier}" ; id_param_fichier++)); do
for ((id_param_fichier=0 ; "${nb_params}" - "${id_param_fichier}" ; id_param_fichier++)); do
nom_param=$(echo "${params_int[${id_param_fichier}]}" | grep -v '#.*-device' | sed "s/=.*//" | sed "s/#//")
nom_param=$(echo "${params_int[${id_param_fichier}]}" | grep -v '#.*-device' | sed "s/=.*//" | sed "s/#//")
val_param=$(echo "${params_int[${id_param_fichier}]}" | sed "s/.*=//")
val_param=$(echo "${params_int[${id_param_fichier}]}" | sed "s/.*=//")
echo "nom_param=${nom_param}" # Debogage
echo "val_param=${val_param}" # Debogage
# Récupération des données d'après le fichier de configuration
# Récupération des données d'après le fichier de configuration
if [ "${nom_param}" == "PONT" ]; then
if [ "${nom_param}" == "PONT" ]; then
echo "ip link show ${val_param}" # Debogage
if [[ ${verif_params} == "vrai" ]]; then
if [[ $(ip link show "${val_param}" 2> /dev/null) ]]; then
if [[ $(ip link show "${val_param}" 2> /dev/null) ]]; then
pont="${val_param}"
pont="${val_param}"
pont_init=1
pont_init=1
echo "pont_init=1" # Debogage
else
else
echo "Erreur: le pont ${val_param} n'existe pas. Arrêt immédiat du script \"${0}\" sans aucune modification du système."
die "Le pont ${val_param} n'existe pas." 8
exit 1
fi
else
pont="${val_param}"
pont_init=1
fi
fi
elif [ "${nom_param}" == "VLAN" ]; then
elif [ "${nom_param}" == "VLAN" ]; then
if [[ "${val_param}" =~ ^-?[0-9]+$ && "${val_param}" -ge 1 && "${val_param}" -le 4094 && $(echo -n "${val_param}" | cut -c 1) -ne 0 ]]; then
if [[ "${val_param}" =~ ^-?[0-9]+$ && "${val_param}" -ge 1 && "${val_param}" -le 4094 && $(echo -n "${val_param}" | cut -c 1) -ne 0 ]]; then
if [[ "${pont_init}" -eq 1 ]]; then
if [[ "${pont_init}" -eq 1 ]]; then
vlan="${val_param}"
vlan="${val_param}"
vlan_init=1
vlan_init=1
echo "vlan_init=1" # Debogage
else
else
echo "Erreur: le paramètre \"#PONT=votrePont\" est manquant."
die "Le paramètre \"#PONT=votrePont\" est manquant dans le fichier ${chemin_mv}." 9
exit 1
fi
fi
else
else
echo "Erreur: le VLAN \"${val_param}\" n'est pas un entier compris entre 1 et 4094. Arrêt immédiat du script \"${0}\" sans aucune modification du système."
die "Le VLAN \"${val_param}\" n'est pas un entier compris entre 1 et 4094. Veuillez verifier le fichier ${chemin_mv}." 9
exit 1
fi
fi
elif [ "${nom_param}" == "8021Q" ]; then
elif [ "${nom_param}" == "8021Q" ]; then
declare -a label_vlan=( $(echo ${val_param} | sed 's/,/\n/g') )
declare -a label_vlan=( $(echo ${val_param} | sed 's/,/\n/g') )
@ -523,25 +521,21 @@ recupParams(){
if [[ "${label_vlan[${id_label_vlan}]}" =~ ^-?[0-9]+$ && "${label_vlan[${id_label_vlan}]}" -ge 1 && "${label_vlan[${id_label_vlan}]}" -le 4094 && $(echo -n "${label_vlan[${id_label_vlan}]}" | cut -c 1) -ne 0 ]]; then
if [[ "${label_vlan[${id_label_vlan}]}" =~ ^-?[0-9]+$ && "${label_vlan[${id_label_vlan}]}" -ge 1 && "${label_vlan[${id_label_vlan}]}" -le 4094 && $(echo -n "${label_vlan[${id_label_vlan}]}" | cut -c 1) -ne 0 ]]; then
if [[ "${pont_init}" -eq 1 ]]; then
if [[ "${pont_init}" -eq 1 ]]; then
ieee8021q_init=1
ieee8021q_init=1
echo "ieee8021q_init=1" # Debogage
else
else
echo "Erreur: le paramètre \"#PONT=votrePont\" est manquant."
die "Le paramètre \"#PONT=votrePont\" est manquant dans le fichier ${chemin_mv}." 9
exit 1
fi
fi
else
else
echo "Erreur: le tronc 802.1Q comporte un identifiant de VLAN (\"${val_param}\") qui n'est pas un entier compris entre 1 et 4094. Arrêt immédiat du script \"${0}\" sans aucune modification du système."
die "Le tronc 802.1Q comporte un identifiant de VLAN (\"${val_param}\") qui n'est pas un entier compris entre 1 et 4094. Veuillez verifier le fichier ${chemin_mv}." 9
exit 1
fi
fi
done
done
elif [ "${nom_param}" == "INTERFACE" ]; then
elif [ "${nom_param}" == "INTERFACE" ]; then
if [[ ${verif_params} == "vrai" ]]; then
if [[ ! $(ip link show "${val_param}" 2> /dev/null) ]]; then
if [[ ! $(ip link show "${val_param}" 2> /dev/null) ]]; then
if [[ "${vlan_init}" -eq 1 || "${ieee8021q_init}" -eq 1 ]]; then
if [[ "${vlan_init}" -eq 1 || "${ieee8021q_init}" -eq 1 ]]; then
interface="${val_param}"
interface="${val_param}"
interface_init=1
interface_init=1
echo "interface_init=1" # Debogage
else
else
echo "Erreur: le paramètre \"#VLAN=votreVLAN\" est manquant."
die "Le paramètre \"#VLAN=votreVLAN\" est manquant dans le fichier ${chemin_mv}." 9
exit 1
fi
fi
elif [[ $(ls /run/network/ | sed -e "s/ifstate//g" -e "s/^.//" -e "/^$/d" -e "/^lo$/d" | grep "${val_param}" 2> /dev/null) ]]; then
elif [[ $(ls /run/network/ | sed -e "s/ifstate//g" -e "s/^.//" -e "/^$/d" -e "/^lo$/d" | grep "${val_param}" 2> /dev/null) ]]; then
pont_init=0
pont_init=0
@ -549,8 +543,11 @@ recupParams(){
ieee8021q_init=0
ieee8021q_init=0
interface_init=0
interface_init=0
else
else
echo "Erreur: l'interface ${val_param} est déjà existante. Arrêt immédiat du script \"${0}\" sans aucune modification du système."
die "L'interface ${val_param} est déjà existante." 8
exit 1
fi
else
interface="${val_param}"
interface_init=1
fi
fi
fi
fi
@ -559,6 +556,31 @@ recupParams(){
done
done
}
}
genService(){
echo "genService" # Debogage
mkdir -p ${chemin_services_demons}
echo "chemin_mv=${chemin_mv}" # Debogage
nom_du_service="qemu-${nom_mv}-$(echo -n ${chemin_mv} | sha512sum | cut -c 1-10).service"
cat << _EOF_ > ${chemin_services_demons}/${nom_du_service}
[Unit]
Description=Service pour la machine vituelle ${chemin_mv}
After=syslog.target
After=network.target
[Service]
RestartSec=2s
Type=simple
ExecStart=${nom_complet_script} demarre ${chemin_mv}
[Install]
WantedBy=multi-user.target
_EOF_
echo "Le service ${chemin_services_demons}/${nom_du_service} a été crée"
ln -sf ${chemin_services_demons}/${nom_du_service} ${chemin_services_production}/${nom_du_service}
echo "Un lien synbolique vers ${chemin_services_production}/${nom_du_service} a été crée"
echo -e "Si vous voulez exécuter votre machine au démarrage du système, veuillez utiliser la commande suivante :\n\t\033[01;30msystemctl enable ${nom_du_service}\033[00m"
}
usage()
usage()
{
{
case ${1} in
case ${1} in
@ -605,6 +627,36 @@ usage()
esac
esac
}
}
localiserMV() {
nom_mv="$(basename ${1})"
if [[ "$(dirname ${1})" != "." ]];then
base_chemin_mv="$(dirname ${1})"
nom_fichier_mv="${nom_mv}"
else
base_chemin_mv+="/${nom_mv}"
nom_fichier_mv="qemu-${nom_mv}.mv"
fi
chemin_mv="${base_chemin_mv}/${nom_fichier_mv}"
echo "chemin_mv=${chemin_mv}" # Debogage
echo "nom_mv=${nom_mv}" # Debogage
echo "base_chemin_mv=${base_chemin_mv}" # Debogage
echo "nom_fichier_mv=${nom_fichier_mv}" # Debogage
}
demarreService() {
systemctl daemon-reload
systemctl start ${nom_du_service}
echo "Verification en cours..."
sleep 2
systemctl is-active --quiet ${nom_du_service}
if [[ $? -eq 0 ]]; then
echo -e "\033[01;32mLa machine virtuelle ${nom_mv} est bien démarrée.\033[00m"
else
echo -e "\033[01;31mLa machine virtuelle ${nom_mv} n'a pas démarrée.\033[00m"
journalctl --no-pager --lines=10 --output=cat -eu ${nom_du_service}
fi
}
case ${1} in
case ${1} in
cree)
cree)
echo "Créer" # Debogage
echo "Créer" # Debogage
@ -629,30 +681,25 @@ case ${1} in
if [[ "${1}" == "-h" ]]; then
if [[ "${1}" == "-h" ]]; then
usage "demarre"
usage "demarre"
fi
fi
nom_mv="$(basename ${1})"
localiserMV ${1}
if [[ "$(dirname ${1})" != "." ]];then
base_chemin_mv="$(dirname ${1})"
fi
chemin_mv="${base_chemin_mv}/${nom_mv}/qemu-${nom_mv}.mv"
echo "chemin_mv=${chemin_mv}" # Debogage
echo "nom_mv=${nom_mv}" # Debogage
echo "base_chemin_mv=${base_chemin_mv}" # Debogage
shift
shift
echo 1 "$#" # Debogage
echo 1 "$#" # Debogage
if [[ $# -eq 0 ]]; then
if [[ $# -eq 0 ]]; then
echo "Demarrage de la MV..." # Debogage
echo "Demarrage de la MV..." # Debogage
# recupParams
recupParams vrai
# execCmd "${commandes_a_executer[@]}"
execCmd "${commandes_a_executer_on[@]}"
commande_qemu=$(grep -Ev '^#|^$' ${chemin_mv} | tr -d '\n' | tr -d '\\')
commande_qemu=$(grep -Ev '^#|^$' ${chemin_mv} | tr -d '\n' | tr -d '\\')
echo "${bin_qemu} ${commande_qemu}" # Debogage
echo "${bin_qemu} ${commande_qemu}" # Debogage
${bin_qemu} ${commande_qemu}
${bin_qemu} ${commande_qemu}
fi
execCmd "${commandes_a_executer_off[@]}"
else
while [[ $# -gt 0 ]]; do
while [[ $# -gt 0 ]]; do
case "${1}" in
case "${1}" in
'-d') #demon
'-d') #demon
echo "demon" # Debogage
echo "demon" # Debogage
if [[ ${temoin_d} -ne 1 ]]; then
if [[ ${temoin_d} -ne 1 ]]; then
#commandes_a_executer+=( "nouvMV ${nom_mv}")
commandes_a_executer_demon+=( "genService" )
commandes_a_executer_demon+=( "demarreService")
temoin_d=1
temoin_d=1
else
else
die "L'option ${1} a déjà été renseignée." 3
die "L'option ${1} a déjà été renseignée." 3
@ -668,6 +715,8 @@ case ${1} in
esac
esac
shift
shift
done
done
execCmd "${commandes_a_executer_demon[@]}"
fi
fi
fi
;;
;;
@ -677,8 +726,12 @@ case ${1} in
if [[ "${1}" == "-h" ]]; then
if [[ "${1}" == "-h" ]]; then
usage "arret"
usage "arret"
fi
fi
nom_mv="${1}"
localiserMV ${1}
echo "nom_mv=${nom_mv}"
shift
nom_du_service="qemu-${nom_mv}-$(echo -n ${chemin_mv} | sha512sum | cut -c 1-10).service"
systemctl stop ${nom_du_service}
recupParams faux
execCmd "${commandes_a_executer_off[@]}"
;;
;;
active)
active)