tornado定时调用

发现, tornado的database模块的Connection在很长时间没有请求数据库后,就会出现断开数据库连接
通过tornado定时调用来执行一个语句,来和mysql保持心跳

# -*- coding: utf-8 -*-

from urls import urls
from settings.dbsettings import MYSQL 
from tornado.ioloop import PeriodicCallback
from lib.utils import dolog 

import tornado.web
import tornado.database
import os

SETTINGS = dict(
    template_path=os.path.join(os.path.dirname(__file__), "templates"),
    static_path=os.path.join(os.path.dirname(__file__), "static"),

    )


class Application(tornado.web.Application):
    def __init__(self):
        handlers = urls
        settings = SETTINGS
        tornado.web.Application.__init__(self, handlers, **settings)

        self.db = tornado.database.Connection(**MYSQL) # tornado3要改一下, 换成torndb
        
        # 心跳 => 保持和mysql的连接
        def ping_db():
            t = self.db.query("SELECT now() as time")[0].time
            print "ping:", t
        pc = PeriodicCallback(ping_db, 1800)
        pc.start()


application = Application()

---------
可用try捕获<连接失败异常>然后调用self.db.reconnect来<重连>,然后再查询
这样就省去了定时调用的消耗

***最新修改:还是定时调用的消耗小,try的消耗比较大

转载于:https://my.oschina.net/1123581321/blog/182148

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值