Finalisation du backup sql et telechargement
This commit is contained in:
parent
22cffe21b4
commit
4d6e744c7c
76
main.go
76
main.go
@ -5,6 +5,8 @@ import (
|
||||
"fmt"
|
||||
"log"
|
||||
"os"
|
||||
"strings"
|
||||
|
||||
"time"
|
||||
|
||||
"canguidev.fr/pvnet/function"
|
||||
@ -28,6 +30,7 @@ func main(){
|
||||
var mysqlUser string
|
||||
var mysqlPswd string
|
||||
var pathSaveSql string
|
||||
var nameBase string
|
||||
|
||||
// Chargement de la liste des hosts du fichier config ssh
|
||||
d := simplyssh.GetHost(pathConfigSsh)
|
||||
@ -47,7 +50,7 @@ func main(){
|
||||
} else {
|
||||
for _, host := range d {
|
||||
// for sur les hosts et break sur le host selectionner
|
||||
if(host.Id == uint(index)){
|
||||
if host.Id == uint(index) {
|
||||
fmt.Println("debut de connection")
|
||||
// connection en ssh avec la clée et les informations du fichier config
|
||||
client := simplyssh.Connect(pathSsh, host.HostName, host.Port, host.User)
|
||||
@ -70,13 +73,8 @@ func main(){
|
||||
session.Close()
|
||||
|
||||
// Créez une nouvelle session pour exécuter le backup
|
||||
sessionBackup, err := client.NewSession()
|
||||
if err != nil {
|
||||
log.Fatal("Failed to create session for backup: ", err)
|
||||
}
|
||||
defer sessionBackup.Close()
|
||||
|
||||
choice, index, err := gochoice.Pick(
|
||||
_, index, err := gochoice.Pick(
|
||||
"What do you want to do?\nPick:",
|
||||
[]string{
|
||||
"Backup sql and download",
|
||||
@ -88,79 +86,71 @@ func main(){
|
||||
fmt.Println("You didn't select anything!")
|
||||
return
|
||||
}
|
||||
|
||||
fmt.Println("Enter path download key: ")
|
||||
fmt.Printf("You have selected: '%s', which is the index %d\n", choice, index)
|
||||
|
||||
if (index == 0) {
|
||||
|
||||
//var pathSaveSite string
|
||||
orderedKeys := []string{"host","mysql_login", "mysql_pasw", "path_save_sql", "path_save_site"}
|
||||
|
||||
if index == 0 {
|
||||
excel := function.ReadExcel(pathExcel)
|
||||
key:="host"
|
||||
// Parcourir les résultats d'Excel
|
||||
for _, value := range excel {
|
||||
// Lire les clés dans l'ordre spécifié
|
||||
for _, k := range orderedKeys {
|
||||
if v, exists := value[k]; exists && k == key {
|
||||
fmt.Println("Key:", k, "Value:", v)
|
||||
if(k==selectHost){
|
||||
switch k {
|
||||
sessionBackup, err := client.NewSession()
|
||||
if err != nil {
|
||||
log.Fatal("Failed to create session for backup: ", err)
|
||||
}
|
||||
defer sessionBackup.Close()
|
||||
fmt.Println("--------------------------")
|
||||
for key, val := range value {
|
||||
if strings.Compare(val, selectHost) == 1 {
|
||||
switch key {
|
||||
case "path_save_sql":
|
||||
pathSaveSql = v
|
||||
pathSaveSql = val
|
||||
case "path_save_site":
|
||||
// pathSaveSite = v
|
||||
case "mysql_login":
|
||||
mysqlUser = v
|
||||
mysqlUser = val
|
||||
case "mysql_pasw":
|
||||
mysqlPswd = v
|
||||
}
|
||||
}
|
||||
// Switch pour affecter les variables
|
||||
|
||||
mysqlPswd = val
|
||||
case "name_base":
|
||||
nameBase = val
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fmt.Println("--------------------------")
|
||||
fmt.Println("MySQL User:", mysqlUser)
|
||||
fmt.Println("MySQL Password:", mysqlPswd)
|
||||
fmt.Println("Path Save SQL:", pathSaveSql)
|
||||
log.Fatal("stop julien")
|
||||
|
||||
fmt.Println("Name Base:", nameBase)
|
||||
fmt.Println("--------------------------")
|
||||
//log.Fatal("stop julien")
|
||||
currentTime := time.Now()
|
||||
formattedTime := currentTime.Format("20060102_150405")
|
||||
|
||||
filename := "backup/test_" + formattedTime + ".sql"
|
||||
commandBackup := "mysqldump -u "+mysqlUser+" -p'"+mysqlPswd+"' test > " + filename
|
||||
filename := "backup/" + nameBase + "_" + formattedTime + ".sql"
|
||||
commandBackup := "mysqldump -u " + mysqlUser + " -p'" + mysqlPswd + "' " + nameBase + " > " + filename
|
||||
|
||||
// Maintenant on utilise la sessionBackup pour exécuter la commande du backup
|
||||
if err := sessionBackup.Run(commandBackup); err != nil {
|
||||
log.Fatal("Failed to run commandBackup: " + err.Error())
|
||||
}
|
||||
fmt.Println("backup ok")
|
||||
|
||||
if client == nil {
|
||||
log.Fatal("Client SSH non initialisé")
|
||||
}
|
||||
sftpClient, err := sftp.NewClient(client)
|
||||
if err != nil {
|
||||
log.Fatal("Erreur connection: ", err)
|
||||
}
|
||||
defer sftpClient.Close()
|
||||
|
||||
var pathDownload string
|
||||
fmt.Scanln(&pathDownload)
|
||||
fmt.Println(filename)
|
||||
currentTime2 := time.Now()
|
||||
formattedTime2 := currentTime2.Format("20060102_150405")
|
||||
|
||||
filename2 := "test_" + formattedTime2 + ".sql"
|
||||
filename2 := nameBase+"_" + formattedTime2 + ".sql"
|
||||
err = simplyssh.DownloadFile(sftpClient, filename, pathSaveSql+filename2)
|
||||
if err != nil {
|
||||
log.Fatal("Erreur lors du téléchargement: ", err)
|
||||
}
|
||||
fmt.Println("Téléchargement terminé")
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
//log.Fatal("Failed to run: " + err.Error())
|
||||
}
|
||||
fmt.Println(b.String())
|
||||
|
||||
|
||||
Loading…
Reference in New Issue
Block a user