python SQLAlchemy 中的Engine详解【如何避免链接错误的一些配置MySQL Connection not available】

参考:https://www.jb51.net/article/164591.htm

 

 mysql如果超过最大连接数就会报错:too many connections” 【修改mysql的配置参数:max_connections】

MySQL 默认情况下如果一个连接8小时【MySQL中的配置参数interactive_timeout和wait_timeout(可能导致过多sleep进程的两个参数)】内容没有任何动作(查询请求)就会自动断开链接,出现 MySQL has gone away的错误。或MySQL Connection not available,代表当前链接已超时失效!

 

使用SQLAlchemy 配置 Engine从参数就可以避免这些错误出现:

"""
            create_engine
                1、uri格式为"mysql+mysqlconnector://用户名:密码@localhost:3306/数据库名称"
                2、pool_size:这里设置100,如果设置为0表示没有大小限制【查看官方文档】
                3、max_overflow,这里设置100,如果设置为-1,以表示没有溢出限制;并发连接的总数没有限制【查看官方文档】
                4、pool_recycle:【这里必须设置,避免各种连接错误问题】这里设置默认值为3600【1小时】
                    解释:MySQL默认情况下如果一个连接8小时内容没有任何动作(查询请求)就会自动断开链接出现 MySQL has gone away的错误。
                    设置了 pool_recycle后SQLAlchemy就会在指定时间内回收连接。如果设置为3600 就表示1小时后该连接会被自动回收。
                5、pool_pre_ping: 这里默认设置为True
                        这是1.2新增的参数,如果值为True,那么每次从连接池中拿连接的时候,
                        都会向数据库发送一个类似 select 1的测试查询语句来判断服务器是否正常运行。
                        当该连接出现 disconnect 的情况时,该连接连同pool中的其它连接都会被回收。
                6、关于连接数的常见错误类型官方文档:https://docs.sqlalchemy.org/en/13/errors.html#error-3o7r
                7、配置当前引擎的最大并发连接数max_connections = pool_size + max_overflow
        """
        self.engine = create_engine(
            GlobalSecure.SQLALCHEMY_DATABASE_URI, pool_size=100, pool_recycle=3600, max_overflow=100,
            pool_pre_ping=True)

 

create_engine 还有很多可选参数,这里介绍几个重要的参数。

1

2

3

4

5

engine = create_engine('mysql://user:password@localhost:3306/test?charset=utf8mb4',

   echo=False

   pool_size=100,

   pool_recycle=3600,

   pool_pre_ping=True)

echo :为 True 时候会把sql语句打印出来,当然,你可以通过配置logger来控制输出,这里不做讨论。

pool_size: 是连接池的大小,默认为5个,0表示连接数无限制

pool_recycle: MySQL 默认情况下如果一个连接8小时内容没有任何动作(查询请求)就会自动断开链接,出现 MySQL has gone away的错误。设置了 pool_recycle 后 SQLAlchemy 就会在指定时间内回收连接。如果设置为3600 就表示 1小时后该连接会被自动回收。

pool_pre_ping : 这是1.2新增的参数,如果值为True,那么每次从连接池中拿连接的时候,都会向数据库发送一个类似 select 1 的测试查询语句来判断服务器是否正常运行。当该连接出现 disconnect 的情况时,该连接连同pool中的其它连接都会被回收。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值