V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  yonoho  ›  全部回复第 4 页 / 共 4 页
回复总数  77
1  2  3  4  
2017-11-17 16:22:39 +08:00
回复了 CodemonkeyM 创建的主题 程序员 58 好厉害...
以前在哪看过,好像现在 js 也可以调用一些特殊的接口来拿到电脑显卡的指纹特征的,所以这算是一种设备级的 cookie。当然如果结合大数据能拿到的更多
2017-11-13 14:00:24 +08:00
回复了 airyland 创建的主题 全球工单系统 [花点时间] 的鲜花质量问题
开始剪羊毛了,都一样差
这个问题就像,我在世界各地都可以刷美元,为什么还会有各种本地货币??
广州确实低,而且参差不齐。你只描述工作经验的话我感觉 15-20 吧
2017-09-28 11:20:05 +08:00
回复了 Mush 创建的主题 全球工单系统 大家抢票的时候不要同时用两个平台啊, 会重复扣费的
似乎明白了他们的订单逻辑
2017-09-21 14:34:25 +08:00
回复了 ZeoZhang 创建的主题 职场话题 进了一个可怕的公司
yoooooooo~
2017-09-18 15:00:30 +08:00
回复了 Xinghx 创建的主题 程序员 程序员有必要去定期做按摩吗?
除开上面那些不正经的,按摩对缓解肌肉僵硬是很有效的,而这通常是长时间连续码字容易犯的毛病。而且它和运动的效果还不一样,一般的运动很难拉伸到一些细小的肌肉,另外某些肌肉要是真的出毛病了你也会疼的动不起来。所以那些每天运动就感到身体很放松的人,他们不需要按摩的原因很可能是他们并不太忙——可以按时下班,工作中也可以经常站起来活动。我以前有段时间加班严重,每周快到周末肩膀就会很硬,绷着放松不下来,腰椎附近也疼,每周末就都要找一位老师傅按摩。现在不忙了,每天运动一会,已经很久不去按了。另外按摩师傅水平差距很大,一定要找好的,就是那些靠摸就能精准找到你的酸痛点的人,他们也常常有一些特别的手法,敢做一些特别的动作。
2017-08-25 09:48:00 +08:00
回复了 xuezher 创建的主题 程序员 无偿加班,拖欠工资...此刻的我很心塞,虽已提了离职。
仲裁+1,爽一把
@JasperYanky 总结一下:本文内的问题是,在基于 gevent 的 http server 上大量使用 requests 时速度很慢,甚至会超时,看起来像阻塞了一样。最后楼主通过调大 pool manager 的 maxsize 解决了问题。

然后我通过类似 #69 的测试方法复现了这个问题,并横向测试了其他方案的一些表现。测试用例方面为了排除外部变量,与 #69 的第二步不同,我没有选择 baidu 的页面,而是用第一步中自己的 /hello 页面来进行测试。即完整的测试方案为:

0. 写一个简单的 http server,提供两个接口。第一个 /hello 简单返回 "hello";第二个 /world 会通过 http 访问 /hello 然后把拿到的东西返回出去(不使用公共 session,裸 requests.get )
1. ab -c 100 -n 5000 http://127.0.0.1:5000/hello
2. ab -c 100 -n 5000 http://127.0.0.1:5000/world

先来看一下这个用例,会发现第二步比第一步多的就只是一次 /hello 的访问,因此理论上第二步的 QPS 应该为第一步的一半(在未达到处理极限的前提下)。然后测试数据如下(全部测试跑在我的小本本上,默认 2 个 worker,CPython3.6,gunicorn,gevent,测试有偏差,15% 以内大概,看个比例就行)

go 8784 3544

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

gevent+requests 1079 261

gevent+httplib2 988 336

gevent+gcurl 1079 562

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

sanic+aiohttp_client 6631 1513

以 go 版本为对照组,第二步 QPS 能达到第一步的 40%,基本满足预期(而且绝对值上也是最高的)。然后第二组就是有问题的 gevent + requests 了,第二步只有第一步的 24%。看来确实有问题,这里考虑一下,io 已经被 patch 成异步的了不会阻塞,那多半是 requests 自己慢,再想一下它那些高级的接口和冗长的面向对象代码,可能是慢的原因,于是把第二步中的 http client 换成了更底层的 httplib2,发现 QPS 提高到了 336 ( 34%),效果显著但还不够好。于是想进一步替换成更高效的 pycurl,同时为了对接 gevent,找了个 gcurl 包,这次 QPS 达到了 562 ( 52%),效果拔群。到此基本可以确定,是 requests 代码本身的执行效率低导致的问题,与 gevent 应该没什么关系。当 requests 不能满足你的需求时,可以换一个更快的 http client。

最后说一下绝对 QPS 的问题,gevent 下的 /hello 接口都只有大约 1000,比 go 低了一个数量级,造成这个问题的原因与 requests 类似,都不是 io 的问题,而是 python 代码本身执行效率低。即使不用 monkey patch,改成原生的 tornado,/hello 的 QPS 也只有 1200 左右。上面测试数据的最后一组我用了 sanic 框架,这个框架基于原生 asyncio 并把 ioloop 和 httpparser 都替换成了 C 版,才使 /hello 接口的 QPS 接近 go,但因为没有用 C 版的 http client,/world 的 QPS 比仍然偏低( 22%)。综上,当你的 python 代码执行效率遇到瓶颈的时候,要么简化代码,要么上 C 模块,要么也可以考虑换成 go。
patch #67: /c sleep 1,访问一次 /a 10s+
@1iuh 请问这个问题应该怎么复现?我用最简化的测试方法(/a 访问 1000 次 /b, 每个 /b 访问 1 次 /c, /c ),1000 次 10s+,没感觉有阻塞
我猜楼主的测试是在一个请求里调用多次 requests,并期待并行执行的效果。但因为代码本身写成了同步顺序执行(多行或者循环),所以用了 monkey patch 也没用。这种情况下不改代码是不可能并行的,最简单的方法是依然使用 gevent worker,然后使用 #12 提供的 grequests 包重写第三方 http 请求部分,把这些 http 请求放在一起调用 grequests.map ( gevent.spawn ),就能实现并行加速。
@woostundy 有效啊,你咋测的
2017-05-27 14:20:46 +08:00
回复了 changwei 创建的主题 Python 你们对 Flask 这个框架的设计有什么看法吗?
flask 是我最欣赏的 python web 框架,我觉得它的设计十分简单优雅,尤其你列举的那些不好用的地方,在我看来都是精髓。

可能楼主对优雅和规范的认识和 flask 的设计者们不太一样吧
2017-02-22 15:27:45 +08:00
回复了 hunk 创建的主题 程序员 想做一个监控类的图表动态更新页面,有啥轮子可以复用?
influxdb 据说很好用,单机很快。我们用的 opentsdb 集群,感觉专用的时间序列数据库在使用上还是更加方便的,尤其应对复杂查询的时候,可以少造很多轮子。

凡是叫做 db 的东西,持久化都是没问题的,不用考虑 mysql 了我感觉。
1  2  3  4  
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3372 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 25ms · UTC 11:20 · PVG 19:20 · LAX 03:20 · JFK 06:20
Developed with CodeLauncher
♥ Do have faith in what you're doing.