twisted的一些代码
之前用swoole(1.7.19)写的一段程序在数据量大的时候存在内存泄漏,改为twisted(15.4)实现,自测无误,记录如下(两者cpu占用率90%时吞吐rps能从120提升到1000)。
#!/usr/bin/env python from twisted.internet import task, reactor
from twisted.python import log
from twisted.web import static, server, resource
import MySQLdb
import json class RotateMap(object):
def __init__(self):
self.using = 0
self.unuse = 1
self.map = [{},{}] def find(self, key):
if self.map[self.using].has_key(key):
return self.map[self.using][key]
return False def set(self, nmap):
self.map[self.unuse] = nmap
self._swap() def get(self):
return self.map[self.using] def _swap(self):
self.using,self.unuse = self.unuse,self.using check = RotateMap()
allow = RotateMap()
start = RotateMap() log.startLogging(open("/tmp/tserver.log",'w')) class TServer(resource.Resource):
isLeaf = True
def getChild(self, name, request):
if name == '':
return self
return Resource.getChild(self, name, request) def render_GET(self, request):
if request.requestHeaders.hasHeader("x-forwarded-for"):
log.msg("%s %s %s" % (request.requestHeaders.getRawHeaders("x-forwarded-for"), request.path, json.dumps(request.args)))
else:
log.msg("%s %s %s" % ("127.0.0.1", request.path, json.dumps(request.args))) if "/api1" == request.path:
if request.args.has_key("version"):
version = request.args["version"][0]
if version != "":
global start
info = start.get()
result = {}
if info["version"] != version:
result["needUp"] = True
result["version"] = info
else:
result["needUp"] = False return json.dumps(result) elif "/api2" == request.path:
host = ""
if request.args.has_key("host"):
host = request.args["host"][0]
global check
if host != "":
v1 = check.find(host)
if v1 == False:
v1 = ""
return "%s" % (v1) elif "/api3" == request.path:
host = ""
if request.args.has_key("host"):
host = request.args["host"][0]
v1 = v2 = 1
global allow
if host != "" and allow.find(host) != False:
v1 = 0
return "%d|%d" % (v1,v2) elif "/reload" == request.path:
cmd = "file"
if request.args.has_key("cmd"):
cmd = request.args["cmd"][0]
helper = ReloadHelper()
helper.reload(cmd)
return "done"
else:
request.setResponseCode(404)
return "404 not found" request.setResponseCode(400)
return "400 bad request" class ReloadHelper(object):
def reload(self, cmd):
log.msg("reload %s start" % (cmd))
if cmd == "db":
self._reloadDB()
elif cmd == "file":
self._reloadFile()
log.msg("reload %s end" % (cmd)) def _reloadFile(self):
data = {}
f = open("check.data")
line = f.readline()
while line:
domain, levelid = line.strip().split("|")
data[domain] = levelid
line = f.readline()
f.close()
global check
check.set(data) data = {}
f = open("allow.data")
line = f.readline()
while line:
domain = line.strip()
data[domain] = ""
line = f.readline()
f.close()
global allow
allow.set(data) def _reloadDB(self):
try:
conn=MySQLdb.connect(host='hostname',user='username',passwd='passwd',port=3306)
conn.select_db("dbname")
cur = conn.cursor()
cur.execute("set names utf8")
cur.execute("SELECT id, version, name FROM table ORDER BY id DESC LIMIT 1")
row = cur.fetchone()
if len(row) == 3:
data = {}
data["id"] = row[0]
data["version"] = row[1]
data["name"] = row[2]
global start
start.set(data)
cur.close()
conn.close()
except MySQLdb.Error, e:
log.err("mysql error %d, %s" %(e.args[0], e.args[1])) helper = ReloadHelper()
l = task.LoopingCall(helper.reload, "db")
l.start(600) l = task.LoopingCall(helper.reload, "file")
l.start(3600000) def main():
tserver = static.File("/usr/local/nginx/html")
tserver.putChild("service", TServer())
tserver.putChild("html", static.File("/usr/nginx/html")) reactor.listenTCP(8080, server.Site(tserver), 50, "127.0.0.1")
reactor.run() if __name__ == '__main__':
main()
twisted的一些代码的更多相关文章
- Python Twisted系列教程10:增强defer功能的客户端
作者:dave@http://krondo.com/an-introduction-to-asynchronous-programming-and-twisted/ 译者:杨晓伟(采用意译) 可以从这 ...
- Python Twisted系列教程9:第二个小插曲,Deferred
作者:dave@http://krondo.com/a-second-interlude-deferred/ 译者:杨晓伟(采用意译) 可以从这里从头来阅读这个系列 更多关于回调的知识 稍微停下来再思 ...
- Python 开源异步并发框架的未来
http://segmentfault.com/a/1190000000471602 开源 Python 是开源的,介绍的这几个框架 Twisted.Tornado.Gevent 和 tulip 也都 ...
- Tornado模块分类和各模块之间的关系
1. Core web framework tornado.web — 包含web框架的大部分主要功能,包含RequestHandler和Application两个重要的类 tornado.https ...
- tornado源码分析-模块介绍
1.Core web framework tornado.web - web框架功能模块,包括RequestHandler和Application两个重要的类 tornado.httpserver - ...
- Tornado模块分类
Tornado模块分类 1. Core web framework tornado.web — 包含web框架的大部分主要功能,包含RequestHandler和Application两个重要的类 t ...
- Tornado 模块概述
Tornado模块分类 1. Core web framework tornado.web — 包含web框架的大部分主要功能,包含RequestHandler和Application两个重要的类 t ...
- Python框架之Tornado(概述)
本系列博文计划: 1.剖析基于Python的Web框架Tornado的源码,为何要阅读源码? Tornado 由前 google 员工开发,代码非常精练,实现也很轻巧,加上清晰的注释和丰富的 demo ...
- 一个在交流群里讨论过两轮的问题,答案竟然跟一个 PEP 有关
Python 中有没有办法通过类方法找到其所属的类? 这个问题看起来不容易理解,我可以给出一个例子: class Test: @xxx def foo(self): pass 现在有一个类和一个类方法 ...
随机推荐
- Oracle EBS-SQL (BOM-10):检查有BOM无计划员的数据.sql
select DISTINCT msi.segment1 编码 ,msi.description 描述 ,msi.item_type 物料类型 ,msi.inventory_ ...
- 【自学php】第四天 - 使用数组
php支持两种数组,数字索引数组和关联数组.关联数组有点类似Map,可以用字符串或其他数据类型做键对应相应的值保存在数组中. 1.初始化数组 数字索引数组的初始化可以使用如下代码: $products ...
- DTW-js版
最近想试试语音识别,然后看到了DTW这个算法 主要参考:http://www.cnblogs.com/rockyf/articles/4519352.html function dtw(arr1, a ...
- 《UNIX环境高级编程》笔记--文件访问权限和新文件、目录所有权
1.与进程关联的用户ID和组ID 与一个进程关联的ID有一下几个: 实际用户ID和实际组ID标识我们究竟是谁.通常在一个会话间值是不会改变的,但是超级用户进程有方法改变 他们,在以后的进程控制中会进行 ...
- CodeForces 540B School Marks(思维)
B. School Marks time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- 还是log4net的使用
最近做个项目要用到日志系统,这这可把我给难住了,后来问了下度娘,发现只有你想不到的,没有那些找不到的开源组件,后来发现了log4net,但是我是控制台程序,没有个实例还真不好搞,想想还是看看他的运行过 ...
- IIS Express中如何配置支持json
今天在使用i18next的时候,由于要加载一个json的文件,但是在vs2013中一直加载不成功呢,经过上网查资料得知原来要配置iis express才能支持json文件的加载. 文件的默认位置在:C ...
- ServiceStack 入门(一)
本文主要介绍ServiceStack的安装,与第一个项目的创建. 详细了解ServiceStack,可参考官方网站: https://servicestack.net/ , Github上Servic ...
- Android 数据适配器
把复杂的数据(数组.链表.数据库.集合等)填充到指定的视图界面上. arrayAdapter(数组适配器): 用于绑定一些格式单一的数据,数据源:数据或者集合. private Li ...
- hadoop笔记之MapReduce的运行流程
MapReduce的运行流程 MapReduce的运行流程 基本概念: Job&Task:要完成一个作业(Job),就要分成很多个Task,Task又分为MapTask和ReduceTask ...