mysql中5.6和5.5有什么区别

区别:1、在5.5版本中主从配置不能省略binlog和POS两个参数,而在5.6版本中这两个参数可以省略;2、在5.5版本中不支持多线程复制,同步复制是单线程、队列的,而在5.6版本中支持多线程复制。

mysql中5.6和5.5有什么区别

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql中5.6和5.5有什么区别

5.6的改进地方:

1、在5.5和之前的版本mysql中,主从配置的话,要在从节点配置change master to 指明binlog和POS。而在5.6及以后

,这2个参数就可以省略掉。MySQL可以通过内部的GTID机制自动找点同步。我们只要指明master的IP、用户名和密码、端口即可。

2、5.6支持多线程复制

在5.5里,同步复制是单线程、队列的,只能一个的执行。而在5.6里,多个库可以同时进行复制(注意:同一个库内仍是不能多线程了)。

5.6里会涉及到UUID这个参数

MySQL [(none)]>show variables like '%uuid%';+---------------+--------------------------------------+| Variable_name | Value                                |+---------------+--------------------------------------+| server_uuid   | ca910cf0-3aec-11e6-9319-b888e3dcfeb8 |+---------------+--------------------------------------+1 row in set (0.00 sec)

注意:在mysql初次启动时候会自动生成这个UIID,写入到auto.cnf中,官方不建议修改这个值。并且server_uuid和GTID有密切关系。

GTID:全局事务标识符

使用这个功能时,每次事务提交都会在binlog里生成唯一的标识符,它由UUID和事务ID组成。首次提交的事务ID为1,以后依次递增。

开启GTID时,slave做同步复制时,无需找到binlog日志和POS点。直接

GTID写法:

change master tomaster_HOST=192.168.2.100,master_PORT=2206,master_USER=repluser,master_PASSWORD='123456',master_AUTO_POSITION=1;另外传统的写法:CHANGE MASTER TOMASTER_HOST='master2.mycompany.com',MASTER_USER='replication',MASTER_PASSWORD='bigs3cret',MASTER_PORT=3306,MASTER_LOG_FILE='master2-bin.001',MASTER_LOG_POS=4,MASTER_CONNECT_RETRY=10;

如果之前启用过了GTID,那么就不能不能再使用传统的change master to的方式了,会报错,如下:

ERROR 1776 (HY000): Parameters MASTER_LOG_FILE, MASTER_LOG_POS, RELAY_LOG_FILE and RELAY_LOG_POS cannot be set when MASTER_AUTO_POSITION is active.

31a42737cfc54aa1d92bc07cb63fe7a4.png

GTID的工作流程:

1、在master上提交一个事务,并写入到binlog

2、binlog发送到slave上,slave接收并写入relay log,slave读取到这个GTID,并设置gtid_next的值。例如:

set @@SESSION.GTID_NEXT=’B0869D03-D332223-35454:3′;

然后告诉slave接下来的事务必须使用GTID,并写入到自己的binlog中。

3、slave检查并确认这个gtid没有被使用,如果没有被使用,那么开始执行这个事务并写入到它自己的binlog里。

4、由于gtid_next的值不是空的,slave不会尝试去生成一个新的gtid,而是通过主从同步来获的GTID。

另外,要使用GTID方式进行主从同步的话,还要在my.cnf里面加上如下的配置:

[mysqld]log-bin=mysql-binbinlog_format = mixedlog_slave_updates = ONgtid-mode = ONenforce_gtid_consistency = ON

然后在master上导出mysqldump -uroot -proot -q –single-transaction -R -E –triggers -B hellodb > /root/hello.sql

在slave上导入mysql -uroot -proot < /root/hello.sql

在slave上配置change master to指向(如下6行代码):

change master tomaster_HOST=192.168.2.100,master_PORT=3306,master_USER=repluser,master_PASSWORD='123456',master_AUTO_POSITION=1;

GTID的局限性:

1、GTID的复制是基于事务的,不支持MyISAM,这可能导致多个GTID分配各同一个事务。

2、对create table … select语句不支持。因为该语句会被拆分成create table和insert 两个事务,并且如果这两个事务被分配了同一个GTID,将会导致insert被备库忽略掉。

3、不支持创建、删除临时表

多线程复制演示:

在slave上执行下面几条命令:

> stop slave;> set global  slave_parallel_workers = 4;> start slave;> show full processlist;可以看到有4个线程 Waitingfor an eventfromCoordinator

如果此时在主上有大量的insert操作,可以在slave上执行> select * from mysql.slave_worker_infoG 应该可以查看到worker_id在不断变化,说明是多线程复制在起作用了。

说明:slave_parallel_workers 即可实现在slave上多线程并发复制。不过,它只能支持一个实例下多个 database 间的并发复制,并不能真正做到多表并发复制。因此在较大并发负载时,slave还是没有办法及时追上master,需要想办法进行优化(比如:尽量将一个库中的表按照业务逻辑拆分成多个库来保存,这样在写操作时候,slave就能开启多线程复制,减少了同步的时延。)

此外,建议修改my.cnf,增加2行(默认这个info_file是文件的,不写入数据库的)

relay_log_info_repository = tablemaster_info_repository = table

单单这样还不够,默认这2张表是MyISAM的,不安全还要转换下

> alter table slave_master_info engine innodb;> alter table slave_relay_log_info engine innodb;> alter table slave_worker_info engine innodb;

这样的话,可防止表损坏,在损坏后可以自行修复。

GTID模式下的主从复制,同步时候报错不能跳过的解决方法:

假如在slave上看到同步报错“从节点的XXX键不存在”

我们可以尝试使用5.5上的老方法

> stop slave;> set global sql_slave_skip_counter=1> start slave;

执行的时候会发现报错了,提示如下:

bd20dddcc8e8e040e3c3b42bb78dfa82.png

可以看出运行在GTID模式下,不支持sql_slave_skip_counter这种方式跳过的。

那么可以如下方法来跳过:

> show  slave statusG查看如下2行的信息:

Retrieved_Gtid_Set: ca910cf0-3aec-11e6-9319-b888e3dcfeb8:1-2Executed_Gtid_Set: ca910cf0-3aec-11e6-9319-b888e3dcfeb8:1

第一行表示收到的事务,第二行表示已经执行完的事务。也就是说执行到Retrieved_Gtid_Set时候发生错误了。

因此,我们直接单单跳过这个事务即可。

> stop slave;> set GTID_NEXT='ca910cf0-3aec-11e6-9319-b888e3dcfeb8:2';     就是这种写法,不要加什么1-2这些玩意> begin;> commit;> set GTID_NEXT="AUTOMATIC";      #把gtid_next设置回来> start slave;> show slave statusG   验证下是否IO/SQL都是YES状态。

GTID模式转换为传统模式的方法及注意点:

要转换成传统模式,需要在my.cnf里面注释掉下面2行:

# gtid-mode=ON# enforce_gtid_consistency = ON

然后重启MySQL。

登进mysql,执行类似如下命令:

> stop slave;> CHANGE MASTER TOMASTER_HOST='master2.mycompany.com',MASTER_USER='replication',MASTER_PASSWORD='bigs3cret',MASTER_PORT=3306,MASTER_LOG_FILE='master2-bin.001',MASTER_LOG_POS=4,MASTER_CONNECT_RETRY=10;

结果报错了,如下图:

b2841fbd0bb844f34762aea1d2688e0a.png

解决方法:

> change master to MASTER_AUTO_POSITION=0;     # 关闭这个参数,这个参数是GTID复制才用到的。> CHANGE MASTER TOMASTER_HOST = '192.168.2.11',MASTER_USER='repluser',MASTER_PASSWORD='123456',MASTER_PORT=3306,MASTER_LOG_FILE='mysql-bin.000012',MASTER_LOG_POS=500,MASTER_CONNECT_RETRY=10;> start slave;> show slave statusG 验证下是否IO/SQL都是YES状态。

推荐学习:mysql视频教程

以上就是mysql中5.6和5.5有什么区别的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/177705.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月1日 05:58:47
下一篇 2025年11月1日 05:59:37

相关推荐

  • Golang简单博客系统开发实战

    答案:用Go语言可快速搭建一个具备文章发布、查看和管理功能的简单博客系统。通过合理设计项目结构,定义文章模型并使用内存存储,结合HTTP路由与处理器实现CRUD操作,利用模板引擎渲染HTML页面,并提供静态资源访问支持,最终运行服务即可在浏览器中访问基础博客首页,具备完整雏形且易于扩展。 想快速上手…

    2025年12月16日
    000
  • Golang包重命名与导入别名使用方法

    在Go语言中,包重命名通过import别名解决命名冲突、提升可读性。例如import ( myfmt “fmt” )将fmt重命名为myfmt,后续用myfmt.Println调用;当导入同名包如json和jsoniter时,别名可明确区分标准库与第三方;使用_进行匿名导入可…

    2025年12月16日
    000
  • Go语言中实现动态IN查询的指南

    本文详细介绍了在Go语言中使用database/sql包执行带有动态参数列表的IN查询的方法。由于database/sql不直接支持将切片作为单个占位符的参数,因此需要通过动态生成SQL占位符字符串并使用interface{}切片配合可变参数来构建查询,同时考虑了空切片等边界情况。 理解databa…

    2025年12月16日
    000
  • 数据库连接池性能调优实践

    合理设置连接池参数可提升系统性能,需根据业务特征配置最小/最大连接数、获取超时时间及空闲回收策略;启用借出、归还或空闲时的连接检测机制保障连接有效性;结合监控活跃连接、等待线程等指标持续优化;针对高并发、批处理、读写分离等场景差异化配置,实现资源与稳定的平衡。 数据库连接池是应用系统与数据库之间的重…

    2025年12月16日
    000
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2025年12月16日
    000
  • Go语言连接外部MySQL数据库:DSN配置与常见错误排查

    本文将深入探讨go语言如何使用`database/sql`和`go-sql-driver/mysql`连接外部mysql数据库。我们将详细介绍dsn(数据源名称)的构建方式,并通过一个实际案例分析`getaddrinfow: the specified class was not found.`这一…

    2025年12月16日
    000
  • OAuth认证后的用户数据持久化与安全会话管理

    本教程将深入探讨OAuth2认证流程中,如何高效且安全地处理从身份提供商获取的用户数据,并将其持久化到数据库。我们将介绍使用UPSERT操作来避免数据重复和竞态条件,并详细阐述如何通过配置安全的HTTP-only会话Cookie来建立和维护用户会话,以抵御常见的Web安全威胁,确保用户认证体验的流畅…

    2025年12月16日
    000
  • Go语言database/sql包中处理动态SQL IN 查询的实践指南

    本文详细介绍了在Go语言中使用database/sql包执行动态SQL IN查询的通用方法。针对IN子句无法直接接受切片作为参数的问题,教程重点阐述了如何通过动态生成占位符?并配合可变参数传递切片元素来构建安全高效的查询,并提供了完整的代码示例和注意事项。 在go语言的database/sql包中,…

    2025年12月16日
    000
  • OAuth2认证后用户数据存储与会话安全指南

    本文旨在提供OAuth2认证后处理用户数据持久化和会话管理的最佳实践。我们将探讨如何将OAuth返回的用户数据安全地存储到数据库,推荐使用事务性的UPSERT操作来处理用户存在性检查与插入/更新。同时,文章还将详细阐述如何通过配置安全的HTTP-only会话Cookie来建立和维护用户会话,并强调H…

    2025年12月16日
    000
  • OAuth响应处理与安全会话管理:数据库集成与Cookie最佳实践

    本教程深入探讨了OAuth2认证流程结束后,如何安全高效地处理用户数据并建立会话。文章首先介绍了将OAuth提供者返回的用户数据存储到数据库的最佳实践,重点讲解了原子性的UPSERT操作以避免数据冗余和竞态条件。随后,详细阐述了基于Cookie的会话管理策略,强调了使用HTTPS、Secure、Ht…

    2025年12月16日
    000
  • Go database/sql 包查询结果行数精确判断与首行数据获取

    本文深入探讨Go语言中database/sql包在数据库查询时,如何精确判断返回结果的行数(零行、单行或多行),并安全地获取首行数据。针对QueryRow的局限性,文章提供了一个通用的自定义函数方案,利用db.Query和*sql.Rows的特性,实现对查询结果的细粒度控制,同时强调了错误处理和资源…

    2025年12月16日
    000
  • OAuth2集成:用户数据持久化与安全会话管理指南

    本文旨在探讨OAuth2认证流程结束后,如何高效且安全地处理用户数据持久化与会话管理。我们将重点介绍数据库中用户数据的“存在则更新,不存在则插入”(UPSERT)策略,并深入讲解如何利用HTTPS和安全、HttpOnly的Cookie来建立健壮的用户会话,以确保用户体验和系统安全。 1. OAuth…

    2025年12月16日
    000
  • 在Go语言中处理SQL IN 子句的动态参数绑定

    本文旨在解决Go语言database/sql包中,如何将动态切片(slice)作为IN查询条件参数的问题。由于db.Query无法直接将切片展开为多个占位符,我们将探讨一种通用且安全的解决方案,通过动态生成SQL语句中的占位符并结合interface{}类型转换来实现,确保代码的灵活性和防止SQL注…

    2025年12月16日
    000
  • OAuth 响应处理与安全会话管理实践指南

    本教程旨在指导开发者如何高效且安全地处理 OAuth2 认证流程中获取的用户数据,并将其存储至数据库。文章将重点介绍采用 UPSERT 语句进行数据更新或插入的最佳实践,同时详细阐述如何利用安全 Cookie(如 Secure、HttpOnly 和 Path 选项)构建健壮的用户会话管理机制,规避潜…

    2025年12月16日
    000
  • Go语言database/sql:高效构建和执行带有可变参数的IN查询

    在Go语言中,使用database/sql包执行带有可变参数列表的IN查询时,直接传入切片作为单个占位符是无效的。本文将详细介绍一种通用的解决方案,通过动态生成SQL语句中的占位符(问号),并将切片元素展开为独立的参数传递给db.Query方法,从而优雅地处理IN子句中的可变值集合,并讨论相关注意事…

    2025年12月16日
    000
  • Golang如何实现自动化备份与恢复

    Go语言适合构建自动化备份与恢复系统,其核心是通过调用系统命令或API实现数据备份与恢复。1. 文件备份可使用os和io包复制文件,数据库备份可通过mysqldump等工具或驱动导出;2. 使用robfig/cron库设置定时任务,如每日2点执行备份,并结合systemd或Kubernetes管理任…

    2025年12月16日
    000
  • 如何使用Golang测试数据库操作

    使用事务回滚确保测试隔离,通过传入*sql.Tx实现数据操作函数的可测试性,结合sqlmock模拟SQL验证逻辑,保证测试可重复且无副作用。 测试数据库操作在 Golang 中是确保数据层逻辑正确的重要环节。关键在于隔离真实环境、使用事务控制以及合理模拟数据。以下是具体实践方法。 使用测试数据库或事…

    2025年12月16日
    000
  • Go语言连接MySQL数据库:权限配置与常见问题解决指南

    本文详细探讨Go语言连接MySQL数据库时遇到的常见问题,特别是“Access denied”错误和数据查询无结果的情况。核心问题在于MySQL用户权限配置不当,未能授权通过TCP连接。文章提供了详细的MySQL用户权限设置步骤,并结合Go语言的database/sql接口和go-sql-drive…

    2025年12月16日
    000
  • Go语言连接MySQL数据库:权限配置与常见问题解析

    本文详细介绍了在Go语言中如何连接MySQL数据库,重点解决了常见的“Access Denied”权限错误以及查询结果为空的问题。通过使用go-sql-driver/mysql驱动,文章提供了详细的代码示例,并强调了MySQL用户权限配置的关键性,指导读者正确设置用户权限以确保Go应用程序能顺利访问…

    2025年12月16日
    000
  • Go语言生态系统:Java开发者工具链指南

    本文旨在为Java开发者提供一份Go语言开发生态系统的全面指南,涵盖集成开发环境、依赖管理、持续集成工具以及常用库的对应方案。我们将探讨Go语言在这些方面的独特实践,帮助开发者平滑过渡并高效利用Go的优势,从而提升开发效率和项目管理能力。 1. 集成开发环境(IDE)与代码编辑器 对于习惯了ecli…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信