MaxScale2.2如何自动加载MySQL用户

之前在[《MySQL性能管理及架构设计》请添加链接描述](https://coding.imooc.com/class/49.html)课程中为大家讲解了如何使用Maxscale来实现数据库的读写分离的方案。近期在课程交流群中有同学提出在使用Maxscale2.2版本时,无法自动加载MySQL5.7中的用户信息。
所以我就研究了一下新版本的Maxscale,发现确实如此,这是什么原因呢?由如何解决这个问题呢?

我们先来说一说原因,我们来看一下下面的SQL
SELECT u.user, u.host, d.db, u.select_priv, u.authentication_string
FROM mysql.user AS u LEFT JOIN
mysql.db AS d ON (u.user = d.user AND u.host =
d.host)
WHERE u.plugin = ‘‘ AND u.user NOT IN (‘root‘)
UNION
SELECT u.user, u.host, t.db, u.select_priv, u.authentication_string
FROM mysql.user AS u LEFT JOIN
mysql.tables_priv AS t ON (u.user = t.user AND u.host = t.host)
WHERE u.plugin = ‘‘ AND u.user NOT IN (‘root‘)
这个是MaxScale为了加载MySQL的用户,所执行的SQL,大家注意一下u.plugin=‘‘这个过滤条件,这个plugin列来自于mysql.user用户,用于表示MySQL认证用户的方式,在Mysql5.6之前的版本中默认为‘‘,而在MySQL5.6之后的版本默认值为mysql_native_password.所以在新版本的MySQL中执行这个SQL是查询不出任何数据,这也就是为什么MaxScale不能加载MySQL用户的原因了。不过有意思的是,在mariadb中plugin这一列目前还是一直保持默认为‘‘的状态,所以如果maxscale的端连接的是Mariadb则不会出现问题。
原因找到了,那么我们怎么解决呢?
当然是修改maxscale中的这条SQL了,好在我们可以方便的获得maxscale的源代码。我们可以通过下面的方式获得maxscale的源代码
git clone https://github.com/mariadb-corporation/MaxScale.git
然后对
server/modules/authenticator/MySQLAuth/dbusers.c文件进行修改,把从第45行到51行的SQL,修改为:

define NEW_LOAD_DBUSERS_QUERY "
SELECT u.user, u.host, d.db, u.select_priv, u.%s \
FROM mysql.user AS u LEFT JOIN mysql.db AS d \
ON (u.user = d.user AND u.host = d.host) WHERE u.plugin = ‘mysql_native_password‘ %s \
UNION \
SELECT u.user, u.host, t.db, u.select_priv, u.%s \
FROM mysql.user AS u LEFT JOIN mysql.tables_priv AS t \
ON (u.user = t.user AND u.host = t.host) WHERE u.plugin = ‘mysql_native_password‘ %s"
然后再对修改后的源码进行编译安装就可以了。最后如果大家对MySQL感兴趣的话可以关注一下我之前所发布的MySQL两门实战课程。
《MySQL性能管理及架构设计》
《高性能可扩展MySQL数据库设计及架构优化 电商项目》

原文地址:http://blog.51cto.com/sqlercn/2083112

时间: 2024-11-29 09:46:05

MaxScale2.2如何自动加载MySQL用户的相关文章

如何在tomcat启动时自动加载一个类

有时候在开发web应用的时候,需要tomcat启动后自动加载一个用户的类,执行一些初始化方法,如从数据库中加载业务字典到内存中,因此需要在tomcat启动时就自动加载一个类,或运行一个类的方法. 可以采用在WEB-INF/web.xml中添加一个监听程序(ServletContextListener配置项),步骤如下:1) 增加一个监听程序 MyServletContextListener.java, 实现javax.servlet.ServletContextListener接口 packag

Phalcon自动加载(PHP自动加载)

自动加载(phalcon\Loader) 转载请注明来源 一.php文件引入 通过 include() 或 require() 函数,可以在PHP程序执行之前在该文件中插入一个文件的内容. 区别:处理错误的方式不同.include() 函数会生成一个警告(但是脚本会继续执行),而 require() 函数会生成一个致命错误(fatal error)(在错误发生后脚本会停止执行) * 正因为在文件不存在或被重命名后脚本不会继续执行,因此我们推荐使用 require() 而不是 include().

final,类的自动加载,命名空间

final是干什么的一般是为了防止父类的一个方法被重写如果父类中的方法被声明为 final,则子类无法覆盖该方法.如果一个类被声明为 final,则不能被继承. Note: 属性不能被定义为 final,只有类和方法才能被定义为 final. 类的自动加载类的自动加载是指,在外面的页面中,并不需要去"引入"类文件,但是程序会在需要的时候动态加载需要的类文件. spl_autoload_register() 函数可以注册任意数量的自动加载器,当使用尚未被定义的类(class)和接口(in

访问修饰限定符的简单总结、final/abstruct/interface对类的限制、自动加载机制、序列化与反序列化【数据持久化和对象的序列化问题】、对象的拷贝(按引用是因为对象标识)和克隆(__clone方法中的this指向)

1.针对访问修饰限定符的理解只需要两点:(1)针对的是类的概念和访问代码的位置来确定是否能够访问(2)对访问修饰限定符的使用时只需要对该成员的使用场景注意即可[也就是内部,继承类,外部进行访问的权限] 不需要对内部进行太多理解[需要对php底层理解时进行理解] [重点][用途]通过访问修饰限定符将内部成员的权限合理的限制,然后再使用公共接口来调用这个基本服务,保证外部不能访问其内部的构件[这样既能够通过类内的设置,将内部的功能实现更好的限制,只有最外层的接口可以正常被访问到,而不了解内部的业务]

laravel的源码解析:PHP自动加载功能原理解析

前言 这篇文章是对PHP自动加载功能的一个总结,内容涉及PHP的自动加载功能.PHP的命名空间.PHP的PSR0与PSR4标准等内容. 一.PHP自动加载功能 PHP自动加载功能的由来 在PHP开发过程中,如果希望从外部引入一个 class,通常会使用 include 和 require 方法,去把定义这个 class 的文件包含进来.这个在小规模开发的时候,没什么大问题.但在大型的开发项目中,使用这种方式会带来一些隐含的问题:如果一个 PHP 文件需要使用很多其它类,那么就需要很多的 requ

PHP的类文件自动加载机制

搜集于网络,学习php的类的自动加载机制,在实际大型项目中其重要性尤为突出. PHP的类自动加载机制 在PHP开发过程中,如果希望从外部引入一个class,通常会使用include和require方法,去把定义这个class的文件包含进来.这个在小规模开发的时候,没什么大问题.但在大型的开发项目中,这么做会产生大量的require或者include方法调用,这样不因降低效率,而且使得代码难以维护,况且require_once的代价很大. 在PHP5之前,各个PHP框架如果要实现类的自动加载,一般

php 自动加载函数、自动加载方法、自动加载类

在PHP开发过程中,如果希望从 外部引入一个class,通常会使用include和require方法,去把定义这个class的文件包含进来.这个在小规模开发的时候,没什么大问 题.但在大型的开发项目中,这么做会产生大量的require或者include方法调用,这样不因降低效率,而且使得代码难以维护,况且 require_once的代价很大. 在PHP5之前,各个PHP框架如果要实现类的自动加载,一般都是按照某种约定自己实现一个遍历 目录,自动加载所有符合约定规则的文件的类或函数. 当然,PHP

PHP命名空间和自动加载初探

参考资料: PHP手册-语言参考:http://php.net/manual/zh/language.namespaces.php 概要: 1. 声明了命名空间之后,下面的const, function, class都会划归到该命名空间. 2. 只有声明过命名空间的PHP 文件才能加载有命名空间的PHP文件. 3. PHP 5.3 及以上才能使用命名空间 名词: 关键字:namespace 用来声明 本PHP文件的命名空间 常量:__NAMESPACE__ 用来返回当前命名空间的名称 默认为空字

手机H5页面,滑动到底部自动加载下一页内容

做公众号项目中有如下场景,一个H5页面有列表数据,不考虑一次加载所有数据,故需要分页操作,解决方案为滑动到底部自动加载下一页内容.直接在H5的js当中实现. 主要使用jquery的scroll()方法: 当用户滚动指定的元素时,会发生 scroll 事件. scroll 事件适用于所有可滚动的元素和 window 对象(浏览器窗口). scroll() 方法触发 scroll 事件,或规定当发生 scroll 事件时运行的函数. 代码如下: $(window).scroll(function()