- 浏览: 520212 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (422)
- 重要 (12)
- BUG解决备忘录 (32)
- 环境搭建 (17)
- 开源组件 (4)
- 数据库 (16)
- 设计模式 (4)
- 测试 (3)
- javascript (5)
- Android (14)
- jdk相关 (9)
- struts2 (10)
- freemark (3)
- 自定义扩展及工具类 (5)
- jdk5新特性及java基础 (13)
- ssh及其他框架 (15)
- linux (32)
- tcp-ip http协议 (8)
- 服务器集群与负载均衡 (34)
- 项目管理相关 (11)
- 实用小技术 (10)
- 架构相关 (14)
- firefox组件 (11)
- spider (6)
- 产品设计 (11)
- PHP (1)
- ws (4)
- lucene (10)
- 其他 (2)
- BI (1)
- NoSQL (3)
- gzip (1)
- ext (4)
- db (6)
- socket (1)
- 源码阅读 (2)
- NIO (2)
- 图片处理 (1)
- java 环境 (2)
- 项目管理 (4)
- 从程序员到项目经理(一):没有捷径 (1)
- bug (1)
- JAVA BASE (8)
- 技术原理 (0)
- 新框架新技术 (1)
- 量化与python (1)
- 系统编程 (0)
- C语言 (0)
- 汇编 (0)
- 算法 (0)
最新评论
-
hyspace:
别逗了,最后一个算法根本不是最优的,sort(function ...
数组去重——一道前端校招试题 -
washingtin:
楼主能把策略和路由的类代码贴出来吗
Spring + iBatis 的多库横向切分简易解决思路 -
sdyjmc:
初略看了一下,没有闹明白啊,均衡负载使用Nginx,sessi ...
J2EE集群原理 I -
shandeai520:
谢谢大神!请教大神一个问题:假如我有三台服务器,连接池的上限是 ...
集群和数据库负载均衡的研究 -
hekuilove:
给lz推荐一下apache commonsStringUtil ...
request 获取 ip
http://www.net5
本文主要是尝试MySQL 6.0.3-beta下的集群+复制,没有做深入的测试,仅可作安装配置参考。 如果只是做普通的集群,那么一般只需要4台机器,甚至只需要3台,即把管理节点和SQL节点放在同一个机器上,不过不推荐这么做。如果是集群+复制,则机器数量翻番。 共有4个节点,如下图所示: 共有2个集群,分别作为master和slave,如下图: MySQL的安装路径默认为:/usr/local/mysql
。 首先,创建数据文件主目录 /usr/local/mysql/data,然后编辑配置文件: vi /usr/local/mysql/config.ini 在SQL节点中,除了作为正常的mysqld服务在运行而设定的常规参数外,想要加入集群中,只需要增加几行即可: vi /etc/my.cnf 数据节点配置很简单,只需要指定管理节点IP即可: vi /etc/my.cnf 很简单,直接运行命令: 数据节点有些特殊,如果是第一次启动,则需要增加参数 –initial,如果不是,直接启动即可: 非第一次启动: 如果你不是把 my.cnf 放在 /etc/ 下,则需要指定实际位置所在,比如: 或 正常的mysqld启动方式启动即可,比如我习惯使用 /etc/init.d/mysql 来启动: 或 在管理节点上,运行客户端工具 ndb_mgm: #查看集群状态 #查看全部数据节点状态 #报告数据节点的内存使用情况 #重启第3个节点 集群的备份很简单,只需在管理节点上执行START BACKUP 即可: 来做个实际的测试,在SQL节点上先制造一些数据出来: 然后用上面提到的方法进行备份后,删除该表的数据: 接下来在2个数据节点上分别执行以下命令恢复数据: 再在SQL节点上查一下: 然后在另一个数据节点上执行恢复。 再来查一次看看: 恢复完毕。 从MySQL 5.1 开始,就支持集群+复制了,这对于想要构建一个高可用方案的用户来说,无疑是个惊喜。在这种模式下,既有主从的实时备份,又有基于集群的负载均衡,不足指出在于,从我的测试结果来看,这种方案下的性能还不是太高,仍有待改进。 3个集群,6个SQL节点,形成一个3个点环形的复制。 3个集群,6个SQL节点,形成一个6个点环形的复制,把另一个SQL节点也利用起来。 由于集群下的复制是基于row-based复制的,因此需要设置logbin-format的格式为:ROW 或者 MIXED。 新版本的MySQL已经不再通过 my.cnf 来指定master相关的信息了,而是通过 CHANGE MASTER 指令来管理。因此,slave上只需简单增加类似如下几行: 先按照正常的方式启动master和slave上的mysqld后,执行SHOW PROCESSLIST 可以看到2个mysqld都只有2个进程: 在slave上执行 SHOW SLAVE STATUS 再看看: 可以看到,现在还没有任何复制相关的配置。因此,我们需要先在master上添加一个账户用于复制: 然后,我们用 CHANGE MASTER 指令来指定一下 master 相关的参数: 执行 START SLAVE 来启动它。 再来看看:. 简介
2. 准备工作
2.1. 普通集群
Node
IP Address
管理节点 (MGM)
192.168.0.1
SQL 节点 (SQL)
192.168.0.2
数据节点 A (NDBD)
192.168.0.3
数据节点 B (NDBD)
192.168.0.4
2.2. 集群+复制
Node
IP Address
Master
管理节点 (MGM)
192.168.0.1
SQL 节点 (SQL)
192.168.0.2
数据节点 A (NDBD)
192.168.0.3
数据节点 B (NDBD)
192.168.0.4
Slave
管理节点 (MGM)
192.168.1.1
SQL 节点 (SQL)
192.168.1.2
数据节点 A (NDBD)
192.168.1.3
数据节点 B (NDBD)
192.168.1.4
3. 配置
3.1. 管理节点
#定义默认参数
[ndbd default]
#设置集群中每个表保存的副本数
#这里有2个数据节点,那么每个节点则保存一个副本
NoOfReplicas=2
#设置用于保存数据的内存大小
DataMemory=1G
#设置用于保存哈希索引的内存大小
IndexMemory=1G
#设定管理节点相关参数
[ndb_mgmd]
#指定ID号
id = 1
#指定管理节点主机
hostname=192.168.0.1
#指定管理节点的数据文件主目录
datadir=/usr/local/mysql/data
#设定数据节点相关参数
[ndbd]
id = 3
hostname=192.168.0.3
datadir=/usr/local/mysql/data
[ndbd]
id = 4
hostname=192.168.0.4
datadir=/usr/local/mysql/data
#设定SQL节点相关参数
[mysqld]
id = 2
hostname=192.168.0.2
#增加一个API节点,API节点视需求增加
[mysqld]
id = 5
3.2. SQL节点
# mysql cluster
#告诉mysqld,要启用ndbcluster引擎
ndbcluster
#指定管理节点
ndb-connectstring=192.168.0.1
[mysql_cluster]
ndb-connectstring=192.168.0.1
3.3. 数据节点
# mysql cluster
#告诉mysqld,要启用ndbcluster引擎
ndbcluster
#指定管理节点
ndb-connectstring=192.168.0.1
[mysql_cluster]
ndb-connectstring=192.168.0.1
4. 启动
4.1. 启动管理节点
/usr/local/mysql/bin/ndb_mgmd –f /usr/local/mysql/config.ini
4.2. 启动数据节点
第一次启动:/usr/local/mysql/bin/ndbd --initial
/usr/local/mysql/bin/ndbd
/usr/local/mysql/bin/ndbd –defaults-file=/usr/local/mysql/my.cnf --initial
/usr/local/mysql/bin/ndbd –defaults-file=/usr/local/mysql/my.cnf
4.3. 启动SQL节点
service mysql start
/etc/init.d/mysql start
5. 管理
/usr/local/mysql/bin/ndb_mgm
-- NDB Cluster -- Management Client --
ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=3 @192.168.0.3 (mysql-6.0.3 ndb-6.2.6, Nodegroup: 0, Master)
id=4 @192.168.0.4 (mysql-6.0.3 ndb-6.2.6, Nodegroup: 0)
[ndb_mgmd(MGM)] 1 node(s)
id=1 @192.168.0.1 (mysql-6.0.3 ndb-6.2.6)
[mysqld(API)] 2 node(s)
id=2 @192.168.0.2 (mysql-6.0.3 ndb-6.2.6)
id=5 (not connected, accepting connect from any host)
ndb_mgm> all status
Node 3: started (mysql-6.0.3 ndb-6.2.6)
Node 4: started (mysql-6.0.3 ndb-6.2.6)
ndb_mgm> 3 report memoryusage
Node 3: Data usage is 6%(2154 32K pages of total 32768)
Node 3: Index usage is 2%(3009 8K pages of total 131104)
ndb_mgm> 3 restart
Node 3: Node shutdown initiated
Node 3: Node shutdown completed, restarting, no start.
Node 3 is being restarted
Node 3: Started (version 6.2.6)
6. 备份、恢复
6.1. 备份
ndb_mgm> START BACKUP
Waiting for completed, this may take several minutes
Node 3: Backup 4 started from node 1
Node 3: Backup 4 started from node 1 completed
StartGCP: 7847 StopGCP: 7850
#Records: 1736024 #LogRecords: 0
Data: 41649824 bytes Log: 0 bytes
6.2. 恢复
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| a |
+----------------+
1 row in set (0.01 sec)
mysql> show create table a;
+-------+-------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+-------------------------------------------------------------------------------------------+
| a | CREATE TABLE `a` (
`id` int(11) DEFAULT NULL
) ENGINE=ndbcluster DEFAULT CHARSET=latin1 |
+-------+-------------------------------------------------------------------------------------------+
1 row in set (0.01 sec)
mysql> select count(*) from a;
+----------+
| count(*) |
+----------+
| 1733965 |
+----------+
1 row in set (0.03 sec)
mysql> checksum table a;
+--------+------------+
| Table | Checksum |
+--------+------------+
| test.a | 1641855839 |
+--------+------------+
1 row in set (11.61 sec)
mysql> truncate table a;
Query OK, 0 rows affected (0.68 sec)
/usr/local/mysql/bin/ndb_restore -n 3 -b 5 -r data/BACKUP/BACKUP-3
Nodeid = 3
Backup Id = 5
backup path = data/BACKUP/BACKUP-5
Opening file 'data/BACKUP/BACKUP-5/BACKUP-5.3.ctl'
File size 8120 bytes
Ndb version in backup files: ndb-6.2.6
Connected to ndb!!
Opening file 'data/BACKUP/BACKUP-5/BACKUP-5-0.3.Data'
File size 20809008 bytes
_____________________________________________________
Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 0
_____________________________________________________
Processing data in table: test/def/a(5) fragment 0
_____________________________________________________
Processing data in table: mysql/def/ndb_apply_status(4) fragment 0
_____________________________________________________
Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 0
_____________________________________________________
Processing data in table: sys/def/SYSTAB_0(0) fragment 0
_____________________________________________________
Processing data in table: mysql/def/ndb_schema(2) fragment 0
Opening file 'data/BACKUP/BACKUP-5/BACKUP-5.3.log'
File size 44 bytes
Restored 866287 tuples and 0 log entries
NDBT_ProgramExit: 0 - OK
mysql> select count(*) from a;
+----------+
| count(*) |
+----------+
| 866287 |
+----------+
1 row in set (0.00 sec)
/usr/local/mysql/bin/ndb_restore -n 4 -b 5 -r data/BACKUP/BACKUP-3
Nodeid = 4
Backup Id = 5
backup path = data/BACKUP/BACKUP-5
Opening file 'data/BACKUP/BACKUP-5/BACKUP-5.4.ctl'
File size 8120 bytes
Ndb version in backup files: ndb-6.2.6
Connected to ndb!!
Opening file 'data/BACKUP/BACKUP-5/BACKUP-5-0.4.Data'
File size 20841232 bytes
_____________________________________________________
Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 1
_____________________________________________________
Processing data in table: test/def/a(5) fragment 1
_____________________________________________________
Processing data in table: mysql/def/ndb_apply_status(4) fragment 1
_____________________________________________________
Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 1
_____________________________________________________
Processing data in table: sys/def/SYSTAB_0(0) fragment 1
_____________________________________________________
Processing data in table: mysql/def/ndb_schema(2) fragment 1
Opening file 'data/BACKUP/BACKUP-5/BACKUP-5.4.log'
File size 44 bytes
Restored 867678 tuples and 0 log entries
NDBT_ProgramExit: 0 – OK
mysql> checksum table a;
+--------+------------+
| Table | Checksum |
+--------+------------+
| test.a | 1641855839 |
+--------+------------+
1 row in set (11.62 sec)
7. 集群下的复制
7.1. 简述
集群+复制的配置其实很简单,就是配置好2个独立的集群后,把其中一个的SQL节点作为另一个集群SQL节点的slave即可。甚至可以使用下面几种架构:7.2. 开始配置
7.2.1. master上的配置
相对于普通的mysqld服务器配置,只需要增加类似如下2行:server-id = 1
binlog_format = "ROW" #or MIXED
7.2.2. slave上的配置
server-id = 2
relay-log-purge=1
skip-slave-start
replicate-ignore-db=mysql
7.3. 启动slave
mysql> SHOW PROCESSLIST;
+----+-------------+-----------+------+---------+------+-----------------------------------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-------------+-----------+------+---------+------+-----------------------------------+------------------+
| 1 | system user | | | Daemon | 0 | Waiting for event from ndbcluster | NULL |
| 2 | root | localhost | NULL | Query | 0 | NULL | show processlist |
+----+-------------+-----------+------+---------+------+-----------------------------------+------------------+
2 rows in set (0.00 sec)
mysql> show slave status\G
Empty set (0.00 sec)
mysql> GRANT REPLICATION SLAVE, GRANT REPLICATION CLIENT ON *.* TO rep@’192.168.1.2’ IDENTIFIED BY ‘rep’;
Query OK, 0 rows affected (0.00 sec)
mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.2', MASTER_USER='rep', MASTER_PASSWORD='rep';
Query OK, 0 rows affected (0.01 sec)
mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************
Slave_IO_State:
Master_Host: 192.168.0.2
Master_User: rep
Master_Port: 3306
Connect_Retry: 60
Master_Log_File:
Read_Master_Log_Pos: 4
Relay_Log_File: slave-relay-bin.000001
Relay_Log_Pos: 4
Relay_Master_Log_File:
Slave_IO_Running: No
Slave_SQL_Running: No
Replicate_Do_DB:
Replicate_Ignore_DB: mysql
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 0
Relay_Log_Space: 106
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: NULL
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
1 row in set (0.00 sec)
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.0.2
Master_User: rep
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: binlog.000001
Read_Master_Log_Pos: 256
Relay_Log_File: slave-relay-bin.000002
Relay_Log_Pos: 398
Relay_Master_Log_File: binlog.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB: mysql
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 256
Relay_Log_Space: 557
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
1 row in set (0.00 sec)
27.cn/shujukuguanli/Mysql/2011/0307/16856.html
发表评论
-
Spring + iBatis 的多库横向切分简易解决思路2
2011-12-26 16:43 2081Table of Contents I. 向Co ... -
Spring + iBatis 的多库横向切分简易解决思路
2011-12-26 16:36 11641.引言 笔者最近在做一个互联网的“类SNS” ... -
tomcat端口被长时间连接,CPU使用率高的原因分析
2011-11-20 23:50 1075tomcat使用的是电脑的80端口。 当客户端访问的 ... -
Nginx+keepalived做双机热备加tomcat负载均衡
2011-10-25 16:55 1670环境说明: nginx1: 192.168.2.4 ... -
centos下MySQL主从同步配置
2011-05-05 00:38 1044一、环境 主机: ... -
HadHoop分布式框架配置(二)
2011-03-16 21:42 1161我们假定,你已经下 ... -
HadHoop分布式框架简介(一)
2011-03-16 21:42 1484分布式系统基本原理 分布式系统被设计成可以存 ... -
利用nginx+apache+mysql+php+memcached+squid搭建门户网站
2011-03-06 04:27 1486转自:http://hi.csdn.net/rushcc200 ... -
CentOS 5.3上安装Apache+php+Mysql+phpMyAdmin
2011-03-03 22:00 11121、系统下载 CentOS 开发社区已发布了新的 5.3 版 ... -
1分钟完美安装最新 CentOS + Nginx + PHP-FPM + MySQL
2011-03-03 21:58 1329PHP 5.3.1 MySQL 5.0.89 Ngin ... -
集群和数据库负载均衡的研究
2011-03-01 03:34 1760http://dadupi.blogbus.com/logs/ ... -
Memcached集群/分布式的单点故障
2011-03-01 03:24 1924我看到过这样一段文字 “memcached如何处理容错的? ... -
Memcached 集群架构问题归纳
2011-03-01 02:54 1026集群架构方面的问题 o memcached是怎么工作的 ... -
大型bbs架构(squid+nginx)实例分享
2011-03-01 01:50 1522这个架构 基于squid、nginx 和lvs等技术 , ... -
nginx图片服务器的架构方案
2011-03-01 01:44 1738图片服务 通常数据 容量较大,而且访问也频繁,鉴于此,图片 ... -
解密大中型网站架构设计来自威鹏网信息化解决方案专家。
2011-03-01 01:38 1021相信很多IT ... -
基于mod_proxy+Apache 2.2.16+Tomcat 7的负载均衡与集群配置
2011-03-01 00:59 1512基于mod_proxy+Apache 2.2.16+Tomca ... -
揭秘全球最大网站Facebook背后的那些软件
2011-03-01 00:53 10952010年6月,Google公布全球Top 1000网站 ... -
基于nginx的tomcat负载均衡和集群(超简单)
2011-03-01 00:46 1124今天看到"基于apache ... -
Lighttpd 的安装配置
2011-03-01 00:20 1204lighttpd(http://lighttpd.net/ ...
相关推荐
MySQL的主主复制是一种高可用性和高可靠性的解决方案,它允许两个MySQL服务器相互同步数据,形成主-主模式。在这种模式下,任何一台服务器都可以作为读写操作的入口,当其中一台服务器的数据发生变化时,这些变化会...
本教程将详细讲解如何通过源码安装MySQL 5.6.15或5.7版本,并实现主从复制,以及掌握一些常用的MySQL命令。 **1. 准备工作** 在开始源码安装之前,确保你的CentOS系统是最新的,可以通过`yum update`来更新。另外,...
Centos7下安装MySQL主从集群 在Centos7下安装MySQL主从集群需要进行详细的准备工作和操作步骤。以下是安装和配置MySQL主从集群的详细步骤: 首先,需要准备两台Centos7服务器和MySQL5.7安装介质。然后,需要配置...
MySQL 5.7 主从复制集群配置 MySQL 5.7 主从复制集群是 MySQL 的一种高可用性解决方案,通过将数据实时同步到多个服务器上来提高数据库的可用性和可靠性。下面是 MySQL 5.7 主从复制集群配置的详细步骤和注意事项。...
使用`CLUSTER NODES`命令查看当前集群节点的状态,`CLUSTER ADDSLOTS`分配新的槽,`CLUSTER REMOVE`移除节点,`CLUSTER REPLICATE`更改节点的复制关系。 此外,Redis Cluster具有自动故障转移的特性,当主节点失败...
### MySQL与Docker环境下搭建主从复制详解 在IT领域,数据库管理系统的高效稳定运行对于任何业务来说都至关重要。为了确保数据的安全性、可靠性和可用性,采用主从复制架构是一种常见且有效的策略。本文将详细介绍...
- `replicate-wild-ignore-table`:可选的复制过滤规则,这里忽略了`mysql`、`test`和`information_schema`数据库的表,防止不必要的同步。 **3. 设置复制** 在DB1上设置主服务器,DB2上设置从服务器,通过MySQL的`...
MySQL集群通常基于主从复制(Master-Slave Replication)或主主复制(Master-Master Replication)的技术实现。主从复制是其中最常见的一种方式,它通过将主数据库上的事务操作记录(即二进制日志)发送到一个或多个...
3. **配置主节点**:在主节点的`my.cnf`配置文件中,设置`server-id = 1`,开启`log-bin=mysql-bin`日志记录,指定需要复制的数据库(例如`replicate-do-db=fire9`)。 4. **配置从节点**:在从节点的`my.cnf`配置...
总结,MySQL 5.6 Replicate容灾方案是企业级数据库管理的重要组成部分,它通过实时数据复制确保了数据的安全和业务的连续性。在实际部署中,需要根据业务需求和环境条件进行详细规划和配置,同时配合智能容灾策略和...
2. 添加副本节点:先添加为主节点,再通过`CLUSTER REPLICATE`命令将其设置为其他节点的副本。 五、集群操作 1. 数据操作:客户端连接任意节点,通过槽定位数据并进行读写操作。 2. 监控集群状态:使用`CLUSTER ...
适合的读者包括但不限于数据库管理员、系统管理员、运维工程师以及对MySQL复制感兴趣的软件开发者。 **1.4 作业内容和范围** 本指南将详细解释MySQL 5.6的复制过程,从安装MySQL开始,到配置主从复制,再到进行性能...
MySQL 高可用负载均衡集群部署 MySQL 高可用负载均衡集群部署是指在 MySQL 数据库中实现高可用性和负载均衡,以提高数据库的性能和可靠性。在本文中,我们将介绍如何使用 haproxy 和 keepalived 实现 MySQL 高可用...
### 构建高可用的MySQL主主复制方案 在当今高度依赖数据稳定性的环境中,确保数据库系统的高可用性成为IT架构师关注的重点之一。本文将详细介绍如何利用Heartbeat与Ldirectord工具配合MySQL来实现主主复制,进而...
MySQL Replicate 容灾方案 MySQL 是最流行的开源关系数据库管理系统之一,随着数据规模的增长,数据库的可用性和灾备恢复能力变得越来越重要。MySQL Replicate 是一种常用的容灾解决方案,可以确保数据库的高可用性...
MySQL复制是一种强大的功能,它允许数据在多个服务器之间实时同步,从而实现高可用性、负载均衡和数据备份。以下是该书可能涵盖的一些关键知识点: 1. **复制的基本概念**:书中会介绍复制的基本工作原理,包括主从...
MySQL 主从复制环境搭建 MySQL 是一个轻量级的开源框架,具有速度快、多线程、多用户和跨平台等特点。MySQL 主从复制是指将一个 MySQL 服务器的数据实时同步到另一个 MySQL 服务器上,通常用于提高数据安全、负载...