- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当应用程序停止服务请求直到重新部署之前,我们遇到了一些奇怪的 AppEngine 行为。这看起来像图表上的平坦区域:发生这种情况时,应用程序仍会提供静态内容,但所有 servlet 和 Google Cloud Endpoints 将返回 503 错误。
最近我从 StackDriver 添加了端点监控,它正在检查非常简单的 servlet:
public class HealthCheckServlet extends HttpServlet {
@Override
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
PrintWriter writer = resp.getWriter();
writer.print("ok");
}
}
结果让我更加困惑:
...
2015-01-19 18:05:04 UTC - failed
2015-01-19 18:10:02 UTC - resolved - gave an error for 4 minutes
2015-01-19 18:45:04 UTC - failed - worked for 35 minutes
2015-01-19 18:49:03 UTC - resolved - gave an error for 3 minutes
2015-01-19 18:51:03 UTC - failed - worked for 2 minutes
2015-01-19 19:24:03 UTC - resolved - gave an error for 33 minutes
2015-01-19 19:31:07 UTC - failed - worked for 7 minutes
2015-01-19 19:48:02 UTC - resolved - gave an error for 16 minutes
2015-01-19 20:19:04 UTC - failed - worked for 31 minutes
2015-01-20 03:25:03 UTC - resolved - gave an error for 425 minutes
2015-01-20 03:46:05 UTC - failed - worked for 21 minutes
2015-01-20 06:50:04 UTC - resolved - gave an error for 183 minutes
2015-01-20 07:21:04 UTC - failed - worked for 31 minutes
2015-01-20 07:26:02 UTC - resolved - gave an error for 4 minutes
2015-01-20 09:21:02 UTC - failed - worked for 115 minutes
2015-01-20 09:26:02 UTC - resolved - gave an error for 5 minutes
2015-01-20 14:25:02 UTC - failed - worked for 301 minutes
2015-01-20 14:31:02 UTC - resolved - gave an error for 6 minutes
2015-01-20 15:09:02 UTC - failed - worked for 28 minutes
2015-01-20 15:14:05 UTC - resolved - gave an error for 5 minutes
看起来它有 50% 的时间工作,50% 的时间失败甚至更多!
不知道这是否重要,但我们的应用程序使用具有标准 java7 运行时的托管 VM,并且严重依赖 Cron 和 TaskQueue。
更新:
一些 OOM 调查。
我将其中一个卡住的虚拟机切换为由用户管理,并检查了/var/log 中的所有日志是否存在 OOM - 没有发现任何结果。然后我检查是否有任何 java 进程正在运行 - 没有 java 进程正在运行。这看起来很奇怪,因为如果没有 java 进程来响应运行状况检查,则应该重新启动它,但这个特定的 VM 是在 5 小时前启动的。
然后我将此虚拟机切换回由 Google 管理,GAE 重新启动它,然后我将其切换回由用户管理并检查 java 进程 - 这次有一个占用了 77% 的内存并且还在增加。平均负载开始增加,直至达到峰值 90,然后虚拟机重新启动。
现在很明显我遇到了内存问题,但我没有在日志中找到任何与内存相关的内容。既不在 GAE 控制台中,也不在服务器上。
我当前的假设是自动缩放过程在一段时间后失败。也许有太多与 OOM 相关的 VM 重新启动或 VM 出现一些意外行为。否则如何解释没有java进程的VM几个小时没有重新启动?
为了验证这个假设,我需要找到一些自动缩放日志,但我仍然找不到。
此外,如果能看到托管虚拟机的内存使用情况就太好了,但看起来无论是从 GAE 控制台还是从 StackDriver 都无法获得它。或者我找不到它。
最佳答案
是的,目前托管虚拟机还处于测试阶段,尽管有时它们感觉更像是阿尔法阶段。顺便说一句,我们也遇到了类似的情况。
我们似乎遇到了内存耗尽(并出现 OOM)的问题,这使得 JVM 完全没有响应 - 运行状况检查也不可用。结果是 GAE 重新启动实例 - 这大约需要 4-5 分钟。
由于您的实例服务大量 cron 和任务队列请求,我的假设是它运行长时间运行的任务,这可能会消耗大量内存。
提示:启用健康检查并使其实际执行一些有意义的工作 - 实例化一些类,检查一些内部状态等。同时设置 healthcheck settings到一些合理的值,以便服务器错误在大约一分钟内得到处理。例如 - 文档中列出的默认设置将在大约 10 分钟(5 秒 + 4 秒)* 60 = 9 分钟 + 重新启动时间(2-3 分钟)内开始重新启动无响应的实例。
关于java - AppEngine 突然出现 503 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28049783/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!