由于公司现有主库要转移到新的主库上,所以,我打算利用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. 【BZOJ4548】小奇的糖果

    →原题传送门←(by Hzwer) 「题目背景」 小奇不小心让糖果散落到了地上,它对着满地的彩色糖果胡思乱想. 「问题描述」 有 N 个彩色糖果在平面上.小奇想在平面上取一条水平的线段,并拾起它上方或 ...

  2. VLAN-1-VLAN配置

    f0/12和f0/24不在列表中,因为它们动态地成为trunk,支持多个vlan       “unsup”意为这个2950交换机不支持FDDI和TR       首先 switchport mode ...

  3. [題解]51nod_1515_明辨是非

    好久沒有話多了,是覺得有點浪費時間,今天考試和一中用的一樣的題,結果反而考得不好,不過Jackpei一句知恥而後勇點醒夢中人偷偷@Jackpei 就是這樣吧 還有我極度懷疑我的鍵帽打油了......我 ...

  4. 1-zookeeper基本原理和使用

    1 分布式应用 1.1 分布式系统原理 在一个网络中,每台服务器上各跑一个应用,然后彼此连接起来就组成一套系统.比如提供完成的游戏服务,需要有认证应用,道具应用,积分应用,游戏主应用等,应用并非跑在一 ...

  5. [BZOJ2251/BJWC2010]外星联络

    Description 小 P 在看过电影<超时空接触>(Contact)之后被深深的打动,决心致力于寻找外星人的事业.于是,他每天晚上都爬在屋顶上试图用自己的收音机收听外星人发来的信息. ...

  6. Codeforces Round #541 (Div. 2) C.Birthday

    链接:https://codeforces.com/contest/1131/problem/C 题意: 求给的n个数,相邻差值最小的排列方式.1-n相邻. 思路: sort后隔一个取一个,取到底后再 ...

  7. hdu6315( 2018 Multi-University Training Contest 2)

    bryce1010模板 http://acm.hdu.edu.cn/showproblem.php?pid=6315 /*hdu 1007 首先我们在建立线段树之前应该思考的是线段树的节点维护一个什么 ...

  8. Jasper_table_resolve multiple copies of table in detail band issue

    resolve method: (1) put table component into the Title band / Page Header band / Summary band, not i ...

  9. Storm编程入门API系列之Storm的Topology多个Executors数目控制实现

    前期博客 Storm编程入门API系列之Storm的Topology默认Workers.默认executors和默认tasks数目 Storm编程入门API系列之Storm的Topology多个Wor ...

  10. elasticsearch的模糊查询

    https://blog.csdn.net/a772304419/article/details/78951561