<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title></title>
</head>
<body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; color: rgb(0, 0, 0); font-size: 14px; font-family: Calibri, sans-serif;">
<div>While investigating overall performance aspects on our production environment we found out a few things about MitreID:</div>
<ol>
<li>We recommend the following indexes to be added (at least for MySQL):
<ol>
<li>CREATE INDEX token_value_idx ON access_token(token_value(767));</li><li>CREATE INDEX owner_id_idx ON token_scope(owner_id);</li><li>CREATE INDEX expiration_idx ON access_token(expiration);</li><li>CREATE INDEX auth_holder_id1_idx ON refresh_token(auth_holder_id);</li></ol>
</li><li>RSASSASigner.sign is using quite a bit of CPU power. Just an observation, not sure if anything can be done. Using RSA 2048 key.</li></ol>
<div>The indexes themselves may improve performance by 10&#43;%. See attached output from JMeter (<a href="http://jmeter.apache.org/usermanual/component_reference.html#Aggregate_Report">http://jmeter.apache.org/usermanual/component_reference.html#Aggregate_Report</a>).
 Interesting that there is a high latency (1200&#43; ms) per call but the also high throughput (79 req/sec). I guess that&#8217;s why we have Queue Theory in CS, eh? :)</div>
<div><br>
</div>
<div>We can maybe make those changes in Github however won&#8217;t be able to test all options, e.g. PostgreSQL. Note that there is a limitation in MySQL where it doesn&#8217;t handle index on large columns. As configured on my system, the max column length is 767 for
 indexes.</div>
<div><br>
</div>
<div>We are using JMeter to create 100 requests/sec, repeated 50 times, running version 1.1.16 connected to MySQL, MySQL Enterprise Monitor for SQL analysis, and JVisualVM to profile the application. All components are running on my development (MacOS) system.
 The requests are using the Resource Owner flow.</div>
<div><br>
</div>
<div>By the way MitreID doesn&#8217;t appear to be the source of our main performance concerns.</div>
<div><br>
</div>
<div>Regards,</div>
<div>Luiz&nbsp;</div>
</body>
</html>