从MySQL迁移到MariaDB(CentOS)_MySQL
MariaDBCentOS
下面先摘录一点背景介绍,然后是我在 CentOS 6.4 上从 MySQL 5.5.31 迁移至 MariaDB 5.5.31 的操作记录。最后是我后来发现一个较好的迁移方法。
1. 背景介绍
MySQL是世界上最流行的开源关系数据库。2008 年,Sun 收购 MySQL。然后 2010 年,甲骨文又收购了 Sun,于是 MySQL 落入了甲骨文(Oracle)手中。Oracle 与开源社区关系的一直不太好,甚至 MySQL 也被弄成了社区版和企业版,不能免费商业使用;MySQL 企业版的新功能不公开源代码,这样让用户很不爽。MariaDB 则没有这方面的问题。与 MySQL 相比,MariaDB 的优势在于:
可免费商业使用(MySQL 则有社区版和企业版之分,拜 Oracle 所赐)
Maria 存储引擎
PBXT 存储引擎
XtraDB 存储引擎
FederatedX 存储引擎
更快的复制查询处理
线程池
运行速度更快
更多的扩展功能模块
支持 Unicode 排序
于是我决定先在虚拟机上看看如何由 MySQL 迁移到 MariaDB,虽然难以预料的是,不知道 Michael Widenius 会不会在什么时候又将 MariaDB 卖给哪家大公司。
原来 MariaDB 的设计初衷之一就是完全兼容 MySQL,包括 API 和客户端协议,使之能轻松成为 MySQL 的代替品,所以由 MySQL 迁移到 MariaDB 基本上可以称之为“升级”,就好像软件升级版本一样。MariaDB 的技术文档上是这样写的:
如果是相同的基础版本(如 5.5),可以直接卸载 MySQL 然后安装 MariaDB,这样就可以用了。甚至不需要备份然后还原数据库。当然,保险起见,升级前将所有的数据库都备份一下还是非常有必要的,以防万一。
如果 MariaDB 的主版本高,在经过上面的卸载 MySQL 再安装 MariaDB 操作之后,需要使用 mysql_upgrade 升级一下。是的,甚至连命令行都与使用 MySQL 的时候一样。
所有原先的客户端和连接器(PHP、Perl、Python、Java 等)都不需要做任何改变就能正常工作,因为 MariaDB 与 MySQL 使用的是相同的客户端协议,并且客户端库文件也是二进制兼容的。
2. 迁移操作记录(下面的 3 的方法更好)
这个 VPS 安装的是 CentOS,目前版本是 6.4,MySQL 版本是 5.5.31(使用了 remi 源),虚拟机的配置与此极度相似。刚开始不太了解,执行了这个比较傻的操作方式。
A. 先配置 MARIADB 的安装源。
目前 MariaDB 的主版本是 5.5,我的 CentOS 是 32 位的,将下面的安装源配置保存为MariaDB.repo,上传到服务器的 /etc/yum.repos.d 文件夹:
<ol class="dp-sql"> <li class="alt"><span><span>[mariadb] </span></span></li> <li><span><span class="keyword">name</span><span> = MariaDB </span></span></li> <li class="alt"><span>enable=1 </span></li> <li><span>priority=3 </span></li> <li class="alt"><span>baseurl = http://yum.mariadb.org/5.5/centos6-x86 </span></li> <li><span>gpgkey=https://yum.mariadb.org/RPM-GPG-<span class="keyword">KEY</span><span>-MariaDB </span></span></li> <li class="alt"><span>gpgcheck=1 </span></li> </ol>
其中 priority=3 是针对 YUM 的 PRIORITIES 优先级插件的。
B. 卸载原来的 MYSQL 及相关包。
<ol class="dp-xml"><li class="alt"><span><span># yum remove mysql* </span></span></li></ol>
上面用 * 来匹配删除所有 mysql 数据包(包括因包依赖而删除的别的包,如 postfix)。因为直接安装的时候会出现冲突,例如:
file /usr/share/mysql/ukrainian/errmsg.sys from install of MariaDB-server-5.5.31-1.i686 conflicts with file from package mysql-libs-5.5.32-1.el6.remi.i686
嗯,好像因为将 php-mysql 也给删除了(实际上这个不该删除的),所以 phpMyAdmin 也因为依赖关系而被删除了,我没仔细看。
所以最好不要用通配符 *,而是选择性删除几个主要的,
<ol class="dp-xml"><li class="alt"><span><span># yum remove mysql mysql-server mysql-libs </span></span></li></ol>
但是这个我没有再测试,因为后面有更好的方法。
C. 然后安装 MARIADB 及相应 PHP 扩展。
也是指定几个主要的安装包,剩下的让 yum 自己进行依赖关系检查。
<ol class="dp-xml"><li class="alt"><span><span># yum install MariaDB-server MariaDB-client php-mysql </span></span></li></ol>
或者不安装 MariaDB-server 而改为具有同步多主群集特性(synchronous multi-master cluster)的 MariaDB Galera Cluster:
<ol class="dp-xml"><li class="alt"><span><span># yum install MariaDB-Galera-server MariaDB-client galera </span></span></li></ol>
这里比较搞笑的是,没注意前面把 php-mysql 给卸载了,结果运行数据库之后访问 WordPress,结果遭遇下面的错误:
Your PHP installation appears to be missing the MySQL extension which is required by WordPress.
D. 完成,修补
不管版本是否升级了,执行一下数据库升级指令总没有坏处:
<ol class="dp-xml"><li class="alt"><span><span># mysql_upgrade -p </span></span></li></ol>
看看数据库版本是不是升级了:
<ol class="dp-xml"> <li class="alt"><span><span># mysql -u root -p -e 'show global variables like "version";' </span></span></li> <li><span>Enter password: </span></li> <li class="alt"><span>+---------------+----------------+ </span></li> <li><span>| Variable_name | Value | </span></li> <li class="alt"><span>+---------------+----------------+ </span></li> <li><span>| version | 5.5.31-MariaDB | </span></li> <li class="alt"><span>+---------------+----------------+ </span></li> </ol>
将 MariaDB 加入随系统自启动列表,
<ol class="dp-xml"><li class="alt"><span><span># chkconfig --levels 345 mysql on </span></span></li></ol>
嗯,以前 MySQL 的时候是 mysqld,现在是 mysql,就差了一个字母 d。
启动它,
<ol class="dp-xml"><li class="alt"><span><span># service mysql start </span></span></li></ol>
这个时候服务器上的网站应该已经可以正常工作了,访问数据库没有问题。
如果有必要,安装完 MariaDB 之后可以重新安装 postfix。如果发现 phpMyAdmin 提示无访问权限了,那就是被卸载了,需要重新安装和配置 phpMyAdmin。
另外,因为之前进行了卸载操作,所以原来的 MySQL 和 phpMyAdmin 的配置文件都被清除了,也需要重新配置。特别是 MySQL 的配置文件 /etc/my.cnf,因为 MariaDB 虽然创建了一个my.cnf.d 文件夹来存储自己的配置文件,但是它会首先加载 my.cnf,且原来 MySQL 的配置的 [mysqld] 那一节的内容还是有效的。
3. 较好的升级方法
还是在上面介绍的系统配置下,先添加 MariaDB 安装源,然后直接执行系统升级,
# yum update --skip-broken
MariaDB 相关安装包会被安装,不需要的 MySQL 包将被卸载,并且升级之后不需要对系统进行修补了。看看输出的前面一部分:
<ol class="dp-xml"> <li class="alt"><span><span>============================================================================================================== </span></span></li> <li><span>Package Arch Version Repository <span class="attribute">Size</span><span> </span></span></li> <li class="alt"><span>============================================================================================================== </span></li> <li><span>Installing: </span></li> <li class="alt"><span>MariaDB-Galera-server i686 5.5.29-1 mariadb 19 M </span></li> <li><span> replacing mysql.i686 5.5.21-1.el6.remi </span></li> <li class="alt"><span> replacing mysql-server.i686 5.5.21-1.el6.remi </span></li> <li><span>MariaDB-server i686 5.5.31-1 mariadb 32 M </span></li> <li class="alt"><span> replacing mysql-server.i686 5.5.21-1.el6.remi </span></li> <li><span>MariaDB-shared i686 5.5.31-1 mariadb 1.0 M </span></li> <li class="alt"><span> replacing mysql-libs.i686 5.5.21-1.el6.remi </span></li> <li><span>kernel i686 2.6.32-358.11.1.el6 updates 24 M </span></li> <li class="alt"><span>libjpeg-turbo i686 1.2.1-1.el6 base 176 k </span></li> <li><span>replacing libjpeg.i686 6b-46.el6 </span></li> <li class="alt"><span>Updating: </span></li> <li><span>......... </span></li> </ol>
到这里才感觉到 MariaDB 的设计思想那个无缝替代 MySQL 不是噱头,而是实实在在的技术。于是我也就不急着给 VPS 升级到 MariaDB 了,反正过不了多久 CentOS 就会采用 MariaDB,到时候再自然而然地迁移吧。
原文链接:http://cnzhx.net/blog/mysql-migrate-to-mariadb/

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHP で MySQL データベースをバックアップおよび復元するには、次の手順を実行します。 データベースをバックアップします。 mysqldump コマンドを使用して、データベースを SQL ファイルにダンプします。データベースの復元: mysql コマンドを使用して、SQL ファイルからデータベースを復元します。

6月21日、Huawei Developer Conference 2024(HDC2024)が東莞市松山湖に再び集まりました。今回のカンファレンスで最も目を引いたのは、HarmonyOSNEXTが開発者とパイオニアユーザー向けにベータ版を正式に開始し、すべてのシナリオにおけるHarmonyOSNEXTの3つの「画期的な」革新的な機能、ネイティブインテリジェンスとネイティブセキュリティを包括的に実証したことだ。 HarmonyOSNEXT ネイティブ インテリジェンス: 新しい AI 時代の幕開け HarmonyOSNEXT は、Android フレームワークを放棄した後、Android や iOS から独立した真に独立したオペレーティング システムとなり、前例のない復活と言えます。多くの新機能の中でも、ネイティブ インテリジェンスは間違いなく、ユーザーに直感的な感覚と体験のアップグレードを最もよくもたらす新機能です。

MySQL クエリのパフォーマンスは、検索時間を線形の複雑さから対数の複雑さまで短縮するインデックスを構築することで最適化できます。 PreparedStatement を使用して SQL インジェクションを防止し、クエリのパフォーマンスを向上させます。クエリ結果を制限し、サーバーによって処理されるデータ量を削減します。適切な結合タイプの使用、インデックスの作成、サブクエリの使用の検討など、結合クエリを最適化します。クエリを分析してボトルネックを特定し、キャッシュを使用してデータベースの負荷を軽減し、オーバーヘッドを最小限に抑えます。

MySQLテーブルにデータを挿入するにはどうすればよいですか?データベースに接続する: mysqli を使用してデータベースへの接続を確立します。 SQL クエリを準備します。挿入する列と値を指定する INSERT ステートメントを作成します。クエリの実行: query() メソッドを使用して挿入クエリを実行します。成功すると、確認メッセージが出力されます。

PHP を使用して MySQL テーブルを作成するには、次の手順が必要です。 データベースに接続します。データベースが存在しない場合は作成します。データベースを選択します。テーブルを作成します。クエリを実行します。接続を閉じます。

PHP で MySQL ストアド プロシージャを使用するには: PDO または MySQLi 拡張機能を使用して、MySQL データベースに接続します。ストアド プロシージャを呼び出すステートメントを準備します。ストアド プロシージャを実行します。結果セットを処理します (ストアド プロシージャが結果を返す場合)。データベース接続を閉じます。

1. 旧端末で「自分」→「設定」→「チャット」→「チャット履歴の移行とバックアップ」→「移行」をクリックします。 2. 移行するターゲットプラットフォームデバイスを選択し、移行するチャットレコードを選択して、「開始」をクリックします。 3. 新しいデバイスで同じ WeChat アカウントでログインし、QR コードをスキャンしてチャット履歴の移行を開始します。

MySQL 8.4 (2024 年時点の最新の LTS リリース) で導入された主な変更の 1 つは、「MySQL Native Password」プラグインがデフォルトで有効ではなくなったことです。さらに、MySQL 9.0 ではこのプラグインが完全に削除されています。 この変更は PHP および他のアプリに影響します
