由于公司现有主库要转移到新的主库上,所以,我打算利用MySQLfailover工具的故障转移。

1、开发把程序账号转移到新主库上

2、停止现有主库,使之进行故障转移,转移期间会自动锁表,保持数据一致性。

3、查看转移状态,检查是否转移成功

在启动MySQLfailover的时候,报错:

The master and one of the candidates are the same host and port.

大概意思是说主库和候选机使用了相同的端口和host。

检查MySQLfailover源码:

# Parse the master, slaves, and candidates connection parameters
try:
  master_val, slaves_val, candidates_val = parse_topology_connections(
    opt)
  except UtilRplError:
    _, e, _ = sys.exc_info()
    print("ERROR: {0}".format(e.errmsg))
    sys.exit(1)

  # Check hostname alias
    for slave_val in slaves_val:
      if check_hostname_alias(master_val, slave_val):
      parser.error("The master and one of the slaves are the same "
        "host and port.")
    for cand_val in candidates_val:
      if check_hostname_alias(master_val, cand_val):
      parser.error("The master and one of the candidates are the same "
        "host and port.")

这段是报错的代码,可以看到是一段异常捕获代码,这里调用了check_hostname_alias()这个函数。查找开头引用:

  from mysql.utilities.common.server import check_hostname_alias

可以看到是引用了server文件里的check_hostname_alias方法。进入common目录下查看:

/usr/lib/python2.6/site-packages/mysql/utilities/common

查看server.py文件:

def check_hostname_alias(server1_vals, server2_vals):

  server1_vals[in] connection dictionary for server1
  server2_vals[in] connection dictionary for server2

  Returns bool - true = server1 and server2 are the same host
    """
  server1 = Server({'conn_info': server1_vals})
  server2 = Server({'conn_info': server2_vals})
  server1_socket = server1_vals.get('unix_socket', None)
  server2_socket = server1_vals.get('unix_socket', None)
  if server1_socket:
    server1.connect()
    server1.disconnect()
  if server2_socket:
    server2.connect()
    server2.disconnect()

  return (server1.is_alias(server2.host) and
    int(server1.port) == int(server2.port))

可以看出,这段代码主要是检查主库和候选机的端口和host,如果相同,则返回一个true。

如果返回true,则会触发到异常捕获代码,从而报错。

可以肯定是因为新主库没有设置Host名称所导致的错误。

这里可以编辑一下check_hostname_alias这个方法,让他返回一个flase就可以了。改成这样:

  return (server1.is_alias(server2.host) and
    int(server1.port) == int(3333))

然后启动MySQLfailover进程,发现不会报错,正常运行了。

MySQLfailover错误一则的更多相关文章

  1. 航空概论(历年资料,引之百度文库,PS:未调格式,有点乱)

    航空航天尔雅 选择题1. 已经实现了<天方夜谭>中的飞毯设想.—— A——美国2. 地球到月球大约—— C 38 万公里3. 建立了航空史上第一条定期空中路线—— B——德国4. 对于孔明 ...

  2. Keepalived + MySQLfailover + GTIDs 高可用

    架构图     10.1.1.207    mysql master + keepalived     10.1.1.206    mysql slave ( backup master ) + ke ...

  3. 日期格式代码出现两次的错误 ORA-01810

    错误的原因是使用了两次MM . 一.Oracle中使用to_date()时格式化日期需要注意格式码 如:select to_date('2005-01-01 11:11:21','yyyy-MM-dd ...

  4. ASP.NET Core应用的错误处理[3]:ExceptionHandlerMiddleware中间件如何呈现“定制化错误页面”

    DeveloperExceptionPageMiddleware中间件利用呈现出来的错误页面实现抛出异常和当前请求的详细信息以辅助开发人员更好地进行纠错诊断工作,而ExceptionHandlerMi ...

  5. ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”

    在<ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式>中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应的中间件来完成,接下来我们将 ...

  6. 实时的.NET程序错误监控产品Exceptionless

    Exceptionless可以对ASP.NET, Web API, WebForms, WPF, Console, 和 MVC 应用提供错误监控.上传.报表服务.使用时需要在Exceptionless ...

  7. 一个粗心的Bug,JSON格式不规范导致AJAX错误

    一.事件回放  今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...

  8. SQL Server 致程序员(容易忽略的错误)

    标签:SQL SERVER/MSSQL/DBA/T-SQL好习惯/数据库/需要注意的地方/程序员/容易犯的错误/遇到的问题 概述 因为每天需要审核程序员发布的SQL语句,所以收集了一些程序员的一些常见 ...

  9. C# - 值类型、引用类型&走出误区,容易错误的说法

    1. 值类型与引用类型小总结 1)对于引用类型的表达式(如一个变量),它的值是一个引用,而非对象. 2)引用就像URL,是允许你访问真实信息的一小片数据. 3)对于值类型的表达式,它的值是实际的数据. ...

随机推荐

  1. Windows 2008 R2 如何安装.net framework 3.5

    服务器中安装sql server2012 ,  安装过程中提示没有此 “ Framework 3.5.1 功能 ” , 是不是很尴尬 于是简单记录安装 Framework 3.5.1 功能的步骤 一. ...

  2. bzoj4563 HAOI2016放旗子

    bzoj传送门 已知了"任意两个障碍不在同一行,任意两个障碍不在同一列",如果我们按每列只能放一个来考虑,那么这\(n\)个障碍一定是一个排列,那么也就是"每一列只能放一 ...

  3. D - Bomb

    //反向62 #include <iostream> #include <algorithm> #include <string> #include <cst ...

  4. python错误之RuntimeError: dictionary changed size during iteration

    pythonn报错信息: C:\Users\Administrator\AppData\Local\Programs\Python\Python36-32\python.exe C:/Users/Ad ...

  5. djangoXadmin

    是一个基于admin二次开发的开源组件,但是貌似已经停止开发了. 安装方式:(py3.6,django2.1) 1 先用pip安装xadmin2,它会安装xadmin和一些依赖包 2 用pip卸载xa ...

  6. 2566. [51nod 1129] 字符串最大值

    [题目描述] 一个字符串的前缀是指包含该字符第一个字母的连续子串,例如:abcd的所有前缀为a, ab, abc, abcd. 给出一个字符串S,求其所有前缀中,字符长度与出现次数的乘积的最大值. 例 ...

  7. html5.0学习记录(一)——可拖动视频播放器

    最近自己在重新学习html5新特性,了解到有视频标签和拖动标签,于是自己用这两个特性写了一个小demo,主要功能就是可以通过拖动视频来直接播放.效果图如下: 页面使用了<video>标签和 ...

  8. 打开一个本地apk进行安装

    Intent intent = new Intent(); intent.setAction(Intent.ACTION_VIEW); File file = new File(Environment ...

  9. vi 搜索

    / 向下搜索 ? 向上搜索 n 重复前一个搜索 N 反向重复前一个搜索

  10. 使用 PHPUnit 和 Selenium 进行测试

    适用于 PHP 的 NetBeans IDE 支持 PHPUnit 自动测试.通过 PHPUnit,NetBeans IDE 可为 PHP 提供代码覆盖率,这与 IDE 为 Python 提供的代码覆 ...