由于公司现有主库要转移到新的主库上,所以,我打算利用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. C#递归得到特定文件夹下问件

    List<String> listFile = new List<String>(); public void director(string path) { //绑定到指定的 ...

  2. C - Heavy Transportation

    //改版dijkstra #include <iostream> #include <algorithm> #define Faster ios::sync_with_stdi ...

  3. Zip-line Codeforces - 650D || 风筝

    https://codeforces.com/contest/650/problem/D 原题? http://210.33.19.103/contest/1024/problem/2 4s 520M ...

  4. springMVC-接收数据-参数绑定

    接收数据-参数绑定 #Method Arguments概观 Same in Spring WebFlux The table below shows supported controller meth ...

  5. 软件管理命令-- rpm

    RPM(红帽软件包管理器) 安装软件 rpm -ivh filename.rpm 升级软件 rpm -Uvh filename.rpm 卸载软件 rpm -e filename.rpm -i 安装一个 ...

  6. python+selenium 页面中存在选项卡时,获取页面内容的小技巧

    最近用selenium读取页面内容时,遇到包含选项卡的页面,由于选项卡多由js加载其中的内容,所以在网址打开时只能获取到默认显示的选项卡中的内容,而tab2.tab3等等都需要傻傻的点击一下才会获取到 ...

  7. No bean named 'springSecurityFilterChain' is defined

    1.问题 本文讨论Spring安全配置问题 - 应用程序引导过程抛出以下异常: SEVERE: Exception starting filter springSecurityFilterChain ...

  8. TI德州芯片TLV系列和TPS系列芯片区别(转)

    TLV和TPS一般会有pin to pin的对应型号: 一般来讲,TPS精度.准确度和性能会好一些,所以价钱要贵一些: 对应TLV就是一样可以实现上述功能,但是精度和性能等级是稍微低一点的: 具体选择 ...

  9. kafka系列一:单节点伪分布式集群搭建

    Kafka集群搭建分为单节点的伪分布式集群和多节点的分布式集群两种,首先来看一下单节点伪分布式集群安装.单节点伪分布式集群是指集群由一台ZooKeeper服务器和一台Kafka broker服务器组成 ...

  10. eureka集群环境搭建

    一:集群环境搭建 第一步:我们新建两个注册中心工程一个叫eureka_register_service_master.另外一个叫eureka_register_service_backup eurek ...