Tornado と JS Prototype ライブラリを使用して単純な Web アプリケーションを作成しようとしています。したがって、クライアントはサーバー上で長時間実行されるジョブを実行できます。このジョブが非同期で実行されることを望みます。これにより、他のクライアントがページを表示してそこで何かを実行できるようになります。
これが私が持っているものです:
#!/usr/bin/env/ python
import tornado.httpserver
import tornado.ioloop
import tornado.options
import tornado.web
from tornado.options import define, options
import os
import string
from time import sleep
from datetime import datetime
define("port", default=8888, help="run on the given port", type=int)
class MainHandler(tornado.web.RequestHandler):
def get(self):
self.render("templates/index.html", title="::Log watcher::", c_time=datetime.now())
class LongHandler(tornado.web.RequestHandler):
@tornado.web.asynchronous
def get(self):
self.wait_for_smth(callback=self.async_callback(self.on_finish))
print("Exiting from async.")
return
def wait_for_smth(self, callback):
t=0
while (t < 10):
print "Sleeping 2 second, t={0}".format(t)
sleep(2)
t += 1
callback()
def on_finish(self):
print ("inside finish")
self.write("Long running job complete")
self.finish()
def main():
tornado.options.parse_command_line()
settings = {
"static_path": os.path.join(os.path.dirname(__file__), "static"),
}
application = tornado.web.Application([
(r"/", MainHandler),
(r"/longPolling", LongHandler)
], **settings
)
http_server = tornado.httpserver.HTTPServer(application)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()
if __name__ == "__main__":
main()
サーバー部分です。メインビューがあります(小さな挨拶、現在のサーバー時間、および実行時間の長いジョブを実行する ajax クエリの URL が表示されます。ボタンを押すと、実行時間の長いジョブが実行されます。サーバーがハングします :(このジョブは実行中です。テンプレート ページは次のとおりです。
<html>
<head>
<title>{{ title }}</title>
<script type="text/javascript" language="JavaScript" src="{{ static_url("js/prototype.js")}}"></script>
<script type='text/javascript' language='JavaScript'>
offset=0
last_read=0
function test(){
new Ajax.Request("http://172.22.22.22:8888/longPolling",
{
method:"get",
asynchronous:true,
onSuccess: function (transport){
alert(transport.responseText);
}
})
}
</script>
</head>
<body>
Current time is {{c_time}}
<br>
<input type="button" value="Test" onclick="test();"/>
</body>
</html>
私は何を間違っていますか?Tornado と Prototype (または jQuery) を使用してロング プーリングを実装する方法
PS: チャットの例を見てきましたが、複雑すぎます。それがどのように機能するのか理解できません:(
PSS の完全な例をダウンロード