首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >平均Cpu,URI占用大量cpu

平均Cpu,URI占用大量cpu
EN

Stack Overflow用户
提问于 2010-08-19 21:50:35
回答 1查看 335关注 0票数 3

你好,我使用了一个servlet,它包含一个具有两个对象的持久性管理器对象,当我在仪表板中使用它时,我会收到以下消息:

“此URI占用大量cpu,可能很快就会超出其配额。”

我这个uri的平均Cpu是2300,为什么花了这么长时间?

当我开始查看日志时,我有大量的cpu,例如2000,而在我有不到200个cpu之后,为什么?

10分钟后,当我回来的时候,我又有了大量的cpu,为什么?

有没有可能减少这段时间?

编辑:代码

公共无效doGet(HttpServletRequest请求,HttpServletResponse响应)抛出IOException {

代码语言:javascript
运行
复制
    String param1 = req.getParameter("param1");
    String param2 = req.getParameter("param2");

    PersistenceManager pm = PMF.get().getPersistenceManager();
    String query = "select from " + Myclass.class.getName()+
    "where parameter1 == param1 && parameter2 == param2 "+
    "parameters String param1, String param2";

List<Myclass> result = (List<Myclass>) pm.newQuery(query).execute(param1, param2);

    if(result.isEmpty()) {
        pm.close();
        resp.sendRedirect("/welcome.jsp");
    }
    else {
        pm.close();
        resp.sendRedirect("/question.jsp");
    }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-08-20 13:10:22

这是因为谷歌应用程序引擎的cold starts

因为google app engine的工作方式是,如果在一段时间内看不到请求,它就会终止应用程序实例。因此,在一段休息之后的第一个请求需要更长的时间,并且后续的请求相对较快。

有许多讨论这个问题和可能的解决方案的帖子,主要描述了两种解决方案-

  1. 优化您的代码用于启动
  2. 不建议创建cron或任何其他类型的定期HTTP请求来保持实例正常运行。这是一个非常糟糕的方法,我不推荐这样做,因为它会对整个目的和云的工作原理产生不利影响。

下面是更多关于这个问题的讨论:

  1. App instance recycling and response times - is there solution?
  2. Application instances seem to be too aggressively recycled
  3. Uneven response time between connection to server to first byte sent
  4. Google App Engine application instance recycling and response times…
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3522430

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档