⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 entityperformancetest.jsp

📁 国外的一套开源CRM
💻 JSP
字号:
<%--
 *  Copyright (c) 2003 The Open For Business Project - www.ofbiz.org
 *
 *  Permission is hereby granted, free of charge, to any person obtaining a 
 *  copy of this software and associated documentation files (the "Software"), 
 *  to deal in the Software without restriction, including without limitation 
 *  the rights to use, copy, modify, merge, publish, distribute, sublicense, 
 *  and/or sell copies of the Software, and to permit persons to whom the 
 *  Software is furnished to do so, subject to the following conditions:
 *
 *  The above copyright notice and this permission notice shall be included 
 *  in all copies or substantial portions of the Software.
 *
 *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 
 *  OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 
 *  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 
 *  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 
 *  CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT 
 *  OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR 
 *  THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 *
 *@author     David E. Jones
 *@created    17 April 2003
 *@version    1.0
--%> 

<%@ page import="java.util.*, java.net.*" %>
<%@ page import="org.ofbiz.security.*, org.ofbiz.entity.*, org.ofbiz.base.util.*, org.ofbiz.content.webapp.pseudotag.*" %>

<%@ taglib uri="ofbizTags" prefix="ofbiz" %>

<jsp:useBean id="security" type="org.ofbiz.security.Security" scope="request" />
<jsp:useBean id="delegator" type="org.ofbiz.entity.GenericDelegator" scope="request" />

<div class="head1">Entity Engine Performance Tests</div>

<div class="tabletext">NOTE: These performance results may vary a great deal for different
databases, JDBC drivers, JTA implementations (transaction managers), connection pools, 
local vs. remote deployment configurations, and hardware (app server hardware, database 
server hardware, network connections).</div>

<br>

<%double startTime, totalTime, callsPerSecond;%>
<%int calls;%>
<table width="100%" border="1" cellspacing="0" cellpadding="2">
  <tr>
    <td><div class="tabletext"><b>Operation</b></div></td>
    <td><div class="tabletext"><b>Entity</b></div></td>
    <td><div class="tabletext"><b>Calls</b></div></td>
    <td><div class="tabletext"><b>Seconds</b></div></td>
    <td><div class="tabletext"><b>Seconds/Call</b></div></td>
    <td><div class="tabletext"><b>Calls/Second</b></div></td>
  </tr>
  <%
    calls = 1000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { GenericValue dummy = delegator.findByPrimaryKey("Product", UtilMisc.toMap("productId", "GZ-1000")); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">findByPrimaryKey</div></td>
    <td><div class="tabletext">Large:Product</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    calls = 10000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { GenericValue dummy = delegator.findByPrimaryKeyCache("Product", UtilMisc.toMap("productId", "GZ-1000")); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">findByPrimaryKeyCache</div></td>
    <td><div class="tabletext">Large:Product</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    calls = 1000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { GenericValue dummy = delegator.findByPrimaryKey("Party", UtilMisc.toMap("partyId", "_NA_")); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">findByPrimaryKey</div></td>
    <td><div class="tabletext">Small:Party</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    calls = 10000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { GenericValue dummy = delegator.findByPrimaryKeyCache("Party", UtilMisc.toMap("partyId", "_NA_")); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">findByPrimaryKeyCache</div></td>
    <td><div class="tabletext">Small:Party</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
  	List createTestList = new ArrayList();
    calls = 1000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { 
        GenericValue dummy = delegator.makeValue("Product", UtilMisc.toMap("autoCreateKeywords", "N", "description", "Initial Description", "internalName", "Auto-Test Name", "productId", "_~WRITE_TEST~_" + i)); 
        createTestList.add(dummy); 
        delegator.create(dummy);
    }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">create</div></td>
    <td><div class="tabletext">Large:Product</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>  
  <%
    calls = 1000; startTime = (double) System.currentTimeMillis();    
    for (int i=0; i < calls; i++) { 
        GenericValue dummy = (GenericValue) createTestList.get(i); 
        dummy.set("description", "This was a test from the performace JSP");
        dummy.store();
    }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">update</div></td>
    <td><div class="tabletext">Large:Product</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>    
  <%
    calls = 1000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { 
        GenericValue dummy = (GenericValue) createTestList.get(i); 
        dummy.remove();
    }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">remove</div></td>
    <td><div class="tabletext">Large:Product</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>      
  <%
    calls = 100000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { Map ptyMap = new HashMap(); ptyMap.put("partyId", "_NA_"); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">new HashMap</div></td>
    <td><div class="tabletext">N/A</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    calls = 100000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { Map ptyMap = UtilMisc.toMap("partyId", "_NA_"); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">UtilMisc.toMap</div></td>
    <td><div class="tabletext">N/A</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    UtilCache utilCache = new UtilCache("test-cache", 0,0, false);
    utilCache.put("testName", "testValue");
    calls = 1000000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { utilCache.get("testName"); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">UtilCache.get(String) - basic settings</div></td>
    <td><div class="tabletext">N/A</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    GenericPK testPk = delegator.makePK("Party", UtilMisc.toMap("partyId", "_NA_"));
    utilCache.put(testPk, "testValue");
    calls = 1000000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { utilCache.get(testPk); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">UtilCache.get(GenericPK) - basic settings</div></td>
    <td><div class="tabletext">N/A</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
  <%
    calls = 1000000; startTime = (double) System.currentTimeMillis();
    for (int i=0; i < calls; i++) { utilCache.put(testPk, "testValue"); }
    totalTime = (double) System.currentTimeMillis() - startTime;
    callsPerSecond = (double) calls / (totalTime/1000);
  %>
  <tr>
    <td><div class="tabletext">UtilCache.put(GenericPK) - basic settings</div></td>
    <td><div class="tabletext">N/A</div></td>
    <td><div class="tabletext"><%=calls%></div></td>
    <td><div class="tabletext"><%=totalTime/1000%></div></td>
    <td><div class="tabletext"><%=1/callsPerSecond%></div></td>
    <td><div class="tabletext"><%=callsPerSecond%></div></td>
  </tr>
</table>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -