Search code examples
androidgoogle-play-servicesgoogle-cloud-messagingchrome-gcm

Rate Limit Exceeded error when using Google Cloud Messaging API


When using the Google Cloud Messaging API to send messages between a backend server and an Android/Chrome client, the backend server can, at times, receive a rate limit exceeded response code. This code is “DeviceMessageRateExceeded” for a HTTP Connection Server and “DEVICE_MESSAGE_RATE_EXCEEDED” for a Cloud Connection Server.

What is this error code and how should it be managed?


Solution

  • The rate limit exception code indicates that you are sending messages from a backend server too frequently. To ensure a stable service, there is a per minute / per device app upper limit on the number of messages that can be sent from a backend server. This limit is set high so most well behaving apps should not be affected, all apps should however be prepared to receive this error code.

    As specified in the question, in the case of an HTTP Connection Server, the error code will be “DeviceMessageRateExceeded”. And for a Cloud Connection Server, it will be “DEVICE_MESSAGE_RATE_EXCEEDED”, which is replacing the previous error code “QUOTA_EXCEEDED”.

    If your backend server receives this error code, it must slow down the rate it sends messages to the client, ideally by implementing exponential backoff.