"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 파이썬. MySQL 데이터베이스 생성 백업을 자동화합니다.

파이썬. MySQL 데이터베이스 생성 백업을 자동화합니다.

2024-07-31에 게시됨
검색:331

Python. Automating creation backups of MySQL database.

이 스크립트는 MySQL 데이터베이스의 백업 생성, 복원, 대상 MySQL 서버에서 데이터베이스 및 사용자 생성 관리를 자동화합니다.

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:
이 함수는 MySQL 서버에 데이터베이스가 존재하는지 확인합니다. 데이터베이스가 존재하지 않으면 데이터베이스를 생성합니다. 확인하거나 생성하려면 호스트, 포트, 사용자 이름, 비밀번호, 데이터베이스 이름과 같은 매개변수가 필요합니다.

check_and_create_user:
데이터베이스 기능과 마찬가지로 이 기능은 MySQL 서버에 사용자가 존재하는지 확인합니다. 사용자가 존재하지 않는 경우 사용자를 생성하고 특정 데이터베이스에 권한을 부여합니다. 또한 호스트, 포트, 사용자 이름, 비밀번호, 데이터베이스 이름, 새 사용자 이름, 새 비밀번호와 같은 매개변수도 사용합니다.

backup_mysql_database:
mysqldump를 사용하여 MySQL 데이터베이스를 백업하는 기능입니다. 호스트, 포트, 사용자 이름, 비밀번호, 데이터베이스 이름 및 백업 파일을 저장할 경로와 같은 매개변수를 사용합니다.

restore_mysql_database:
이 기능은 백업 파일에서 MySQL 데이터베이스를 복원합니다. 호스트, 포트, 사용자 이름, 비밀번호, 데이터베이스 이름, 백업 파일 경로와 같은 매개변수를 사용합니다.

기본:
이것이 스크립트의 주요 기능입니다. 연결 세부 정보, 데이터베이스 이름 및 백업 경로를 포함하여 소스 및 대상 MySQL 데이터베이스에 대한 매개변수를 설정합니다. 그런 다음 소스 데이터베이스와 대상 데이터베이스가 다른지 확인하고, 존재하지 않는 경우 대상 데이터베이스와 사용자를 생성하고, 소스 데이터베이스의 백업을 생성한 후 마지막으로 백업을 대상 데이터베이스에 복원합니다.

또한 스크립트는 하위 프로세스 모듈을 사용하여 MySQL 작업(mysql, mysqldump)에 대한 셸 명령을 실행하고 오류 처리 및 출력 리디렉션(2>/dev/null)을 수행하여 불필요한 출력을 억제합니다.

MySQL 데이터베이스로 작업하고 자동화를 생성하려는 경우 이 코드가 도움이 될 것입니다.

이 코드는 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]

릴리스 선언문 이 글은 https://dev.to/dm8ry/python-automating-creation-backups-of-mysql-database-2goa?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]에 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3