"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > Pitón. Automatización de la creación de copias de seguridad de la base de datos MySQL.

Pitón. Automatización de la creación de copias de seguridad de la base de datos MySQL.

Publicado el 2024-07-31
Navegar:773

Python. Automating creation backups of MySQL database.

Este script automatiza la creación de copias de seguridad de bases de datos MySQL, su restauración y la gestión de la creación de bases de datos y usuarios en el servidor MySQL de destino.

import subprocess
import datetime
import sys
import os

def check_and_create_database(host, port, username, password, database):
    # Command to check if the database exists
    check_database_command = f"mysql -sN --host={host} --port={port} --user={username} --password={password} -e \"SELECT EXISTS(SELECT 1 FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = '{database}')\" 2>/dev/null"

    # Execute the command
    output = subprocess.check_output(check_database_command, shell=True)

    # If the output contains b'1', the database exists
    if b'1' in output:
        subprocess.run(check_database_command, shell=True, check=True)
        print(f"Database '{database}' already exists.")
        sys.exit(1)
    else:
        # If the command fails, the database does not exist
        print(f"Database '{database}' does not exist. Creating...")

        # Command to create the database
        create_database_command = f"mysql --host={host} --port={port} --user={username} --password={password} -e 'CREATE DATABASE {database}' 2>/dev/null"
        subprocess.run(create_database_command, shell=True)

def check_and_create_user(host, port, username, password, database, new_username, new_password):
    # Command to check if the user exists
    check_user_command = f"mysql -sN --host={host} --port={port} --user={username} --password={password} -e \"SELECT EXISTS(SELECT 1 FROM mysql.user WHERE user = '{new_username}')\" 2>/dev/null"

    # Execute the command
    output = subprocess.check_output(check_user_command, shell=True)

    # If the output contains b'1', the user exists
    if b'1' in output:
        print(f"User '{new_username}' already exists.")
        sys.exit(1)
    else:
        # The user does not exist, create it
        print(f"User '{new_username}' does not exist. Creating...")

        # Command to create the user and grant privileges
        create_user_command = f"mysql --host={host} --port={port} --user={username} --password={password} -e \"CREATE USER '{new_username}'@'%' IDENTIFIED BY '{new_password}'; GRANT ALL PRIVILEGES ON {database}.* TO '{new_username}'@'%'; FLUSH PRIVILEGES;\" 2>/dev/null"
        subprocess.run(create_user_command, shell=True)

def backup_mysql_database(host, port, username, password, database, backup_path):

    # Check if the backup directory exists
    if not os.path.exists(backup_path):
        print(f"Error: Backup directory '{backup_path}' does not exist.")
        sys.exit(1)

    # Create a filename for the backup with the current date and time
    timestamp = datetime.datetime.now().strftime("%Y-%m-%d_%H-%M-%S")
    backup_file = f"{backup_path}/{database}_{timestamp}.sql"

    # Command to create a database backup using mysqldump
    dump_command = f"mysqldump --no-tablespaces --host={host} --port={port} --user={username} --password={password} {database} > {backup_file} 2>/dev/null"

    # Execute the mysqldump command
    subprocess.run(dump_command, shell=True)

    return backup_file

def restore_mysql_database(host, port, username, password, database, backup_file):
    # Command to restore a database from a backup using mysql
    restore_command = f"mysql --host={host} --port={port} --user={username} --password={password} {database} /dev/null"

    # Execute the mysql command
    subprocess.run(restore_command, shell=True)

def main():
    # Connection parameters to the source MySQL database
    source_host = "127.0.0.1"
    source_port = "3309"
    source_username = "my_user"
    source_password = "my_password"
    source_database = "my_database"

    # Connection parameters to the target MySQL database
    target_host = "127.0.0.1"
    target_port = "3309"
    new_username = "new_username"
    new_password = "new_password"
    target_database = "my_database_two"

    target_username = "root"
    target_password = "root_password"

    # Path to save the backup locally
    backup_path = "my_dbs_dumps"

    # Check if source_database is different from target_database
    if source_database == target_database:
        print("Error: Source database should be different from target database.")
        sys.exit(1)

    # Check and create the target database if it does not exist
    check_and_create_database(target_host, target_port, target_username, target_password, target_database)

    # Check and create the target user if it does not exist
    check_and_create_user(target_host, target_port, target_username, target_password, target_database, new_username, new_password)

    # Create a backup of the MySQL database
    backup_file = backup_mysql_database(source_host, source_port, source_username, source_password, source_database, backup_path)
    print(f"Database backup created: {backup_file}")

    # Restore the database on the target server from the backup
    restore_mysql_database(target_host, target_port, target_username, target_password, target_database, backup_file)
    print("Database backup restored on the target server.")

if __name__ == "__main__":
    main()

check_and_create_database:
Esta función comprueba si existe una base de datos en un servidor MySQL. Si la base de datos no existe, la crea. Se necesitan parámetros como el host, el puerto, el nombre de usuario, la contraseña y el nombre de la base de datos para verificar o crear.

check_and_create_user:
Al igual que la función de base de datos, esta función verifica si existe un usuario en el servidor MySQL. Si el usuario no existe, lo crea y otorga privilegios a una base de datos específica. También toma parámetros como el host, el puerto, el nombre de usuario, la contraseña, el nombre de la base de datos, el nuevo nombre de usuario y la nueva contraseña.

backup_mysql_database:
Esta función realiza una copia de seguridad de una base de datos MySQL usando mysqldump. Toma parámetros como el host, el puerto, el nombre de usuario, la contraseña, el nombre de la base de datos y la ruta para guardar el archivo de respaldo.

restore_mysql_database:
Esta función restaura una base de datos MySQL a partir de un archivo de copia de seguridad. Toma parámetros como el host, el puerto, el nombre de usuario, la contraseña, el nombre de la base de datos y la ruta al archivo de respaldo.

principal:
Esta es la función principal del guión. Configura parámetros para las bases de datos MySQL de origen y destino, incluidos detalles de conexión, nombres de bases de datos y rutas de respaldo. Luego realiza comprobaciones para garantizar que las bases de datos de origen y de destino sean diferentes, crea la base de datos de destino y el usuario si no existen, crea una copia de seguridad de la base de datos de origen y finalmente restaura la copia de seguridad en la base de datos de destino.

Además, el script utiliza el módulo de subproceso para ejecutar comandos de shell para operaciones MySQL (mysql, mysqldump) y realiza manejo de errores y redirección de salida (2>/dev/null) para suprimir salidas innecesarias.

Si estás trabajando con bases de datos MySQL y quieres crear automatización, este código te ayudará.

Este código representa una buena plantilla inicial para crear scripts de automatización para administrar bases de datos MySQL.

dmi@dmi-laptop:~/my_python$ python3 mysql_backup_restore.py 
Database 'my_database_two' does not exist. Creating...
User 'new_username' does not exist. Creating...
Database backup created: my_dbs_dumps/my_database_2024-05-13_20-05-24.sql
Database backup restored on the target server.
dmi@dmi-laptop:~/my_python$ 

[email protected]

Declaración de liberación Este artículo se reproduce en: https://dev.to/dm8ry/python-automating-creation-backups-of-mysql-database-2goa?1 Si hay alguna infracción, comuníquese con [email protected] para eliminarla.
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3