V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
poke707
V2EX  ›  Python

关于python程序生存周期的问题

  •  
  •   poke707 ·
    Ginhing · 2014-01-15 20:36:55 +08:00 · 4194 次点击
    这是一个创建于 3759 天前的主题,其中的信息可能已经有所发展或是发生改变。
    以前用过PHP写过web,响应浏览器请求完成后php脚本就跑完了,下次请求时重新跑过,所以并没有像asp那个Application("key")样的全局变量.
    现在用python,好奇一下跟PHP的运作方式有什么异同吗?
    (这个问题的场景是,有个webapp,需要临时保存一个值,使所有请求都能访问到,这个值能否存在内存中?)
    13 条回复    1970-01-01 08:00:00 +08:00
    poke707
        1
    poke707  
    OP
       2014-01-15 20:49:53 +08:00
    上述场景说详细点是,微信的access token,每2小时更新一次
    est
        2
    est  
       2014-01-15 21:57:23 +08:00   ❤️ 1
    asp那个Application("key")也只是单机IIS可用的吧。你感受下。正确的姿势是写入文件或者Berkeley DB或者redis或者其他什么持久化方案都可以。
    poke707
        3
    poke707  
    OP
       2014-01-15 22:02:34 +08:00
    @est 这个不需要持久化吧?那如果是更新非常频繁的变量,例如统计访问人数?
    9hills
        4
    9hills  
       2014-01-15 22:09:53 +08:00 via iPad   ❤️ 1
    @poke707 redis表示没问题

    Python 不同线程间可通过全局变量共享数据,加好锁就行了
    est
        5
    est  
       2014-01-15 22:11:51 +08:00   ❤️ 1
    @poke707 那就是内存db了。搞个rpc也可以。集中到单一进程里处理


    @9hills 跨了线程没法跨进程,跨了进程没法跨机器。还是远程操作一次性到位好了。
    9hills
        6
    9hills  
       2014-01-15 22:14:34 +08:00 via iPad
    @est 嗯,从可扩展的角度讲,刚开始就不要用全局变量
    poke707
        7
    poke707  
    OP
       2014-01-15 22:52:53 +08:00
    多谢楼上,看来问题可以解决了,但是我还是有些道理不明白:
    总结来说,是否跑python的服务器(或者是进程?)不出错不重启,里面的全局or静态变量都还在?
    tonic
        8
    tonic  
       2014-01-15 23:29:29 +08:00   ❤️ 1
    @poke707 进程里的在, 但是你不能保证每次都是这一个进程来处理请求吧...
    misaka
        9
    misaka  
       2014-01-15 23:45:41 +08:00   ❤️ 1
    @poke707 在是在,不过是进程间独立。
    9hills
        10
    9hills  
       2014-01-15 23:57:22 +08:00   ❤️ 1
    @poke707 恩,如果是单进程多线程的模型,全局变量是一直在的,而且各个线程之间可共享(注意加锁哦,threading.Lock。要不怎么算全局变量

    但是如果你的业务是多进程模型,比如nginx+多个tornado实例。。那就老老实实用内存db吧,比如redis之类。一般来说线上业务都是多进程模型,毕竟有GIL啦,服务器又都是多核的。。
    poke707
        11
    poke707  
    OP
       2014-01-16 00:11:38 +08:00
    大家真热情啊:)
    我在后面的楼的追问其实撇开业务了,纯粹的看看单个python进程,我还以为会被GC掉呢
    实际使用中我会注意实际情况的:)
    Livid
        12
    Livid  
    MOD
       2014-01-16 00:12:36 +08:00   ❤️ 2
    大部分的 Python 框架,都是启动一个进程,然后每次处理一个请求的时候,执行预先定义好的一个函数。这个函数可以访问这个进程的数据。

    为了充分利用多个 CPU,你可以启动多个进程。

    为了在进程之间共享一些可能不需要持久化的数据,那么比较好比较快的做法就是 Redis。V2EX 就是这么做的。
    julyclyde
        13
    julyclyde  
       2014-01-16 10:08:54 +08:00
    ASP的application确实方便也确实难以扩展,因为IIS是多线程服务器
    大规模web应用程序的application域一般都是依靠序列化对象和外部存储机制来实现的
    某些java应用服务器本身支持cluster可能也可以支持application
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   808 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 20:19 · PVG 04:19 · LAX 13:19 · JFK 16:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.