Python プロジェクトで App Engine モジュールを使用しています。( https://developers.google.com/appengine/docs/python/modules/#Python_Background_threads )
m プロジェクトでもチャネルを使用しています: https://developers.google.com/appengine/docs/python/channel/
接続/切断されたポスト メッセージ ('/_ah/channel/connected/'、'/_ah/channel/disconnected/') を API モジュールに送信したいと考えています。現在、それらをどのモジュールにも表示できません(デフォルトまたはAPI)
app.yaml
api_version: 1
application: integrate
version: 1-0-0
runtime: python27
threadsafe: true
builtins:
- deferred: on
libraries:
- name: pycrypto
version: "2.6"
handlers:
- url: /favicon\.ico
static_files: static/favicon.ico
upload: static/favicon\.ico
- url: /admin/.+
script: src.default.main.app
login: admin
- url: /.*
script: src.default.main.app
api.yaml
api_version: 1
application: integrate
module: api
version: 1-0-0
runtime: python27
threadsafe: true
inbound_services:
- channel_presence
builtins:
- deferred: on
libraries:
- name: pycrypto
version: "2.6"
handlers:
- url: /admin/.+
script: src.api.main.app
login: admin
- url: /.*
script: src.api.main.app
ディスパッチ.yaml
application: integrate
dispatch:
- url: "*/_ah/channel/*"
module: api
注: 明確にするために、これはすべてローカルで dev モードで動作します。
api.main.app
app = webapp2.WSGIApplication(debug=True)
_routes = [
:
ChannelDisconnectedHandler.mapping(),
ChannelConnectHandler.mapping()
]
for r in self._routes:
app.router.add(r)
ChannelDisconnectHandler
CHANNEL_DISCONNECTED_URL_PATTERN = '/_ah/channel/disconnected/'
class ChannelDisconnectedHandler(RequestHandler):
@classmethod
def mapping(cls):
return CHANNEL_DISCONNECTED_URL_PATTERN, cls
def post(self):
"""
Channel Presence handler. Will be called when a client disconnects.
"""
channel_id = self.request.get('from')
logging.info("Channel Disconnect. Id: %s" % channel_id)
ChannelConnectHandler
CHANNEL_CONNECT_URL_PATTERN = '/_ah/channel/connected/'
class ChannelConnectHandler(RequestHandler):
@classmethod
def mapping(cls):
return CHANNEL_CONNECT_URL_PATTERN, cls
def post(self):
"""
Channel Presence handler. Will be called when a client connects.
"""
channel_id = self.request.get('from')
logging.info("Channel Connect. Id: %s" % channel_id)
したがって、クライアント (javascript で記述) は API モジュールに投稿し、チャネルを開きます。
var open_channel = function(tokenResponse) {
console.log("Open Channel. token Response: " + tokenResponse)
token = tokenResponse.token;
var channel = new goog.appengine.Channel(token);
if (socket != null) {
socket.close();
}
socket = channel.open();
socket.onopen = onOpened;
socket.onmessage = onMessage;
socket.onerror = onError;
socket.onclose = onClose;
};
onOpened = function() {
console.info("Channel API Connection is open.");
};
onError = function(e) {
console.info("CHANNEL Error. Code: " + e.code + ", Description: " + e.description);
};
onClose = function() {
console.info("Close Channel");
};
onMessage = function(msg) {
console.info("Message Received: " + msg + ", Data: " + msg.data);
};
このコールバック関数は、有効なトークンで到達します。ソケットを正常に作成し、この関数を期待どおりに完了します。次に、ローカル システムで onOpened 関数が呼び出され、サーバーからメッセージを受信します。実稼働環境では onOpened が呼び出されることはなく、メッセージを受信することもありません。/_ah/channel/connected/ も呼び出されません。
チャネル サービスはモジュールでサポートされていませんか? 私が欠けているものについて何か考えはありますか?