zoukankan      html  css  js  c++  java
  • twisted adbapi 连接超时中断重连,Lost connection ,cp_reconnect=True 参数不好用 ,2006, 2013 MySQLdb.OperationalError

    转载  

    https://stackoverflow.com/questions/12677246/twisted-adbapi-cp-reconnect-not-working/35178822


    重写adbapi.ConnectionPool
    
    

    class ReconnectingMySQLConnectionPool(adbapi.ConnectionPool):
    """
    This connection pool will reconnect if the server goes away. This idea was taken from:
    https://stackoverflow.com/questions/12677246/twisted-adbapi-cp-reconnect-not-working/35178822
    """

    def _runInteraction(self, interaction, *args, **kw):
    try:
    return adbapi.ConnectionPool._runInteraction(self, interaction, *args, **kw)
    except MySQLdb.OperationalError as e:
    if e.args[0] not in (2006, 2013):
    raise
    logger.error("Lost connection to MySQL, retrying operation. If no errors follow, retry was successful.")
    conn = self.connections.get(self.threadID())
    self.disconnect(conn)
    return adbapi.ConnectionPool._runInteraction(self, interaction, *args, **kw)


    -------------------

    加强版


    class ReconnectingMySQLConnectionPool(adbapi.ConnectionPool):
    """
    This connection pool will reconnect if the server goes away. This idea was taken from:
    https://stackoverflow.com/questions/12677246/twisted-adbapi-cp-reconnect-not-working/35178822
    """

    def _runInteraction(self, interaction, *args, **kw):

    #

    i = 0
    while i <= 10:
    try:
    return adbapi.ConnectionPool._runInteraction(self, interaction, *args, **kw)
    except MySQLdb.OperationalError as e:
    if e.args[0] not in (2006, 2013):
    raise
    logger.error(
    "Lost connection to MySQL, retrying operation. If no errors follow, retry was successful.")
    # time.sleep(0.1)
    conn = self.connections.get(self.threadID())
    self.disconnect(conn)
    i += 1
    logger.info("Lost connection 重试__%s" % str(i))

    raise MySQLdb.OperationalError("Lost connection to MySQL")



    ----------------
    使用处



    class MysqlTwistedPipline(object):
    def __init__(self, dbpool):
    self.dbpool = dbpool

    @classmethod
    def from_settings(cls, settings):
    # 参数名称 要 一致
    dbparms = dict(
    host=settings['MYSQL_HOST'],
    user=settings['MYSQL_USER'],
    passwd=settings['MYSQL_PASSWORD'],
    db=settings['MYSQL_DBNAME'],
    charset='utf8',
    cursorclass=MySQLdb.cursors.DictCursor,
    use_unicode=True,
    cp_reconnect=True
    )

    # dbpool = adbapi.ConnectionPool("MySQLdb", **dbparms)
    dbpool = ReconnectingMySQLConnectionPool("MySQLdb", **dbparms)

    return cls(dbpool)
     
  • 相关阅读:
    .NET 分页
    SQL将用户表中已存在的数据所有姓名(汉字)转换为拼音首字母
    EXECL文件导入数据库
    Jquery ajax
    Jquery学习
    C#动态调用webservice
    使用VSTS的Git进行版本控制(四)——在Visual Studio中管理分支
    使用VSTS的Git进行版本控制(三)——评审历史记录
    使用VSTS的Git进行版本控制(二)——提交保存工作
    使用VSTS的Git进行版本控制(一)——复制现有仓库
  • 原文地址:https://www.cnblogs.com/angdh/p/14071486.html
Copyright © 2011-2022 走看看