MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践
接触php已快有3年了,一直想有所突破,最近看了下分布和数据库读写分离。总算也小有成果.....前段时间发布了,用ngix实现分流 nginx 配置轮询分流-实现负载均衡【测试通过】 今天就来分享一下,数据库读写分离并且同步。我目前,介绍的是1台写入服务器,n台
接触php已快有3年了,一直想有所突破,最近看了下分布和数据库读写分离。总算也小有成果.....前段时间发布了,用ngix实现分流
nginx 配置轮询分流-实现负载均衡【测试通过】
今天就来分享一下,数据库读写分离并且同步。我目前,介绍的是1台写入服务器,n台读取服务器....
写这个的同时,我在思考一个问题,如果写入压力过大的时候,1台服务器写入不够用,那么写入该怎么办!利用队列,缓存!一台服务器慢慢写?还求大神给解释,求带!
1,mysql的配置
mysql的配置我就不多说了,看我 另一篇文章
CentOS 5.x,6.0编译安装Nginx1.2.3+MySQL5.5.15+PHP5.3.6
我是再这个环境下做测试的,我是配置了1台。利用VMware Workstation拷贝出来多台服务器的,所以环境绝对一样。
2,场景描述
主数据库服务器:192.168.10.130
从数据库服务器:192.168.10.131
3 ,配置主服务器
修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改
vi etc/my.cnf
启动mysql服务(192.168.10.130)
/etc/init.d/mysqld start
通过命令行登录管理MySQL服务器
mysql -uroot -p
授权给从数据库服务器192.168.10.131
mysql> GRANT REPLICATION SLAVE ON *.* to 'rep1'@'192.168.10.131' identified by '123';
查询主数据库状态
Mysql> show master status;
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000005 | 261 | | |
+------------------+----------+--------------+------------------+
记录下 FILE (mysql-bin.000005) 及 Position(261) 的值,在后面进行从服务器操作的时候需要用到。
4,配置从服务器
修改从服务器的配置文件,my.cnf 不一定路径和我一样哦,注意修改
vi etc/my.cnf
启动mysql服务
/opt/mysql/init.d/mysql start
通过命令行登录管理MySQL服务器
mysql -uroot -p
执行同步SQL语句
mysql> change master to
master_host=’192.168.10.130’,
master_user=’rep1’,
master_password=’123’,
master_log_file=’mysql-bin.000005’,
master_log_pos=261;
注意上面的数据要和主服务器一样,否则同步会失败!
?
正确执行后启动Slave同步进程
mysql> start slave;
主从同步检查
mysql> show slave status\G
其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。
如果不是,请检查上面是否那一步骤有问题!可以留言给我。。。如果都YES 可以进入下一步操作
5,第一次同步主从服务器数据
锁定主服务器mysql:
mysql> FLUSH TABLES WITH READ LOCK;
锁定从服务器mysql:
mysql> FLUSH TABLES WITH READ LOCK;
将主服务器的数据文件(整个/opt/mysql/data目录)复制到从服务器,建议通过tar归档压缩后再传到从服务器解压覆盖。
开启主服务器mysql:
mysql> UNLOCK TABLES;
开启从服务器mysql:
mysql> UNLOCK TABLES;
6,测试是否同步
在主服务器上操作:
mysql> create database first_db; mysql> use first_db; mysql> create table first_tb(id int(3),name char(10)); mysql> INSERT INTO `first_tb` VALUES ('1', '1');
在从服务器上查看....
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| first_db |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.01 sec)
=============================
数据已经同步过来了。现在只要在主服务器上有任何操作,都会自动同步到从服务器来。
作者:open520yin 发表于2013-8-8 16:44:01 原文链接
阅读:0 评论:0 查看评论
原文地址:MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践, 感谢原作者分享。

ホット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)

ホットトピック











ビッグ データ構造の処理スキル: チャンキング: データ セットを分割してチャンクに処理し、メモリ消費を削減します。ジェネレーター: データ セット全体をロードせずにデータ項目を 1 つずつ生成します。無制限のデータ セットに適しています。ストリーミング: ファイルやクエリ結果を 1 行ずつ読み取ります。大きなファイルやリモート データに適しています。外部ストレージ: 非常に大規模なデータ セットの場合は、データをデータベースまたは NoSQL に保存します。

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

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

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

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

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

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

Oracle データベースと MySQL はどちらもリレーショナル モデルに基づいたデータベースですが、Oracle は互換性、スケーラビリティ、データ型、セキュリティの点で優れており、MySQL は速度と柔軟性に重点を置いており、小規模から中規模のデータ セットに適しています。 ① Oracle は幅広いデータ型を提供し、② 高度なセキュリティ機能を提供し、③ エンタープライズレベルのアプリケーションに適しています。① MySQL は NoSQL データ型をサポートし、② セキュリティ対策が少なく、③ 小規模から中規模のアプリケーションに適しています。
