Details
-
Type: Improvement
-
Status: Closed
-
Priority: Major
-
Resolution: Fixed
-
Affects Version/s: 1.7.1
-
Component/s: ICE-Components
-
Labels:None
-
Environment:Any
Description
We are wasting some amount of memory per client with every EL expression. We are using 5,160 bytes in string objects per client in both auction monitor and address demo (coincidentally it's the same amount). We are keeping in memory strings like "#{AuctionBean.sortByTitle}" for every client, while the value is the same and never changes. This doesn't happen with standard JSF or facelets, only when using JSPs.
Both standard JSF and ICEfaces use a group of objects from the org.apache.el.parser package to store EL expressions. Only one set of these objects is necessary for each EL expression in a document. The number of instances of these objects is not proportional to the number of clients accessing a document in both standard JSF and ICEfaces. The problem is that ICEfaces references these objects indirectly through other three objects, and one of those objects stores the entire string of the EL expression. This is being done on a per-client basis.
A concrete example would illustrate this better. Consider the following EL expression: "#{AuctionBean.sortByTitle}". The servlet container (in this case Tomcat 6) represents this expression with an AstValue object (from org.apache.el.parser), and this object has two children: AstIdentifier, which stores the string "AuctionBean", and AstDotSuffix, which stores the string "sortByTitle". Only one set of these objects is created per EL expression in a document. ICEfaces does the following. An HtmlCommandLink object, from the 'actionExpression field', references an instance of MethodExpressionMethodBindingAdapter (from javax.faces.component), whose sole job is to reference an instance of MethodBindingMethodExpressionAdapter (from com.sun.faces.application), which in turn references an instance of MethodExpressionImpl (from org.apache.el). This last object finally references the AstValue object mentioned above, but also has a String object with the value "#{AuctionBean.sortByTitle}". This is done for every client for every EL expression, and the string is not in constant pools and is not shared by
other EL related objects, even if the value is the same.
In facelets, things are different. For example, a`component object has a hash map called 'bindings'. The values of this hash map are TagValueExpression objects (from com.sun.facelets.el). These objects reference orig ValueExpressionImpl objects (from org.apache.el), as above. However, these ValueExpressionImpl objects reference the same string object when the EL expression is the same.
Both standard JSF and ICEfaces use a group of objects from the org.apache.el.parser package to store EL expressions. Only one set of these objects is necessary for each EL expression in a document. The number of instances of these objects is not proportional to the number of clients accessing a document in both standard JSF and ICEfaces. The problem is that ICEfaces references these objects indirectly through other three objects, and one of those objects stores the entire string of the EL expression. This is being done on a per-client basis.
A concrete example would illustrate this better. Consider the following EL expression: "#{AuctionBean.sortByTitle}". The servlet container (in this case Tomcat 6) represents this expression with an AstValue object (from org.apache.el.parser), and this object has two children: AstIdentifier, which stores the string "AuctionBean", and AstDotSuffix, which stores the string "sortByTitle". Only one set of these objects is created per EL expression in a document. ICEfaces does the following. An HtmlCommandLink object, from the 'actionExpression field', references an instance of MethodExpressionMethodBindingAdapter (from javax.faces.component), whose sole job is to reference an instance of MethodBindingMethodExpressionAdapter (from com.sun.faces.application), which in turn references an instance of MethodExpressionImpl (from org.apache.el). This last object finally references the AstValue object mentioned above, but also has a String object with the value "#{AuctionBean.sortByTitle}". This is done for every client for every EL expression, and the string is not in constant pools and is not shared by
other EL related objects, even if the value is the same.
In facelets, things are different. For example, a`component object has a hash map called 'bindings'. The values of this hash map are TagValueExpression objects (from com.sun.facelets.el). These objects reference orig ValueExpressionImpl objects (from org.apache.el), as above. However, these ValueExpressionImpl objects reference the same string object when the EL expression is the same.
Issue Links
- blocks
-
ICE-3083 Memory performance/efficiency
- Open
Activity
- All
- Comments
- History
- Activity
- Remote Attachments
- Subversion
Arturo Zambrano
created issue -
Arturo Zambrano
made changes -
Field | Original Value | New Value |
---|---|---|
Description |
We are wasting some amount of memory per client with every EL expression. We are using 5,160 bytes in string objects per client in both auction monitor and address demo (coincidentally it's the same amount). We are keeping in memory strings like "#{AuctionBean.sortByTitle}" for every client, while the value is the same and never changes. This doesn't happen with standard JSF or facelets, only when using JSPs. Both standard JSF and ICEfaces use a group of objects from the org.apache.el.parser package to store EL expressions. Only one set of these objects is necessary for each EL expression in a document. The number of instances of these objects is not proportional to the number of clients accessing a document in both standard JSF and ICEfaces. The problem is that ICEfaces references these objects indirectly through other three objects, and one of those objects stores the entire string of the EL expression. This is being done on a per-client basis. A concrete example would illustrate this better. Consider the following EL expression: "#{AuctionBean.sortByTitle}". The servlet container (in this case Tomcat 6) represents this expression with an AstValue object (from org.apache.el.parser), and this object has two children: AstIdentifier, which stores the string "AuctionBean", and AstDotSuffix, which stores the string "sortByTitle". Only one set of these objects is created per EL expression in a document. ICEfaces does the following. An HtmlCommandLink object, from the 'actionExpression field', references an instance of MethodExpressionMethodBindingAdapter (from javax.faces.component), whose sole job is to reference an instance of MethodBindingMethodExpressionAdapter (from com.sun.faces.application), which in turn references an instance of MethodExpressionImpl (from org.apache.el). This last object finally references the AstValue object mentioned above, but also has a String object with the value "#{AuctionBean.sortByTitle}". This is done for every client for every EL expression, and the string is not in constant pools and is not shared by other EL related objects, even if the value is the same. In facelets, things are different. For example, a`component object has a hash map called 'bindings'. The values of this hash map are TagValueExpression objects (from com.sun.facelets.el). These objects reference orig ValueExpressionImpl objects (from org.apache.el), as above. However, these ValueExpressionImpl objects reference the same string object when the EL expression is the same. |
We are wasting some amount of memory per client with every EL expression. We are using 5,160 bytes in string objects per client in both auction monitor and address demo (coincidentally it's the same amount). We are keeping in memory strings like "#{AuctionBean.sortByTitle}" for every client, while the value is the same and never changes. This doesn't happen with standard JSF or facelets, only when using JSPs. Both standard JSF and ICEfaces use a group of objects from the org.apache.el.parser package to store EL expressions. Only one set of these objects is necessary for each EL expression in a document. The number of instances of these objects is not proportional to the number of clients accessing a document in both standard JSF and ICEfaces. The problem is that ICEfaces references these objects indirectly through other three objects, and one of those objects stores the entire string of the EL expression. This is being done on a per-client basis. A concrete example would illustrate this better. Consider the following EL expression: "#{AuctionBean.sortByTitle}". The servlet container (in this case Tomcat 6) represents this expression with an AstValue object (from org.apache.el.parser), and this object has two children: AstIdentifier, which stores the string "AuctionBean", and AstDotSuffix, which stores the string "sortByTitle". Only one set of these objects is created per EL expression in a document. ICEfaces does the following. An HtmlCommandLink object, from the 'actionExpression field', references an instance of MethodExpressionMethodBindingAdapter (from javax.faces.component), whose sole job is to reference an instance of MethodBindingMethodExpressionAdapter (from com.sun.faces.application), which in turn references an instance of MethodExpressionImpl (from org.apache.el). This last object finally references the AstValue object mentioned above, but also has a String object with the value "#{AuctionBean.sortByTitle}". This is done for every client for every EL expression, and the string is not in constant pools and is not shared by other EL related objects, even if the value is the same. In facelets, things are different. For example, a`component object has a hash map called 'bindings'. The values of this hash map are TagValueExpression objects (from com.sun.facelets.el). These objects reference orig ValueExpressionImpl objects (from org.apache.el), as above. However, these ValueExpressionImpl objects reference the same string object when the EL expression is the same. |
Assignee | Deryk Sinotte [ deryk.sinotte ] |
Arturo Zambrano
made changes -
Attachment | el_strings_issue.JPG [ 11187 ] |
Arturo Zambrano
made changes -
Arturo Zambrano
made changes -
Summary | Memory: EL strings need to be pooled in JSP | Memory: EL strings need to be pooled/reused in JSP |
Deryk Sinotte
made changes -
Assignee | Deryk Sinotte [ deryk.sinotte ] | Arturo Zambrano [ artzambrano ] |
Ken Fyten
made changes -
Fix Version/s | 1.8DR#1 [ 10141 ] |
Arturo Zambrano
made changes -
Status | Open [ 1 ] | Resolved [ 5 ] |
Resolution | Fixed [ 1 ] |
Ken Fyten
made changes -
Fix Version/s | 1.8 [ 10161 ] |
Ken Fyten
made changes -
Security | Private [ 10001 ] |
Ken Fyten
made changes -
Status | Resolved [ 5 ] | Closed [ 6 ] |
Assignee | Arturo Zambrano [ artzambrano ] |