私の GAE サーバーでは、データストアの読み取り操作が 12 時間後に 100% に達し、約 20 人のユーザーがいます。
アプリの他の操作に加えて、アプリに接続しているユーザーが 1 秒ごとにサーバーをプールしているチャットを作成しました。したがって、多くのリクエストがありますが、データストアにアクセスし/message
ていません。
/message
要求数(約 42K) と最大 Datstore 読み取り操作 (50k)の間に相関関係はありますか?
編集:
のコード/message
:
ArrayListMultimap<String, ChatMessage> messages;
ServletContext application = null;
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
{
if (application == null)
{
application = getServletContext();
messages = ArrayListMultimap.create();
}
out = response.getOutputStream();
oos = new ObjectOutputStream(out);
Object o = ServerUtils.readObject(request);
if(o instanceof ChatMessage)
{
ChatMessage message = (ChatMessage) o;
messages.put(message.getReciverId(), message);
List<ChatMessage> list = (List<ChatMessage>) messages.get(message.getReciverId());
}
else if(o instanceof String)
{
String sender = (String) o;
List<ChatMessage> list = (List<ChatMessage>) messages.removeAll(sender);
ArrayList<ChatMessage> newList = new ArrayList<ChatMessage>(list);
reponseToClient(newList);
}
}