这种架构一般用在以下三类场景
1. 备份多台 Server 的数据到一台如果按照数据切分方向来讲,那就是垂直切分。比如图 2,业务 A、B、C、D 是之前拆分好的业务,现在需要把这些拆分好的业务汇总起来备份,那这种需求也很适用于多源复制架构。实现方法我大概描述下:业务 A、B、C、D 分别位于 4 台 Server,每台 Server 分别有一个数据库来隔离前端的业务数据,那这样,在从库就能把四台业务的数据全部汇总起来,而不需要做额外的操作。那没有多源复制之前,要实现这类需求,只能在汇总机器上搭建多个 MySQL 实例,那这样势必会涉及到跨库关联的问题,不但性能急剧下降,管理多个实例也没有单台来的容易。
2. 用来聚合前端多个 Server 的分片数据。
同样,按照数据切分方向来讲,属于水平切分。比如图 3,按照年份拆分好的数据,要做一个汇总数据展现,那这种架构也非常合适。实现方法稍微复杂些:比如所有 Server 共享同一数据库和表,一般为了开发极端透明,前端配置有分库分表的中间件,比如爱可生的 DBLE。
3. 汇总并合并多个 Server 的数据
第三类和第一种场景类似。不一样的是不仅仅是数据需要汇总到目标端,还得合并这些数据,这就比第一种来的相对复杂些。比如图 4,那这样的需求,是不是也适合多源复制呢?答案是 YES。那具体怎么做呢?
你可以在安装软件后再创建数据库,这个数量可以是多个。安装ORACLE时,如选择仅安装软件,则安装结束后无数据库。你可以继续创建数据库。实例是一个正在进行时的概念,每当启动一个数据库时,ORACLE会依照初始化参数文件spfile的记录分配内存,启动进程,查找相关文件,而当数据库关闭后,实例的寿命也就终止了,再启动就是一个新的实例,可以简单理解为实例就是内存和进程的集合,与物理文件没有关联,你完全可以删除实例,然后用oradmin来创建一个新实例,然后启动数据库,只要物理文件没有问题。多个实例可对应一个数据库,它们共同操作同一数据文件。但你要说多个数据库,应该是指要创建不同的物理文件,而一个实例不能管理多个数据库。
以mysql数据库为例。1、登录mysql
参数说明:-u为mysql用户名默认用户为root;-h为mysql服务器的ip本机默认为127.0.0.1;-p为使用密码登录,输入正确密码则登录成功
mysql -u root -p -h127.0.0.1
2、创建新数据库
参数说明:zhihu替换为要新建的数据库名
CREATE DATABASE zhihu
3、创建新数据库登录用户(若使用老用户则可以跳过此步)
参数说明:分别填入允许登录的ip,用户名,密码
insert into mysql.user(Host,User,Password) values('localhost','zhihu',password('zhihupassword'))
4、更新用户配置表信息
说明:执行这几条语句之后,就创建了一个数据库名为zhihu,用户名为zhihu,密码为zhihupassword的用户。
flush privileges
5、授权用户在新数据的操作权限
说明:执行下面这条语句之后,就开启了zhihu这个用户在zhihu数据库的所有操作权限,如果有特别的闲置可以将*替换为具体的权限(select,update,delete)
grant all privileges on zhihu.* to zhihu@localhost identified by 'zhihupassword'
6、更新用户配置表信息
flush privileges
php方面登录新数据库即可。
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)