1

この Flask アプリでは、ページがcheck()2 秒ごとに呼び出され、現在のapp.config['count']データが標準出力に出力されます。プロセスを生成し、グローバル カウントに 1 つ追加するボタンもあります。同じ関数内からチェックすると正しく動作しますが、check()試行すると常に 0 のままになります。

ここで何が悪いのか誰か知っていますか?sleep indo_adding_stuff()は、カウントに追加する前に行う他のことの単なるプレースホルダーです。

from flask import Flask, redirect, url_for
from time import sleep
from multiprocessing import Process

app = Flask(__name__)
app.config['count'] = 0

def do_adding_stuff():
    sleep(4)

    print 'previous count: ' + str(app.config['count'])
    app.config['count'] =+ 1
    print 'new count: ' + str(app.config['count'])


@app.route('/')
def index():
    return """
<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.1/jquery.min.js"></script>
<script>
var a = setInterval(function(){
    $.post("/check", {"dummy": "data"})
}, 2000)
</script>
<form method="post" action="add">
<input type="submit" value="add 1 to count">
</form>
"""

@app.route('/add', methods=['POST'])
def add():
    proc = Process(target=do_adding_stuff)
    proc.start()

    return redirect(url_for('index'))

@app.route('/check', methods=['POST'])
def check():
    print('check(): ' + str(app.config['count']))
    return ''

if __name__ == '__main__':
    app.run(debug=True)

そして出力:

check(): 0
check(): 0
check(): 0
check(): 0
previous count: 0
new count: 1
check(): 0
check(): 0
4

1 に答える 1

3

別のプロセスを使用しています。その場合、グローバル変数のようなものはありません。

スレッドに切り替えるか (警告: Python インタープリター ロックによりスレッド化がかなり非効率になります)、または multiprocessing.Value を使用します: 詳細についてはhttp://docs.python.org/2/library/multiprocessing.htmlを参照してください。

注:その値の更新をロックで保護する必要があります。そうしないと、一部の更新が失われます。

于 2013-06-02T12:58:36.713 に答える