免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 7862 | 回复: 18
打印 上一主题 下一主题

一个python做的服务端软件的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-07-12 16:47 |只看该作者 |倒序浏览
20可用积分
小弟用python+twisted+sqlalchemy 写了一个类似于httpserver的服务端软件

这个软件干的事情是这样的:
主要分两步,由两个线程分别完成

1步 接受客户端的数据 放入线程公用队列(queue),线程1做(twisted主线程)
2步 从队列pop出数据 存入数据库,线程2做

现在一个很尴尬的问题是,第一步就收数据部分速度飞快 平均每次请求不到1ms就完成
但是第二部存数据库相比起来就超级慢了,处理一个请求的数据(存入数据库)平均要30ms,可能数据库本身需要一些优化,但是现在还不知道能提高多少

所以:线程公用队列就会一直堆积数据(两部分的性能差距太大),最终就只有撑满内存了........

我的问题是:不管DBA怎么搞数据库部分,但从软件层,有没有什么办法至少是缓解这个问题呢,因为我觉得不管怎么样,所有环节中,存取数据库应该永远是瓶颈大户,并且第2步基本上主要就是做存数据库,没什么其他的什么开销

哪位大哥有什么建议么?

论坛徽章:
0
2 [报告]
发表于 2009-07-12 20:05 |只看该作者
怎么改都解决不了根本矛盾:访问量与数据处理能力的矛盾

所以只能限制访问,操作队列满的时候阻塞访问,让客户端去等

论坛徽章:
0
3 [报告]
发表于 2009-07-12 22:43 |只看该作者
哎....限制访问,可是需要限制访问到什么程度呢,当前两步骤性能差异在上百倍了...

论坛徽章:
0
4 [报告]
发表于 2009-07-12 22:58 |只看该作者

回复 #1 gm3000 的帖子

异步方式?存采取这样的方式如何?

论坛徽章:
0
5 [报告]
发表于 2009-07-13 08:18 |只看该作者
原帖由 ziggler 于 2009-7-12 22:58 发表
异步方式?存采取这样的方式如何?

恩,可以试试。

论坛徽章:
0
6 [报告]
发表于 2009-07-13 10:41 |只看该作者
恩?激动
能否讲的详细点呢?我知道oracle有并发操作的能力,是否是你们说的异步呢?

论坛徽章:
0
7 [报告]
发表于 2009-07-13 13:23 |只看该作者
使用twisted的defer,把 操作串起来
client会24小时不间断传数据吗?那样的话迟早也是不行的,不过这样的情况下twisted应该会帮你处理一部分东西,你测试一下吧
缓存几次查询一并向数据库请求会不会快一点呢?

论坛徽章:
0
8 [报告]
发表于 2009-07-13 13:34 |只看该作者
开多个线程2 ,并发写数据库会好些。

论坛徽章:
0
9 [报告]
发表于 2009-07-13 16:30 |只看该作者
把客户端数据先写入文本文件,再用数据库本身的导入导出工具放入到数据库中,这样能解决数据存储的问题

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
10 [报告]
发表于 2009-07-13 17:07 |只看该作者
原帖由 smallfish_xy 于 2009-7-13 08:18 发表

恩,可以试试。


我觉得异步不是解决之道,因为你的瓶颈之处解决不了,数据就会堆积,同时会消耗内存,

我觉得你的接收消息的queue应该设置一个高水标,如果超出了阈值,就拒绝掉,

如果你的client不能拒绝,那么你可以先保存在内存中,等数据堆积到一定程度,再集中写到DB中,集中写比分散式的写效率要高一些,毕竟访问数据库(磁盘)的次数少了很多。

[ 本帖最后由 cookis 于 2009-7-13 17:09 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP