AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 700405
Accepted
Nick Coons
Nick Coons
Asked: 2015-06-21 01:24:16 +0800 CST2015-06-21 01:24:16 +0800 CST 2015-06-21 01:24:16 +0800 CST

MariaDB Galera 集群,强制同步

  • 772

我在一个多主 Galera 集群中有三台服务器。我最近导入了一些旧数据库,并注意到三个表都在创建,但数据没有被复制。原来我没有注意,这些旧数据库都在使用 MyISAM 表。所以我知道将来我需要将它们转换为 InnoDB,然后再将它们引入以使它们工作。

但是,我没有找到同步现有数据的官方方法。运行ALTER TABLE将现有表转换为 InnoDB 不会同步现有数据。

我的想法是用 转储表(现在它已被转换)mysqldump,然后用mysql -u user -p db < db.sql. 我看不出有什么理由不这样做,但我想知道是否有更好的方法。

cluster
  • 1 1 个回答
  • 3341 Views

1 个回答

  • Voted
  1. Best Answer
    Nick Coons
    2015-06-23T02:53:53+08:002015-06-23T02:53:53+08:00

    我找不到官方的方法来处理这个问题,所以我想到了单独转储表并重新导入它们的想法。不想手动做,我鞭打了一个 PHP 脚本来为我做这件事。我把它贴在这里,以防其他人觉得这很有用。

    /*
     * InnoDB Convert
     * Converts existing non-InnoDB tables to InnoDB, then re-imports the
     * data so that it's replicated across the cluster.
     */
    
    // Configuration
        $_config['db'] = array(
            'type'     => 'mysql',
            'host'     => 'localhost',
            'username' => 'user',
            'password' => 'password'
        );
    
    // Establish database connection
        try {
            $pdo = new PDO(
                $_config['db']['type'] . ':host=' . $_config['db']['host'],
                $_config['db']['username'],
                $_config['db']['password']
            );
        } catch ( PDOException $e ) {
            echo 'Connection failed: ' . $e->getMessage();
        }
    
    // Get list of databases
        $db_query = <<<SQL
      SHOW DATABASES
    SQL;
        $db_result = $pdo->prepare( $db_query );
        $db_result->execute();
    
        while ( $db_row = $db_result->fetch( PDO::FETCH_ASSOC )) {
        // Look through databases, but ignores the ones that come with a
        // MySQL install and shouldn't be part of the cluster
            if ( !in_array( $db_row['Database'], array( 'information_schema', 'mysql', 'performance_schema', 'testdb' ))) {
                $pdo->exec( "USE {$db_row['Database']}" );
    
                $table_query = <<<SQL
      SHOW TABLES
    SQL;
                $table_result = $pdo->prepare( $table_query );
                $table_result->execute();
    
                while ( $table_row = $table_result->fetch( PDO::FETCH_ASSOC )) {
                // Loop through all tables
                    $table = $table_row["Tables_in_{$db_row['Database']}"];
    
                    $engine_query = <<<SQL
      SHOW TABLE STATUS WHERE Name = :table
    SQL;
                    $engine_result = $pdo->prepare( $engine_query );
                    $engine_result->execute( array(
                        ':table' => $table
                    ));
    
                    $engine_row = $engine_result->fetch( PDO::FETCH_ASSOC );
    
                    if ( $engine_row['Engine'] != 'InnoDB' ) {
                    // Engine is not equal to InnoDB, let's convert it
                        echo "Converting '$table' on '{$db_row['Database']}' from '{$engine_row['Engine']}' to InnoDB:\n";
    
                        echo     "Modifying engine...";
    
                        $change_query = <<<SQL
      ALTER TABLE $table ENGINE=InnoDB
    SQL;
                        $change_result = $pdo->prepare( $change_query );
                        $change_result->execute();
    
                        echo "done!\n";
    
                        echo "    Exporting table...";
    
                        exec( "mysqldump -h {$_config['db']['host']} -u {$_config['db']['username']} -p{$_config['db']['password']} {$db_row['Database']} $table > /tmp/dump-file.sql" );
    
                        echo "done!\n";
    
                        echo "    Re-importing table...";
    
                        exec( "mysql -h {$_config['db']['host']} -u {$_config['db']['username']} -p{$_config['db']['password']} {$db_row['Database']} < /tmp/dump-file.sql" );
    
                        echo "done!\n";
    
                        unlink( '/tmp/dump-file.sql' );
    
                        echo "done!\n";
                    }
                }
            }
        }
    

    我成功地用它在大约两分钟内转换了几十个数据库中的数百个表。

    • 2

相关问题

  • 是否有可能从多台计算机中创建一台速度更快的计算机?

  • LVS 集群帮助

  • 如何从 Windows 2008 故障转移群集中删除“额外”(不需要的)网络?

  • 如何在低负载期间关闭(关闭)集群节点?

  • 使用 Nagios 监视 Novell 集群服务

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve