- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
Tomcat 5.5.x 和 6.0.x
Grails 1.6.x
Java 1.6.x
操作系统 CentOS 5.x(64 位)
内存为384M的VPS服务器
JAVA_OPTS:尝试了很多组合——包括以下
导出 JAVA_OPTS='-Xms128M -Xmx512M -XX:MaxPermSize=1024m'
export JAVA_OPTS='-server -Xms128M -Xmx128M -XX:MaxPermSize=256M'
(根据 http://www.grails.org/Deployment 的建议)
我创建了一个空白的 Grails 应用程序,即简单地通过给出命令 grails create-app 然后 WARed 它
我在 VPS 服务器上运行 Tomcat
当我简单启动Tomcat服务器时,没有部署任何应用程序,可用内存约为236M占用内存约156M
当我部署“空白”应用程序时,内存消耗激增至 360M,最后 Tomcat 实例在占用所有可用内存后立即被杀死
如您所见,我的应用尽可能轻便。
不确定为什么内存消耗如此之高。
我实际上是在对一个真实的应用程序进行故障排除,但已将范围缩小到更易于分享和解释的场景。
更新我在 Windows 上的本地 Tomcat 5.5.x 上测试了相同的“空白”应用程序,它运行良好
Java进程的内存消耗从32M猛增到107M。但它没有崩溃,并且仍在可接受的范围内
所以继续寻找答案...我想知道我的 Linux 机器是不是出了什么问题。虽然不确定...
更新 2另见 http://www.grails.org/Grails+Test+On+Virtual+Server
它证实了我的信念,即我的简单空白应用程序应该适用于我的配置。
最佳答案
试图在尽可能少的内存中运行一个长时间运行的基于 Java 的应用程序是一种错误的经济。如果垃圾收集器有足够的常规堆内存,那么应用程序将运行得更加高效。为应用程序提供太少的堆,它将花费太多时间进行垃圾收集。
(这似乎有点违反直觉,但请相信我:这种效果在理论上是可以预测的,在实践中是可以观察到的。)
编辑
实际上,我建议采用以下方法:
首先运行 Tomcat + Grails,尽可能多地分配内存,这样您就可以运行一些东西。 (将 permgen 大小设置为默认值……除非您有明确证据表明 Tomcat + Grails 正在耗尽 permgen。)
运行应用一段时间,使其达到稳定状态,并找出其平均工作集是多少。您应该能够通过内存分析器或通过检查 GC 日志记录来弄清楚这一点。
然后将 Java 堆大小设置为(比方说)测量的工作集大小的两倍或更多。 (这是我在上面试图表达的观点。)
实际上,您的问题还有另一个可能的原因。即使您告诉 Java 使用给定大小的堆,它也可能无法这样做。当 JVM 向操作系统请求内存时,有几种情况操作系统会拒绝。
如果您运行操作系统的机器(真实或虚拟)不再有任何未分配的“真实”内存,并且操作系统的交换空间已完全分配,它将不得不拒绝更多内存请求。
也有可能(尽管不太可能)每个进程的内存限制生效。这将导致操作系统拒绝超出该限制的请求。
最后,请注意 Java 使用更多的虚拟内存,这可以通过简单地将堆栈、堆和 permgen 数字相加来说明。有可执行文件 + DLL 使用的内存,用于 I/O 缓冲区的内存,可能还有其他东西。
关于java - Grails 应用程序占用太多内存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2535458/
我正在阅读 SQL/92(我是新手),它经历了不同的数据类型。其中之一是CHAR,我当然知道它与java中的String非常相似,而不是java中的char。但我们假设它是 CHAR(1)。只有一个字
我的 mysqld 进程消耗了 232% 的 CPU,并且有 14000 多个连接 (我对这件事有点陌生,但关注 Stack Overflow 寻求帮助)。 顶部: PID USER P
Tomcat 服务器占用 100% 的 CPU,但仅在 PRD。我们无法在其他环境中重现这一点。 进行线程转储后,我们发现有一些线程处于等待/可运行状态,但无法找到我们如何找到根本原因。 你能帮忙吗?
我正在使用 Xcode、SpriteKit 和 Swift 构建我的第一款 iPhone 游戏。我对这些技术不熟悉,但我熟悉一般的编程概念。 这是我想用英语做的事情。我想让圆圈随机出现在屏幕上,然后开
我的套接字消耗了 100% 的计算机 CPU。有 150 个客户端每 30 秒异步向服务器发送消息。有谁知道如何解决这个问题?下面是我的 ServerSocket 类 public class Ser
一段时间后(有时几分钟,有时几天),我的应用开始消耗 100% 的 CPU。正如我从 VisualVM 看到的那样,它总是发生在 org.elasticsearch.common.netty.chan
在我的容器 Controller 中,用户可以平移 View 以切换到不同的 View 。当平移手势开始时,它会将新 View Controller 的 View 添加到 View 中:view.in
假设我在数据框中有两列,其中一列不完整。 df = pd.DataFrame({'a': [1, 2, 3, 4], 'b':[5, '', 6, '']}) df Out: a b
在Ubuntu 16.04 LTS中,pyteserract脚本吃得太高,导致系统间歇性重启。 top命令输出为 top - 21:23:31 up 27 min, 4 users, lo
我在具有 88 个内核和 60 个 reducer 的 hadoop 集群上运行 mapreduce 作业。由于某种原因,它只使用了 79 个集群核心。开始时它运行 79 个映射器,但当完成一半拆分时
我正在对机器上的所有用户进行查询,当它执行时,它会占用 100% 的 CPU 并锁定系统。我已经等了 5 分钟,但什么也没有发生。 在任务管理器中,wmiprvse.exe 占用了所有 CPU。当我终
我正在从套接字(通过 TCP 协议(protocol))读取消息,但我注意到 CPU 花费大量时间来调用 BufferedInputStream 的 available() 方法。这是我的代码:
我有 6 个线程。其中一个线程进入某个范围并打开“锁定”和所有其他线程线程正在等待并希望进入相同的范围。 现在,其他线程是否会获得 CPU 时间?其他线程是否在线程调度中?我知道所有其他线程都处于等待
我正在尝试创建一个社交媒体应用程序。但它需要大约 300mb 内存。所以我的主页上有 5 个包含帖子的 fragment 。总体内存使用量为 250-300mb 然后为了测试,我禁用了这些 fragm
我有一个带有一些 TextFormField 的表单,我想扩展最后一个 TextFormField 以占据屏幕的其余部分。最后一个 TextFormField 可以有多行文本。 我没能做到这一点,并尝
我收到磁盘几乎已满的警告,所以我运行 DaisyDisk .. 显然 Xcode 占用了 15GB 的空间: http://imgur.com/a/cTIZZ iOS 设备支持为 12.3 GB: h
我正在使用 Xcode Playground 研究 Swift 内存布局,我创建了一个带有 bool、double 和 int32 的结构,如下所示。基于这种结构,MemoryLayout 的打印结果
一旦执行“self.navigationController pushviewcontroller:vc animated:YES”,我的 CPU 就会达到 100%。我在 Stack Overflo
警告:CPU 使用率达到 100%,请小心。 Link to the jsFiddle 编写此脚本是为了设计动态蛇梯板。每次刷新页面时,都会创建一个新板。大多数时候所有的背景图像都不会出现,CPU 使
我不知道为什么,但是MYSQL给CPU带来了很大的负载。我必须每秒多次更新数据库,并且用户群正在不断增长。 一开始还好,但是现在 CPU 负载每天都在增加 这是日志中的慢速查询: *Query_tim
我是一名优秀的程序员,十分优秀!