MySQL原理详解及部署

Jun 07, 2016 pm 05:34 PM

Mysql支持几种不同形式的复制如:单双向、链式级联、异步复制。在复制过程中,一个服务器充当主服务器(master)而一个或多个其他

一、MySQL主从复制原理

什么是mysql主从复制介绍

Mysql支持几种不同形式的复制如:单双向、链式级联、异步复制。在复制过程中,一个服务器充当主服务器(master)而一个或多个其他的服务器充当从服务器(slave)如果设置了链式级联复制,那么从slave服务器除了当从服务器,还会作为其他服务器的主服务器。

当配好主从复制后,数据库的内容更新应该都在master服务器上,避免用户对主服务器上数据库内容的更新与对从服务器上数据库内容的更新发生了冲突。生产环境中一般会忽略授权表的同步,对在从服务器上的用户仅授权select读权限。或在my.cnf配置文件中加read-only参数,来确保从数据库只读,当然二者同时操作效果更佳。

一般生产环境中会有一个M-->S 或者是一个M-->多个S。在同步的时候还可以双向同步MM.而级联就是A-->B-->C-->D.在从库的my.cnf配置文件中加read-only参数来确保从库只读。常规情况是不允许的,当然如果能够保证不对同一个表写数据可以了。或者我们在从库上只对用户授权select权限。

mysql主从结构的作用:

1)主从服务器架构的设置,可以大大加强数据架构的健壮性,当主服务器出现问题时,我们可以切换到从服务器继续提供服务。

这类似我们说的NFS存储数据通过inotify+rsync实时同步到备份的nfs上的过程。只不是这里是同步mysql数据库的内容而已,用的是mysql自带的工具。

2)主从服务器价格可实现对用户的请求实现读写分离,即通过在从服务器上处理用户select查询请求,降低用户查询响应时间。及读写给主服务器带来的压力。对于更新的数据(update,insert,delete)仍然交给主服务器处理,确保主服务器和从服务器保持实时同步。

如果网站是以非更新为主的业务,如blog,www首先展示等业务,读请求比较多,这时从服务器的负载均衡策略就很有效了,这就是读写分离数据库结构。

3)可以把几个不同的从服务器,根据公司的业务进行拆分,比如有为外部用户提供查询服务的从服务器,有用来备份的从服务器,还有提供公司内部后台、脚本、日志分析及开发人员服务的从服务器。这样拆分除了减轻主服务器的压力外。使得对外用户浏览,对内处理公司内部用户业务,及DBA备份业务互不影响。具体可以看下面的简单架构来说明:

我们现在是一主5从,只要我们向这1主写数据,那么5从就都会同时更新。提示:其中s1 2 3 可以通过lvs做成负载均衡的模式。这样第4台从库给我们的后台,内部访问。

后台的数据库独立出来,安装在备份数据库上,这样我们测试使用的数据就不会影响到线上的环境,也能够保证真实情况。而我们的备份数据库,,要开启binlog功能,做数据库的增量备份功能。

-------小结----------------------------------------------------------------

数据库主从同步跟sersync实时同步是一样的道理。只是我们的sersync是同步文件,而我们这次是同步数据库数据而已。MySQL同步是利用自带的工具来进行同步。主从架构我们可以在从库上执行select查询请求,降低用户查询响应时间及读写给服务器带来的压力。在数据库里面,还有这样的问题:当数据库在更新的时候是没办法做其他操作的如查询。对于更新数据一般都是通过update inserter delete。

如果网站是以非更新的业务为主(浏览为主),读请求比较多,那么这时候从服务器的负载均衡策略就很有效了。这就是传说中的读写分离结构。从库的作用还有很多不同的用途。有为外部用户提供查询服务的从服务器,有用来备份的从服务器,还有提供公司内部后台,脚本,日志分析及开发服务的从服务器。这样拆分能够减轻主服务器的压力。

-------小结----------------------------------------------------------------

相关阅读:

RHEL 6.4(i386)安装MySQL 5.6的方法

Linux网站架构系列之Apache----部署篇

MySQL完整安装和主从双机配置

RHEL6平台rpm方式安装MySQL数据库

RedHat 6.3安装MySQL-server-5.6.13-1.el6.x86_64.rpm

Ubuntu 12.04下源代码安装MySQL5.6以及Python-MySQLdb

linux

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

DockerでのMySQLメモリの使用を減らします DockerでのMySQLメモリの使用を減らします Mar 04, 2025 pm 03:52 PM

この記事では、DockerのMySQLメモリ使用量を最適化することを調査します。 監視手法(Docker統計、パフォーマンススキーマ、外部ツール)および構成戦略について説明します。 これらには、Dockerメモリの制限、スワッピング、およびcgroupsが含まれます

mysqlの問題を解決する方法共有ライブラリを開くことができません mysqlの問題を解決する方法共有ライブラリを開くことができません Mar 04, 2025 pm 04:01 PM

この記事では、MySQLの「共有ライブラリを開くことができない」エラーについて説明します。 この問題は、必要な共有ライブラリ(.so/.dllファイル)を見つけることができないMySQLの障害に起因しています。ソリューションには、システムのパッケージMを介してライブラリのインストールを確認することが含まれます。

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Mar 19, 2025 pm 03:51 PM

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし) Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし) Mar 04, 2025 pm 03:54 PM

この記事では、PHPMyAdminの有無にかかわらず、LinuxにMySQLを直接インストールするのとPodmanコンテナを使用します。 それは、各方法のインストール手順を詳述し、孤立、携帯性、再現性におけるポッドマンの利点を強調しますが、

sqliteとは何ですか?包括的な概要 sqliteとは何ですか?包括的な概要 Mar 04, 2025 pm 03:55 PM

この記事では、自己完結型のサーバーレスリレーショナルデータベースであるSQLiteの包括的な概要を説明します。 SQLiteの利点(シンプルさ、移植性、使いやすさ)と短所(同時性の制限、スケーラビリティの課題)を詳しく説明しています。 c

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド Mar 04, 2025 pm 03:49 PM

このガイドは、HomeBrewを使用してMacOSに複数のMySQLバージョンをインストールおよび管理することを示しています。 Homebrewを使用して設置を分離し、紛争を防ぐことを強調しています。 この記事では、インストール、開始/停止サービス、および最高のPRAを詳述しています

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? Mar 18, 2025 pm 12:01 PM

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? 人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? Mar 21, 2025 pm 06:28 PM

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

See all articles