iis服务器助手广告
返回顶部
首页 > 资讯 > 数据库 >An Overview of PG & MySQL
  • 367
分享到

An Overview of PG & MySQL

2024-04-02 19:04:59 367人浏览 薄情痞子
摘要

本博客的目的在于简述Mysql和postgresql之间如何跨数据库进行复制。涉及跨数据库复制的databases一般被称作异构databases。这是将数据从一种RDBMS server复制到另一种ser

本博客的目的在于简述Mysqlpostgresql之间如何跨数据库进行复制。涉及跨数据库复制的databases一般被称作异构databases。这是将数据从一种RDBMS server复制到另一种server的一种很好的方法。

Postgresqlmysql都是传统的RDBMS数据库,但是他们也提供了NoSQL的能力。本文主要从RDBMS的角度讨论PostgreSQL和MySQL之间的复制问题。不对复制内部机制做详细介绍,只对一些基本元素、如何配置、有点、限制以及一些使用案例进行阐述。

通常情况下,两个种类相同的主备之间使用binary模式或者query模式进行复制。复制的目的在于,在备上能够得到主的实时备份数据,从而形成一个active-passive模式(因为复制只配置单向复制)。当然,也可以配置成向同步,构建active-active模式。

可以在两个不同数据库server之间配置上面的两种模式,其中一个数据库server可以配置从另外一个完全不同的数据库server上接收副本数据并维护副本数据的实时快照。MySQL和PostgreSQL通过原生机制或者第三方插件(包括binlog方法、磁盘块方法、基于语句和行的方法)完成上面提到的模式。

由于MySQL和PostgreSQL使用不同的复制协议,所以他们之间不能互相交互。为了达到通信流的目的,可以使用一个开源软件pg_chameleon。

pg_chameleon背景

pg_chameleon是由python3开发的MySQL to PG的复制工具。该插件也会使用一个mysql-replication的开源库,该库也是由python3开发。从MySQL表中拉取行镜像并存储成JSONB形式,然后同步到PG数据库。PG数据库通过pl/pgsql进行解析并回放。

pg_chameleon特性

1、同一个集群中多个MySQL schema可以复制到一个PG database,形成many-to-one复制模式。

2、源和目的schema名可以不一样

3、复制数据可以从mysql级联副本中拉取。

4、会排除复制失败的表及复制过程中产生错误的表。

5、每个复制功能通过守护进程进行管理

6、配置参数和配置文件以yaml结构进行控制。

Demo

Host

Vm1

Vm2

操作系统

Centos linux release 7.6 x86_64

Centos linux release 7.5 x86_64

数据库版本

MySQL5.7.26

PostgreSQL10.5

数据库端口号

3306

5433

IP地址

192.168.56.102

192.168.56.106

 

首先需要安装Python,他在创建虚拟环境以及激活的时候会用到。

$> wget https://www.python.org/ftp/python/3.6.8/Python-3.6.8.tar.xz$> tar -xJf Python-3.6.8.tar.xz$> cd Python-3.6.8$> ./configure --enable-optimizations$> make altinstall

安装成功后需要创建并激活虚拟环境。另外需要将pip模块升级到最新版本。pg_chameleon最新版本是2.0.10,为了不引入新的bug,建议先使用2.0.9版本。

$> python3.6 -m venv venv$> source venv/bin/activate(venv) $> pip install pip --upgrade(venv) $> pip install pg_chameleon==2.0.9

下一步需要通过set_configuration_files配置启用pg_chameleon,并创建默认路径以及配置文件:

(venv) $> chameleon set_configuration_filescreating directory /root/.pg_chameleoncreating directory /root/.pg_chameleon/configuration/creating directory /root/.pg_chameleon/logs/creating directory /root/.pg_chameleon/pid/copying configuration  example in /root/.pg_chameleon/configuration//config-example.yml

此时,创建一个config-example.yml文件作为默认的配置文件。一个简单的配置例子如下所示:

$> cat default.yml---#global settingspid_dir: '~/.pg_chameleon/pid/'log_dir: '~/.pg_chameleon/logs/'log_dest: filelog_level: infolog_days_keep: 10rollbar_key: ''rollbar_env: ''# type_override allows the user to override the default type conversion into a different one.type_override:  "tinyint(1)":    override_to: boolean    override_tables:      - "*"#postgres  destination connectionpg_conn:  host: "192.168.56.106"  port: "5433"  user: "usr_replica"  passWord: "pass123"  database: "db_replica"  charset: "utf8"sources:  mysql:    db_conn:      host: "192.168.56.102"      port: "3306"      user: "usr_replica"      password: "pass123"      charset: 'utf8'      connect_timeout: 10    schema_mappings:      world_x: pgworld_x    limit_tables:#      - delphis_mediterranea.foo    skip_tables:#      - delphis_mediterranea.bar    grant_select_to:      - usr_readonly    lock_timeout: "120s"    my_server_id: 100    replica_batch_size: 10000    replay_max_rows: 10000    batch_retention: '1 day'    copy_max_memory: "300M"    copy_mode: 'file'    out_dir: /tmp    sleep_loop: 1    on_error_replay: continue    on_error_read: continue    auto_maintenance: "disabled"    gtid_enable: No    type: mysql    skip_events:      insert:        - delphis_mediterranea.foo #skips inserts on the table delphis_mediterranea.foo      delete:        - delphis_mediterranea #skips deletes on schema delphis_mediterranea      update:

本文使用的配置文件是pg_chameleon提供的样例文件改造过的,以适应源和目标环境。下面是配置文件改造的摘要。

默认情况下.yml文件有“global settings”段,用以控制详细信息比如文件位置、日志位置、日志保留期等。接着是“type override”段,这部分是在复制期间重写类型的集合。默认情况下使用样本类型重写规则,即将tinyint(1)转换成布尔值。然后是“pg_conn”,是目标数据库连接的详细信息。最后一部分是源数据库信息,控制源数据库的连接、源和目标直接的schema映射、需要跳过不复制的表、时间超时、内存等配置。注意,“sources”表示可以有多个源。

本文使用的demo中有一个“world_x”database,包括4个表,MySQL社区提供了下载位置:Https://dev.mysql.com/doc/index-other.html

在MySQL和PostgreSQL中都需要创建一个专用用户“usr_replica”,用以复制。在MySQL中该用户需要赋予额外的权限用以访问需要复制表:

mysql> CREATE USER usr_replica ;mysql> SET PASSWORD FOR usr_replica='pass123';mysql> GRANT ALL ON world_x.* TO 'usr_replica';mysql> GRANT RELOAD ON *.* to 'usr_replica';mysql> GRANT REPLICATION CLIENT ON *.* to 'usr_replica';mysql> GRANT REPLICATION SLAVE ON *.* to 'usr_replica';mysql> FLUSH PRIVILEGES;

PostgreSQL段创建一个“db_replica”database用以接收MySQL数据。PG中的“usr_replica”用户自动配置成两个schemas(pgworld_x和sch_chameleon)的拥有者。这两个schema包含实际复制表和catalog表。通过create_replica_schema参数自动配置:

postgres=# CREATE USER usr_replica WITH PASSWORD 'pass123';CREATE ROLEpostgres=# CREATE DATABASE db_replica WITH OWNER usr_replica;CREATE DATABASE

MySQL配置如下,需重启服务才能生效:

$> vi /etc/my.cnfbinlog_fORMat= ROWbinlog_row_image=FULLlog-bin = mysql-binserver-id = 1

此时需要测试下连接是否正常,保证执行pg_chameleon命令时不出问题:

PostgreSQL端:

$> mysql -u usr_replica -Ap'admin123' -h 192.168.56.102 -D world_x

MySQL端:

psql -p 5433 -U usr_replica -h 192.168.56.106 db_replica

下面pg_chameleon的3个命令时搭建环境时执行,添加源并初始化一个备。“create_replica_schema”创建默认的schema(sch_chameleon)以及复制的schema(pgworld_x)。“add_source”通过读取配置文件信息添加source database,本文中是“mysql”。“init_replica”基于配置文件进行初始化。

$> chameleon create_replica_schema --debug$> chameleon add_source --config default --source mysql --debug$> chameleon init_replica --config default --source mysql --debug

上面的三个命令执行成功后,会分别输出明显的执行成功信息。任何错误和语法错误都会清晰的输出。

最后一步是通过“start_replica”启动复制:

$> chameleon start_replica --config default --source mysqloutput: Starting the replica process for source mysql

通过show_status显示复制状态:

$> chameleon show_status --source mysql OUTPUT:  Source id  Source name    Type    Status    Consistent    Read lag    Last read    Replay lag    Last replay-----------  -------------  ------  --------  ------------  ----------  -----------  ------------  -------------          1  mysql          mysql   running   No            N/A                      N/A== Schema mappings ==Origin schema    Destination schema---------------  --------------------world_x          pgworld_x== Replica status ==---------------------  ---Tables not replicated  0Tables replicated      4All tables             4Last maintenance       N/ANext maintenance       N/AReplayed rowsReplayed DDLSkipped rows---------------------  ---$> chameleon show_errors --config defaultoutput: There are no errors in the log

通过ps命令查看守护进程:

$>  ps -ef|grep chameleonroot       763     1  0 19:20 ?        00:00:00 /u01/media/mysql_samp_dbs/world_x-db/venv/bin/python3.6 /u01/media/mysq l_samp_dbs/world_x-db/venv/bin/chameleon start_replica --config default --source mysqlroot       764   763  0 19:20 ?        00:00:01 /u01/media/mysql_samp_dbs/world_x-db/venv/bin/python3.6 /u01/media/mysq l_samp_dbs/world_x-db/venv/bin/chameleon start_replica --config default --source mysqlroot       765   763  0 19:20 ?        00:00:00 /u01/media/mysql_samp_dbs/world_x-db/venv/bin/python3.6 /u01/media/mysq l_samp_dbs/world_x-db/venv/bin/chameleon start_replica --config default --source mysql

直到“real-time 回放”搭建复制才能完成。涉及创建表、向MySQL数据库中插入数据;PG的sync_tables命令更新守护进程并将表记录复制到PG:

mysql> create table t1 (n1 int primary key, n2 varchar(10));Query OK, 0 rows affected (0.01 sec)mysql> insert into t1 values (1,'one');Query OK, 1 row affected (0.00 sec)mysql> insert into t1 values (2,'two');Query OK, 1 row affected (0.00 sec)
$> chameleon sync_tables --tables world_x.t1 --config default --source mysqlSync tables process for source mysql started.

测试确认复制正常:

$> psql -p 5433 -U usr_replica -d db_replica -c "select * from pgworld_x.t1"; n1 |  n2----+-------  1 | one  2 | two

如果是一个迁移需求,执行下面命令标记迁移结束。在所有需要复制的表复制完成后执行这些命令:

$> chameleon stop_replica --config default --source mysql$> chameleon detach_replica --config default --source mysql --debug

下面的命令可选:

$> chameleon drop_source --config default --source mysql --debug$> chameleon drop_replica_schema --config default --source mysql --debug

Pros of Using pg_chameleon

安装并配置比较简单

错误日志易看懂

无需更改任何配置,初始化完成后可以添加额外的复制表

可配置成多源复制

可以指定不复制哪些表

Cons of Using pg_chameleon

仅支持MySQL5.5及其以上的版本到Pg9.5及其以上之间进行复制

每个复制表需要有主键或唯一键

只能MySQL到PG

总结

pg_chameleon工具提供从MySQL向PG迁移的方法。然而只能单向复制。这个缺点可以使用另外一个工具SymmetricDS来弥补。文档:https://pGChameleon.org/documents/;命令行说明:https://pgchameleon.org/documents/usage.html#command-line-reference

原文

https://severalnines.com/blog/overview-postgresql-mysql-cross-replication


您可能感兴趣的文档:

--结束END--

本文标题: An Overview of PG & MySQL

本文链接: https://www.lsjlt.com/news/44287.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 什么是SQL注入如何在SQL Server中防止它
    SQL注入是一种针对数据库的攻击技术,攻击者利用Web应用程序中的漏洞向数据库中插入恶意的SQL查询,以获取对数据库的非法访问权限或篡改数据。在SQL Server中可以通过以下方法来防止SQL注入: 使用参数化查询:参数化查询是一种将...
    99+
    2024-06-04
    sql server
  • 描述SQL Server中的不同备份类型及其用途
    SQL Server中有多种备份类型,每种备份类型都有其特定的用途。以下是一些常见的备份类型及其用途: 完整备份(Full Backup):完整备份是对整个数据库的备份,包括所有数据和日志。这种备份类型是最全面的备份,用于恢复整个数据库...
    99+
    2024-06-04
    sql server
  • 在SQL Server中使用XML数据的最佳实践是什么
    在SQL Server中使用XML数据时,以下是一些最佳实践: 使用XML数据类型:SQL Server提供了XML数据类型,可以存储和操作XML数据。使用XML数据类型可以有效地存储和查询XML数据,同时提高性能和可读性。 使用X...
    99+
    2024-06-04
    sql server
  • 解释SQL Server中的日志文件和数据文件
    SQL Server中的日志文件和数据文件是关系数据库中的两种主要文件类型,用于存储数据库的数据和日志信息。 数据文件包含了实际存储在数据库中的数据,包括表、索引、存储过程等。数据文件通常具有扩展名为.mdf。每个数据库至少有一个数据文件,...
    99+
    2024-06-04
    sql server
  • 描述SQL Server在容器中运行的支持情况和优势
    SQL Server 在容器中运行的支持情况和优势如下: 支持情况: Microsoft 官方已经发布了 SQL Server 的容器镜像,可以直接从 Docker Hub 上拉取使用。 SQL Server 2017 及以上版本支持在 ...
    99+
    2024-06-04
    sql server
  • SQL Server中的镜像和Always On之间有什么区别
    SQL Server中的镜像(Database Mirroring)和Always On是两种提供高可用性和灾难恢复的技术,但它们有一些区别: Mirroring是SQL Server 2005和2012版本中引入的一种技术,主要用于数...
    99+
    2024-06-04
    sql server
  • 解释SQL Server中的Data Virtualization技术及其用途
    Data Virtualization是一种数据集成技术,通过这种技术,用户可以使用SQL查询来访问和操作分布在不同数据源中的数据,而无需复制或移动数据。在SQL Server中,Data Virtualization技术可以通过使用Lin...
    99+
    2024-06-04
    sql server
  • 描述SQL Server中索引碎片的影响以及如何处理它
    索引碎片是指索引中数据的物理存储并非按照逻辑顺序排列,导致数据库性能下降的情况。索引碎片会增加查询的成本,降低数据库的性能。 处理索引碎片的方法包括重新组织索引和重建索引。重新组织索引是通过重新排列索引中的数据来减少碎片,而不会改变索引的定...
    99+
    2024-06-04
    sql server
  • 在SQL Server中什么是故障转移群集实例
    在SQL Server中,故障转移群集实例是一种高可用性解决方案,用于确保数据库实例的持续可用性。故障转移群集实例是一组运行在不同服务器上的SQL Server实例,这些实例共享相同的数据库,并通过Windows故障转移群集服务来监视和管理...
    99+
    2024-06-04
    sql server
  • 如何使用SQL Server的执行计划分析慢查询
    要使用SQL Server的执行计划来分析慢查询,可以按照以下步骤操作: 打开SQL Server Management Studio并连接到您的数据库服务器。 在查询窗口中输入您想要分析的慢查询,并执行该查询。 在查询结果窗口...
    99+
    2024-06-04
    sql server
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作