- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用嵌入式 jetty 。我将它部署在 unix 机器上,我正在使用 top 命令监视内存。我编写了一个每秒向服务器发送 10 个请求的类。当请求数达到16000时,引擎开始抛出异常:Memory allocation failed during query processing。引擎对发送的每个请求执行 sql 查询。
我使用了 verbose 选项,我注意到内存消耗增加了:
0 秒] [时间:用户=0.00 系统=0.00,真实=0.00 秒]1401.581: [GC [PSYoungGen: 640K->128K(768K)] 126729K->126249K(130816K), 0.0004840 秒] [时间: user=0.00 sys=0.00, real=0.00 秒]1401.585: [GC [PSYoungGen: 640K->96K(768K)] 126761K->126305K(130816K), 0.0004510 秒] [时间: user=0.00 sys=0.00, real=0.00 秒]1401.590: [GC [PSYoungGen: 605K->128K(768K)] 126814K->126379K(130816K), 0.0004500 秒] [时间: user=0.01 sys=0.00, real=0.00 秒]1401.595: [GC [PSYoungGen: 640K->80K(768K)] 126891K->126419K(130816K), 0.0004270 秒] [时间: user=0.00 sys=0.00, real=0.00 秒]
我使用 jetty.xml 配置嵌入式 jetty 服务器,我使用的是队列线程池,具有以下值:
最小线程数:10最大线程数:20
谁能帮我确定内存泄漏?它与我访问数据库的方式有关吗?和Jetty有关吗?
下面是主要类(从 eclipsepedia 中获取样本:(http://wiki.eclipse.org/Jetty/Tutorial/Embedding_Jetty)
public class PPTEST {
private static String fileName = "*************/properties.conf";
private static Properties p = new Properties();
public static void main(String[] args) throws Exception {
try {
loadProperties(fileName);
Resource fileserver_xml = Resource.newResource("********/jetty.xml");
XmlConfiguration configuration = new XmlConfiguration(fileserver_xml.getInputStream());
Server server = (Server) configuration.configure();
server.setHandler(new HandlerApple());
server.start();
server.join()
} catch (Exception e) {
e.printStackTrace();
}
}
private static void loadProperties(String fileName)
throws IOException {
FileInputStream propsFile = new FileInputStream(fileName);
p.load(propsFile);
propsFile.close();
}
这是 HandlerApple 类:
公共(public)类 HandlerApple 扩展了 AbstractHandler {
//Properties p = new Properties();
private String CHARACTERS = "0123456789ABCDEF";
private String OK = "HTTP/1.1 200 OK";
Properties config;
public org.apache.log4j.Logger logger;
private String fileName = "****************/gprs-properties.conf";
private String smsformat = "*****************/smsformat.prop";
private Connection dbConn;
private HashMap hpSystem;
private HashMap hpConf;
private String prefix;
private String mobfiltering;
private String resp600;
private String resp601;
private String resp602;
private String resp603;
private String resp604;
private String resp605;
private String resp607;
private String resp608;
private String resp612;
private String resp613;
private String resp611;
private String resp606;
private String resp666;
private String ipH;
private String portH;
private String timeoutH;
private String trpmC;
private String ttpipC;
private String lpdC;
private String igprsC;
private String first_timeout;
private String second_timeout;
private PreparedStatement pstmt;
private ResultSet rs;
Random randomGenerator = new Random();
HandlerApple() {
DatabaseSingleton d = new DatabaseSingleton();
try {
org.apache.log4j.PropertyConfigurator.configure("************/log4j.properties");
logger = org.apache.log4j.Logger.getLogger(HandlerApple.class.getName());
logger.info("Contructor Level");
dbConn = d.getConnection();
hpSystem = loadConfigFile(fileName);
hpConf = loadConfigFile(smsformat);
prefix = (String) hpSystem.get("prefixes");
mobfiltering = (String) hpSystem.get("mobile-filtering");
resp600 = (String) hpConf.get("600");
resp601 = (String) hpConf.get("601");
resp602 = (String) hpConf.get("602");
resp603 = (String) hpConf.get("603");
resp604 = (String) hpConf.get("604");
resp605 = (String) hpConf.get("605");
resp607 = (String) hpConf.get("607");
resp608 = (String) hpConf.get("608");
resp612 = (String) hpConf.get("612");
resp613 = (String) hpConf.get("613");
resp611 = (String) hpConf.get("611");
resp606 = (String) hpConf.get("606");
resp666 = (String) hpConf.get("666");
ipH = (String) hpSystem.get("module-1.ip");
portH = (String) hpSystem.get("module-1.port");
timeoutH = (String) hpSystem.get("module-1.timeout");
trpmC = (String) hpSystem.get("trpm");
ttpipC = (String) hpSystem.get("ttpip");
lpdC = (String) hpSystem.get("lpd");
igprsC = (String) hpSystem.get("igprs.trpm");
first_timeout = (String) hpSystem.get("timeout.1");
second_timeout = (String) hpSystem.get("timeout.2");
logger.info("==================================================================");
logger.info("Clearing maps");
logger.info("==================================================================");
hpSystem.clear();
hpConf.clear();
pstmt = null;
rs = null;
} catch (Exception e) {
e.printStackTrace();
}
}
public void handle(String target, Request baseRequest, HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
try{
//Some code
}catch (Exception e){
//
}
finally {
response.flushBuffer();
if (pstmt != null) {
try {
pstmt.close();
} catch (SQLException ex) {
Logger.getLogger(HandlerApple.class.getName()).log(Level.SEVERE, null, ex);
}
}
if (rs != null) {
try {
rs.close();
} catch (SQLException ex) {
Logger.getLogger(HandlerApple.class.getName()).log(Level.SEVERE, null, ex);
}
}
}
}
我正在使用 DatabaseSingleton 类:
public class DatabaseSingleton {
//Static instance of connection, only one will ever exist
private Connection connection = null;
//Returns single instance of connection
public Connection getConnection() {
//If instance has not been created yet, create it
if (connection == null) {
initConnection();
}
return connection;
}
private void initConnection() {
try {
Class.forName("com.informix.jdbc.IfxDriver");
Properties p=new Properties();
loadProperties("************/gprs-properties.conf", p);
String dburl = p.getProperty("gprs.informix.url");
String dbuser = p.getProperty("gprs.informix.user");
String dbpass = p.getProperty("gprs.informix.password");
connection =
DriverManager.getConnection(dburl, dbuser, dbpass);
} catch (ClassNotFoundException e) {
System.out.println(e.getMessage());
System.exit(0);
} catch (SQLException e) {
System.out.println(e.getMessage());
System.exit(0);
} catch (Exception e) {
}
}
private void loadProperties(String fileName, Properties p)
throws IOException {
FileInputStream propsFile = new FileInputStream(fileName);
p.load(propsFile);
propsFile.close();
}
在抛出异常并停止引擎后,将打印以下内容(使用详细选项):
Heap
PSYoungGen total 832K, used 288K [0xb4d60000, 0xb4e60000, 0xb4e60000)
eden space 640K, 32% used [0xb4d60000,0xb4d94060,0xb4e00000)
from space 192K, 41% used [0xb4e30000,0xb4e44010,0xb4e60000)
to space 192K, 0% used [0xb4e00000,0xb4e00000,0xb4e30000)
PSOldGen total 219520K, used 212479K [0x94e60000, 0xa24c0000, 0xb4d60000)
object space 219520K, 96% used [0x94e60000,0xa1ddfc50,0xa24c0000)
PSPermGen total 16384K, used 8145K [0x90e60000, 0x91e60000, 0x94e60000)
object space 16384K, 49% used [0x90e60000,0x91654420,0x91e60000)
异常跟踪如下:
java.sql.SQLException: Memory allocation failed during query processing.
at com.informix.util.IfxErrMsg.getSQLException(IfxErrMsg.java:373)
at com.informix.jdbc.IfxSqli.a(IfxSqli.java:3208)
at com.informix.jdbc.IfxSqli.E(IfxSqli.java:3518)
at com.informix.jdbc.IfxSqli.dispatchMsg(IfxSqli.java:2353)
at com.informix.jdbc.IfxSqli.receiveMessage(IfxSqli.java:2269)
at com.informix.jdbc.IfxSqli.executePrepare(IfxSqli.java:1153)
at com.informix.jdbc.IfxPreparedStatement.e(IfxPreparedStatement.java:318)
at com.informix.jdbc.IfxPreparedStatement.a(IfxPreparedStatement.java:298)
at com.informix.jdbc.IfxPreparedStatement.<init>(IfxPreparedStatement.java:168)
at com.informix.jdbc.IfxSqliConnect.h(IfxSqliConnect.java:5918)
at com.informix.jdbc.IfxSqliConnect.prepareStatement(IfxSqliConnect.java:1999)
at pinpayhttp.HandlerApple.checkIP(HandlerApple.java:520)
at pinpayhttp.HandlerApple.handle(HandlerApple.java:227)
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
at org.eclipse.jetty.server.Server.handle(Server.java:346)
at org.eclipse.jetty.server.HttpConnection.handleRequest(HttpConnection.java:596)
at org.eclipse.jetty.server.HttpConnection$RequestHandler.content(HttpConnection.java:1068)
at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:807)
at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:220)
at org.eclipse.jetty.server.HttpConnection.handle(HttpConnection.java:426)
at org.eclipse.jetty.io.nio.SelectChannelEndPoint.handle(SelectChannelEndPoint.java:520)
at org.eclipse.jetty.io.nio.SelectChannelEndPoint$1.run(SelectChannelEndPoint.java:40)
at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:528)
at java.lang.Thread.run(Thread.java:619)
Caused by: java.sql.SQLException
at com.informix.util.IfxErrMsg.getSQLException(IfxErrMsg.java:373)
at com.informix.jdbc.IfxSqli.E(IfxSqli.java:3523)
内存分配失败异常后:
1: 209324 76966096 [Ljava.lang.Object;
2: 12971 45337576 [B
3: 1537794 24604704 java.lang.Integer
4: 172537 13265160 [C
5: 32768 10223616 com.informix.jdbc.IfxSqli
6: 32767 6291264 com.informix.jdbc.IfxPreparedStatement
7: 207565 4981560 java.util.Vector
8: 39807 4056792 [I
9: 160921 3862104 java.lang.String
10: 32767 3145632 com.informix.jdbc.IfxResultSet
11: 19329 2202664 <constMethodKlass>
12: 21846 2097216 com.informix.jdbc.IfxColumnInfo
13: 19329 1550760 <methodKlass>
14: 32767 1310680 com.informix.jdbc.IfxResultSetMetaData
15: 30807 1118264 <symbolKlass>
16: 1400 843192 <constantPoolKlass>
17: 10901 784872 com.informix.jdbc.IfxChar
18: 1400 597000 <instanceKlassKlass>
19: 1276 542848 <constantPoolCacheKlass>
20: 32774 524384 java.lang.StringBuffer
21: 10923 524304 com.informix.jdbc.IfxRowColumn
22: 1274 326536 <methodDataKlass>
23: 2258 181760 [S
24: 1563 150048 java.lang.Class
25: 2147 117904 [[I
26: 2820 67680 java.util.HashMap$Entry
27: 1936 46464 java.lang.StackTraceElement
28: 134 42880 <objArrayKlassKlass>
29: 319 42456 [Ljava.util.HashMap$Entry;
30: 1478 35472 java.util.Hashtable$Entry
31: 293 18752 org.eclipse.jetty.io.BufferCache$CachedBuffer
32: 212 16008 [Ljava.lang.String;
33: 445 14240 org.eclipse.jetty.util.StringMap$Node
34: 76 14000 [Ljava.util.Hashtable$Entry;
35: 163 13040 [Lorg.eclipse.jetty.util.StringMap$Node;
36: 301 12040 java.util.HashMap
37: 358 11456 java.util.LinkedHashMap$Entry
38: 308 9856 java.lang.ref.SoftReference
39: 89 8816 [Ljava.lang.StackTraceElement;
40: 140 7840 org.eclipse.jetty.io.ByteArrayBuffer
41: 195 7800 java.sql.SQLException
42: 192 6144 java.util.concurrent.ConcurrentHashMap$Segment
43: 81 5184 java.lang.reflect.Constructor
44: 10 4896 [[Ljava.lang.Object;
45: 294 4704 java.util.jar.Attributes$Name
46: 195 4680 java.util.concurrent.locks.ReentrantLock$NonfairSync
47: 78 4368 java.net.URL
48: 161 3864 java.lang.ref.WeakReference
49: 192 3440 [Ljava.util.concurrent.ConcurrentHashMap$HashEntry;
50: 143 3432 sun.security.util.ObjectIdentifier
51: 85 3400 java.math.BigInteger
52: 138 3312 java.util.ArrayList
53: 66 3168 java.beans.MethodDescriptor
54: 98 3136 java.lang.ref.Finalizer
55: 56 3136 java.security.Provider$Service
56: 124 2976 com.sun.org.apache.xerces.internal.xni.QName
57: 24 2880 java.net.SocksSocketImpl
58: 118 2832 java.security.Provider$ServiceKey
59: 8 2560 <typeArrayKlassKlass>
60: 6 2464 [Lcom.sun.org.apache.xerces.internal.xni.QName;
61: 61 2440 java.util.Hashtable
62: 22 2288 sun.nio.ch.SocketChannelImpl
63: 25 2248 [Z
64: 2 2248 [Lorg.eclipse.jetty.http.HttpStatus$Code;
65: 140 2240 java.util.jar.Attributes
66: 70 2240 java.lang.ThreadLocal$ThreadLocalMap$Entry
67: 7 2120 [J
68: 1 2048 [Lorg.eclipse.jetty.http.HttpGenerator$Status;
69: 36 2016 java.nio.DirectByteBuffer
70: 251 2008 java.lang.Object
71: 27 1944 java.util.jar.JarFile$JarFileEntry
72: 21 1680 java.lang.reflect.Method
73: 16 1664 java.lang.Thread
74: 65 1560 java.util.concurrent.ConcurrentHashMap$HashEntry
75: 19 1520 [Ljava.lang.ThreadLocal$ThreadLocalMap$Entry;
76: 14 1456 [[Ljava.lang.String;
77: 36 1440 sun.misc.Cleaner
78: 30 1440 java.util.ResourceBundle$CacheKey
79: 22 1408 java.beans.PropertyDescriptor
80: 35 1400 sun.misc.URLClassPath$JarLoader
81: 73 1360 [Ljava.lang.Class;
82: 27 1296 java.lang.Package
83: 81 1296 java.util.HashMap$EntrySet
84: 27 1296 java.util.jar.JarFile
85: 50 1200 sun.security.util.DerInputBuffer
86: 50 1200 sun.security.util.DerValue
87: 30 1200 java.util.ResourceBundle$BundleReference
88: 50 1200 sun.security.x509.RDN
89: 47 1128 java.net.InetSocketAddress
90: 47 1128 org.eclipse.jetty.http.HttpStatus$Code
91: 47 1128 java.io.ExpiringCache$Entry
92: 10 1120 <klassKlass>
93: 46 1104 org.eclipse.jetty.http.HttpGenerator$Status
94: 8 1088 java.text.DecimalFormat
95: 45 1080 java.net.Inet4Address
96: 2 1056 [Ljava.lang.Integer;
97: 22 1056 sun.nio.ch.SocketAdaptor
98: 1 1040 [Lcom.sun.org.apache.xerces.internal.impl.dtd.models.ContentModelValidator;
99: 1 1040 [Lsun.text.normalizer.UnicodeSet;
100: 1 1040 [Lcom.sun.org.apache.xerces.internal.impl.dv.DatatypeValidator;
101: 8 1000 [Ljava.beans.MethodDescriptor;
102: 41 984 com.sun.org.apache.xerces.internal.util.SymbolTable$Entry
103: 12 960 [Ljava.util.concurrent.ConcurrentHashMap$Segment;
104: 30 960 java.util.ResourceBundle$LoaderReference
105: 40 960 com.informix.util.IfxMessage$bundleMap
106: 58 928 <compiledICHolderKlass>
107: 28 896 java.util.zip.Inflater
108: 8 896 java.util.GregorianCalendar
109: 36 864 java.nio.DirectByteBuffer$Deallocator
110: 9 864 sun.util.calendar.Gregorian$Date
111: 52 832 java.security.Provider$UString
112: 50 800 sun.security.util.DerInputStream
113: 50 800 sun.security.x509.AVA
114: 50 800 [Lsun.security.x509.AVA;
115: 33 792 sun.reflect.NativeConstructorAccessorImpl
116: 16 768 java.util.LinkedHashMap
117: 23 736 java.util.Locale
118: 30 720 java.security.Provider$EngineDescription
119: 18 720 com.sun.org.apache.xerces.internal.impl.dtd.XMLSimpleType
120: 1 704 [Lcom.sun.org.apache.xerces.internal.util.SymbolTable$Entry;
121: 2 640 <arrayKlassKlass>
122: 16 640 java.util.WeakHashMap$Entry
123: 39 624 java.util.regex.Pattern$CharPropertyNames$1
124: 19 608 java.io.ObjectStreamField
125: 15 600 sun.nio.cs.ISO_8859_1$Decoder
126: 25 600 com.sun.org.apache.xerces.internal.util.XMLStringBuffer
127: 12 576 java.nio.HeapByteBuffer
128: 36 576 sun.reflect.DelegatingConstructorAccessorImpl
129: 12 576 sun.security.x509.X500Name
130: 11 528 java.util.Properties
131: 22 528 java.util.Date
132: 22 528 com.sun.org.apache.xerces.internal.xni.XMLString
133: 22 528 sun.security.x509.OIDMap$OIDInfo
134: 22 528 [Ljava.nio.channels.SelectionKey;
135: 8 512 java.text.DecimalFormatSymbols
136: 21 504 java.security.AccessControlContext
137: 21 504 sun.security.x509.AVAKeyword
138: 7 504 org.eclipse.jetty.io.nio.DirectNIOBuffer
139: 31 496 java.io.FileDescriptor
140: 12 480 java.util.concurrent.ConcurrentHashMap
141: 15 480 com.sun.org.apache.xerces.internal.impl.dtd.XMLElementDecl
142: 19 456 java.lang.ThreadLocal$ThreadLocalMap
143: 7 448 java.text.SimpleDateFormat
144: 8 448 org.eclipse.jetty.io.nio.IndirectNIOBuffer
145: 9 432 sun.util.calendar.ZoneInfo
146: 17 408 com.informix.msg.bundleMap
147: 5 400 java.net.URI
Total 2644614 206176808
有人可以帮忙吗?我只需要一些指导...
最佳答案
对于高负载,您的内存限制似乎非常低。我会尝试 -mx1g
作为开始,如果你有更多内存(和 64 位 JVM),我会尝试更多。
由于消息可能很重要,您能否打印出确切的异常?
关于java - 负载测试期间嵌入式 Jetty 中的内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11357091/
在没有指定上下文和上下文处理程序的情况下启动 jetty 实例是否正确,然后在服务器启动后继续向其添加上下文。尽管我能够使用可变 HandlerCollection 执行此操作并且日志显示服务器和上下
在没有指定上下文和上下文处理程序的情况下启动 jetty 实例是否正确,然后在服务器启动后继续向其添加上下文。尽管我能够使用可变 HandlerCollection 执行此操作并且日志显示服务器和上下
我正在尝试让 Jetty 在我的 Ubuntu 上自动启动。 我已经完成了这些命令: cp /opt/jetty/bin/jetty.sh /etc/init.d update-rc.d jett
我是 Jetty 和客户端/服务器架构的新手。 我设法在 Eclipse 中编写了一个 jetty 服务器,它可以工作。 但是我怎样才能停止 jetty 服务器呢?我听说过 stop.jar 和 st
我已经使用Jetty / tomcat应用服务器使用Spring Web应用程序工作了大约两年了,但是让我感到困惑的是如何在这些服务器中处理多个请求。我知道 Spring 有助于单例,但我的理解仅限于
我正在尝试使用 jetty 来使用 maven 托管一个简单的 helloworld servlet。我很困惑。 我关注了这些 instructions ,但是当我发出 mvn jetty:run ,
我正在使用 Jetty 9,我有 jetty.base 和 jetty.home,我想知道我什么时候启动 jetty,它以什么样的顺序调用 jetty.base 和 jetty.home,我的意思是一
我有一个 Ubuntu 服务器 10.10 64 位 在 上运行 Web 应用程序 jetty 6.1.24-6 在 Sun 的 JVM ,两者都是从标准 Ubuntu 存储库安装的。 我正在尝试查找
我在集成测试中使用 ShrinkWrap 启动 Jetty 服务器。 问题: 当我启动我的测试 jetty 服务器而不是制作我的 Controller 模型时 - 模型不起作用! 我认为原因是不同的类
使用Gradle帮助运行Jetty 9 我已经看到了在how-to-run-jetty-7-with-specified-war-with-groovy-gradle和setting_up_embed
我正在将一个项目打包到 docker jetty 镜像中,并且我正在尝试访问日志,但没有访问日志。 文件 FROM jetty:9.2.10 MAINTAINER Me "me@me.com" ADD
有没有办法解决jetty引起的文件锁定问题?完全来自 gradle ? 一些澄清: 使用 Gradle Jetty plugin 时通过运行 gradle jettyRun, jetty 导致静态资源
我最近才开始使用 Java(我最近的大部分经验都在 .NET 中)。作为这项工作的一部分,我一直在对 Jetty 和 Tomcat 进行一些比较。 我认为在我们的环境中 Tomcat 的一个功能是内置
我已将 Jetty 嵌入到 Java 应用程序中,并在 Jetty 服务器对象的实例上调用 start() 方法(在设置描述静态和动态 Web 内容位置的处理程序列表之后)。 start() 调用会阻
我正在使用 Jetty 部署生产网站。假设我的网站是 foo.com 当我将浏览器指向一个不存在的上下文(比如 foo.com/notavailable)时,Jetty 会显示一个错误页面,其中包含部
我想使用 Jetty 的嵌入式版本创建一个应用程序。不幸的是,我找不到有关我需要这样做的 jar 文件的任何信息。 Maven 存储库中有几个( http://repo2.maven.org/mave
This answer explains how the server version header can be completely removed通过使用 HttpConfiguration.s
有人可以告诉我DispatcherType在做什么吗? 似乎是重要的配置。 指向ServletContextHandler#addFilter之类的东西对类的使用也没有帮助,对我来说,“ aa”是明智
我正在尝试使用jetty gradle插件运行Jetty服务器进行功能测试。但是,我得到了java.lang.IllegalArgumentException: Object is not of ty
我需要在gradle构建中创建多种不同的模式来运行 jetty 。 它们的系统属性和类路径不同。 如何使用Gradle Jetty插件进行操作? 最佳答案 您可以创建JettyRun类型的多个任务。要
我是一名优秀的程序员,十分优秀!