2

我将 GCM 与 Google AppEngine (Java) 结合使用。我的服务每天发送超过 10.000 条消息。几乎每条消息都成功发送到接收者。但几乎每天,通过 AppEngine 发送 GCM 消息后,我都会收到以下异常:

Uncaught exception from servlet
java.io.IOException: Could not fetch URL: https://android.googleapis.com/gcm/send
at com.google.appengine.api.urlfetch.URLFetchServiceImpl.convertApplicationException(URLFetchServiceImpl.java:137)
at com.google.appengine.api.urlfetch.URLFetchServiceImpl.fetch(URLFetchServiceImpl.java:43)
at com.google.apphosting.utils.security.urlfetch.URLFetchServiceStreamHandler$Connection.fetchResponse(URLFetchServiceStreamHandler.java:417)
at com.google.apphosting.utils.security.urlfetch.URLFetchServiceStreamHandler$Connection.getInputStream(URLFetchServiceStreamHandler.java:296)
at com.google.apphosting.utils.security.urlfetch.URLFetchServiceStreamHandler$Connection.getResponseCode(URLFetchServiceStreamHandler.java:149)
at com.google.android.gcm.server.Sender.sendNoRetry(Sender.java:362)
at com.google.android.gcm.server.Sender.send(Sender.java:261)
at de.alamos.firemergency.apager.gcm.ApagerServlet.sendDataToAndroid(ApagerServlet.java:282)
at de.alamos.firemergency.apager.gcm.ApagerServlet.doPost(ApagerServlet.java:162)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
...

此错误发生在以下行:

MulticastResult results = sender.send(message, tokens, 5);

有谁知道,问题可能是什么?

这很奇怪,因为 99,999% 的消息都会被发送。他们中只有少数人抛出了这个异常。

4

1 回答 1

1

这是“解决方案”: https ://groups.google.com/forum/#!msg/google-appengine/vkD2ffMogAg/ntF_EkHYaxcJ

总结: 使用 AppEngine 的几个 URL 调用会失败是很正常的。如果呼叫失败,您只需要再试一次。

我尝试使用 AppEngine 任务队列来解决这个问题。

于 2013-08-15T17:39:13.297 回答