blob: a250922cbae5a135c87ec0ff691ce8473786e3bd [file] [log] [blame]
<!doctype html>
<html lang="cn" class="no-js">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta name="generator" content="Hugo 0.95.0" />
<link rel="canonical" type="text/html" href="/cn/docs/performance/api-preformance/">
<link rel="alternate" type="application/rss&#43;xml" href="/cn/docs/performance/api-preformance/index.xml">
<meta name="robots" content="noindex, nofollow">
<link rel="shortcut icon" href="/favicons/favicon.ico" >
<link rel="apple-touch-icon" href="/favicons/apple-touch-icon-180x180.png" sizes="180x180">
<link rel="icon" type="image/png" href="/favicons/favicon-16x16.png" sizes="16x16">
<link rel="icon" type="image/png" href="/favicons/favicon-32x32.png" sizes="32x32">
<link rel="icon" type="image/png" href="/favicons/android-36x36.png" sizes="36x36">
<link rel="icon" type="image/png" href="/favicons/android-48x48.png" sizes="48x48">
<link rel="icon" type="image/png" href="/favicons/android-72x72.png" sizes="72x72">
<link rel="icon" type="image/png" href="/favicons/android-96x96.png" sizes="96x96">
<link rel="icon" type="image/png" href="/favicons/android-144x144.png" sizes="144x144">
<link rel="icon" type="image/png" href="/favicons/android-192x192.png" sizes="192x192">
<title>HugeGraph-API Performance | HugeGraph</title>
<meta name="description" content="HugeGraph API性能测试主要测试HugeGraph-Server对RESTful API请求的并发处理能力,包括:
顶点/边的单条插入
顶点/边的批量插入
顶点/边的查询
HugeGraph的每个发布版本的RESTful API的性能测试情况可以参考:
v0.5.6 …">
<meta property="og:title" content="HugeGraph-API Performance" />
<meta property="og:description" content="Apache HugeGraph 官网" />
<meta property="og:type" content="website" />
<meta property="og:url" content="/cn/docs/performance/api-preformance/" /><meta property="og:site_name" content="HugeGraph" />
<meta itemprop="name" content="HugeGraph-API Performance">
<meta itemprop="description" content="Apache HugeGraph 官网"><meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="HugeGraph-API Performance"/>
<meta name="twitter:description" content="Apache HugeGraph 官网"/>
<link rel="preload" href="/scss/main.min.0dc89c707c94a8edbf7722b8ffab87c78b14c4c3e2532e1f45bd6d12c3ccf83b.css" as="style">
<link href="/scss/main.min.0dc89c707c94a8edbf7722b8ffab87c78b14c4c3e2532e1f45bd6d12c3ccf83b.css" rel="stylesheet" integrity="">
<script
src="https://code.jquery.com/jquery-3.5.1.min.js"
integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0="
crossorigin="anonymous"></script>
<link rel="stylesheet" href="/css/prism.css"/>
<script type="application/javascript">
var doNotTrack = false;
if (!doNotTrack) {
window.ga=window.ga||function(){(ga.q=ga.q||[]).push(arguments)};ga.l=+new Date;
ga('create', 'UA-00000000-0', 'auto');
ga('send', 'pageview');
}
</script>
<script async src='https://www.google-analytics.com/analytics.js'></script>
</head>
<body class="td-section">
<header>
<nav class="js-navbar-scroll navbar navbar-expand navbar-dark flex-column flex-md-row td-navbar">
<a class="navbar-brand" href="/cn/">
<span class="navbar-logo"><svg id="图层_1" data-name="图层 1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 16 16"><defs><style>.cls-1{fill:none;stroke:#fff;stroke-miterlimit:10;stroke-width:.5px;opacity:.3}.cls-2{fill:#229efa}.cls-3{fill:#9948f7}.cls-4{fill:#33bc7a}.cls-5{fill:url(#未命名的渐变_3)}.cls-6{fill:url(#未命名的渐变_13)}.cls-7{fill:url(#未命名的渐变_11)}</style><linearGradient id="未命名的渐变_3" x1="6.16" y1="14.63" x2="6.16" y2="6.01" gradientUnits="userSpaceOnUse"><stop offset="0" stop-color="#2e3192"/><stop offset="0" stop-color="#229efa"/><stop offset=".44" stop-color="#239cf8"/><stop offset=".6" stop-color="#2795f2"/><stop offset=".71" stop-color="#2d8ae8"/><stop offset=".81" stop-color="#3679d9"/><stop offset=".89" stop-color="#4263c6"/><stop offset=".95" stop-color="#5048af"/><stop offset="1" stop-color="#5c319b"/></linearGradient><linearGradient id="未命名的渐变_13" x1="10.75" y1="8.2" x2="4.49" y2="1.94" gradientUnits="userSpaceOnUse"><stop offset="0" stop-color="#991146"/><stop offset="0" stop-color="#326b4e"/><stop offset=".02" stop-color="#3a685c"/><stop offset=".07" stop-color="#506180"/><stop offset=".13" stop-color="#645aa0"/><stop offset=".19" stop-color="#7554bc"/><stop offset=".26" stop-color="#8250d2"/><stop offset=".35" stop-color="#8d4ce3"/><stop offset=".45" stop-color="#944aee"/><stop offset=".6" stop-color="#9848f5"/><stop offset="1" stop-color="#9948f7"/></linearGradient><linearGradient id="未命名的渐变_11" x1="15.34" y1="6.67" x2="7.88" y2="10.98" gradientUnits="userSpaceOnUse"><stop offset="0" stop-color="#33bc7a"/><stop offset=".45" stop-color="#32ba7a"/><stop offset=".61" stop-color="#2fb37c"/><stop offset=".73" stop-color="#29a87e"/><stop offset=".82" stop-color="#219782"/><stop offset=".9" stop-color="#168186"/><stop offset=".97" stop-color="#09668b"/><stop offset="1" stop-color="#03598e"/></linearGradient></defs><title>logo</title><rect class="cls-1" x="-143.14" y="-373.46" width="597.8" height="424.44"/><circle class="cls-2" cx="12.02" cy="1.83" r="1.33"/><circle class="cls-3" cx="12.02" cy="14.17" r="1.33"/><circle class="cls-4" cx="1.33" cy="8" r="1.33"/><path class="cls-5" d="M7.91 10h0a2.65 2.65.0 01-.23-3.74A1.75 1.75.0 017.91 6h0A2.66 2.66.0 014.4 6h0a1.81 1.81.0 01.24.24A2.65 2.65.0 014.4 10h0a2.62 2.62.0 00-.89 2 2.65 2.65.0 104.4-2z"/><path class="cls-6" d="M12.19 5.49a2.78 2.78.0 01-.5.11A2.64 2.64.0 018.76 3.5h0a2.65 2.65.0 10-2.6 3.17A2.6 2.6.0 007 6.53H7a2.65 2.65.0 013.44 2 2.94 2.94.0 010-.51 2.65 2.65.0 011.75-2.53z"/><path class="cls-7" d="M13 5.35a2.64 2.64.0 00-2.59 2.12h0a3 3 0 01-.08.32A2.65 2.65.0 017.54 9.58a2.86 2.86.0 00.37.41h0a2.63 2.63.0 01.9 2 2.84 2.84.0 01-.05.51 2.64 2.64.0 013.12-2.06l.32.08h0a2.6 2.6.0 00.84.14 2.65 2.65.0 100-5.3z"/></svg></span><span class="font-weight-bold">HugeGraph</span>
</a>
<div class="td-navbar-nav-scroll ml-md-auto" id="main_navbar">
<ul class="navbar-nav mt-2 mt-lg-0">
<li class="nav-item mr-4 mb-2 mb-lg-0">
<a class="nav-link" href="/cn/docs/" ><i class='fas fa-book pr-2'></i><span>Documentation</span></a>
</li>
<li class="nav-item mr-4 mb-2 mb-lg-0">
<a class="nav-link" href="https://github.com/apache/incubator-hugegraph" target="_blank" ><i class='fab fa-github pr-2'></i><span>GitHub</span></a>
</li>
<li class="nav-item mr-4 mb-2 mb-lg-0">
<a class="nav-link" href="/cn/community/" ><span>Community</span></a>
</li>
<li class="nav-item dropdown mr-4 d-none d-lg-block">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
中文
</a>
<div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
<a class="dropdown-item" href="/docs/performance/api-preformance/">English</a>
</div>
</li>
</ul>
</div>
<div class="navbar-nav d-none d-lg-block"></div>
</nav>
</header>
<div class="container-fluid td-outer">
<div class="td-main">
<div class="row flex-xl-nowrap">
<main class="col-12 col-md-9 col-xl-8 pl-md-5" role="main">
<div class="td-content">
<div class="pageinfo pageinfo-primary d-print-none">
<p>
This is the multi-page printable view of this section.
<a href="#" onclick="print();return false;">Click here to print</a>.
</p><p>
<a href="/cn/docs/performance/api-preformance/">Return to the regular view of this page</a>.
</p>
</div>
<h1 class="title">HugeGraph-API Performance</h1>
<ul>
<li>1: <a href="#pg-dbfafc29a5e930415f78f72c47ee67f2">v0.5.6 Stand-alone(RocksDB)</a></li>
<li>2: <a href="#pg-fd5b165e28a07f1c35ab177b10e15dc8">v0.5.6 Cluster(Cassandra)</a></li>
<li>3: <a href="#pg-0005aca20e30ef2795411939ccbf0fd9">v0.4.4</a></li>
<li>4: <a href="#pg-d4233a3feb070643ef5d54a6f9c12cab">v0.2</a></li>
</ul>
<div class="content">
<p>HugeGraph API性能测试主要测试HugeGraph-Server对RESTful API请求的并发处理能力,包括:</p>
<ul>
<li>顶点/边的单条插入</li>
<li>顶点/边的批量插入</li>
<li>顶点/边的查询</li>
</ul>
<p>HugeGraph的每个发布版本的RESTful API的性能测试情况可以参考:</p>
<ul>
<li><a href="/docs/performance/api-preformance/hugegraph-api-0.5.6-rocksdb/">v0.5.6 stand-alone</a></li>
<li><a href="/docs/performance/api-preformance/hugegraph-api-0.5.6-cassandra/">v0.5.6 cluster</a></li>
<li><a href="/docs/performance/api-preformance/hugegraph-api-0.4.4/">v0.4.4</a></li>
<li><a href="/docs/performance/api-preformance/hugegraph-api-0.2/">v0.2</a></li>
</ul>
<blockquote>
<p>之前的版本只提供HugeGraph所支持的后端种类中性能最好的API性能测试,从0.5.6版本开始,分别提供了单机和集群的性能情况</p>
</blockquote>
</div>
</div>
<div class="td-content" style="page-break-before: always">
<h1 id="pg-dbfafc29a5e930415f78f72c47ee67f2">1 - v0.5.6 Stand-alone(RocksDB)</h1>
<h3 id="1-测试环境">1 测试环境</h3>
<p>被压机器信息</p>
<table>
<thead>
<tr>
<th>CPU</th>
<th>Memory</th>
<th>网卡</th>
<th>磁盘</th>
</tr>
</thead>
<tbody>
<tr>
<td>48 Intel(R) Xeon(R) CPU E5-2650 v4 @ 2.20GHz</td>
<td>128G</td>
<td>10000Mbps</td>
<td>750GB SSD,2.7T HDD</td>
</tr>
</tbody>
</table>
<ul>
<li>起压力机器信息:与被压机器同配置</li>
<li>测试工具:apache-Jmeter-2.5.1</li>
</ul>
<p>注:起压机器和被压机器在同一机房</p>
<h3 id="2-测试说明">2 测试说明</h3>
<h4 id="21-名词定义时间的单位均为ms">2.1 名词定义(时间的单位均为ms)</h4>
<ul>
<li>Samples &ndash; 本次场景中一共完成了多少个线程</li>
<li>Average &ndash; 平均响应时间</li>
<li>Median &ndash; 统计意义上面的响应时间的中值</li>
<li>90% Line &ndash; 所有线程中90%的线程的响应时间都小于xx</li>
<li>Min &ndash; 最小响应时间</li>
<li>Max &ndash; 最大响应时间</li>
<li>Error &ndash; 出错率</li>
<li>Throughput &ndash; 吞吐量</li>
<li>KB/sec &ndash; 以流量做衡量的吞吐量</li>
</ul>
<h4 id="22-底层存储">2.2 底层存储</h4>
<p>后端存储使用RocksDB,HugeGraph与RocksDB都在同一机器上启动,server相关的配置文件除主机和端口有修改外,其余均保持默认。</p>
<h3 id="3-性能结果总结">3 性能结果总结</h3>
<ol>
<li>HugeGraph单条插入顶点和边的速度在每秒1w左右</li>
<li>顶点和边的批量插入速度远大于单条插入速度</li>
<li>按id查询顶点和边的并发度可达到13000以上,且请求的平均延时小于50ms</li>
</ol>
<h3 id="4-测试结果及分析">4 测试结果及分析</h3>
<h4 id="41-batch插入">4.1 batch插入</h4>
<h5 id="411-压力上限测试">4.1.1 压力上限测试</h5>
<h6 id="测试方法">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数">压力参数</h6>
<p>持续时间:5min</p>
<h6 id="顶点的最大插入速度">顶点的最大插入速度:</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/rocksdb/vertex_batch.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发2200,顶点的吞吐量是2026.8,每秒可处理的数据:2026.8*200=405360/s</li>
</ul>
<h6 id="边的最大插入速度">边的最大插入速度</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/rocksdb/edge_batch.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发900,边的吞吐量是776.9,每秒可处理的数据:776.9*500=388450/s</li>
</ul>
<h4 id="42-single插入">4.2 single插入</h4>
<h5 id="421-压力上限测试">4.2.1 压力上限测试</h5>
<h6 id="测试方法-1">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数-1">压力参数</h6>
<ul>
<li>持续时间:5min</li>
<li>服务异常标志:错误率大于0.00%</li>
</ul>
<h6 id="顶点的单条插入">顶点的单条插入</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/rocksdb/vertex_single.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发11500,吞吐量为10730,顶点的单条插入并发能力为11500</li>
</ul>
<h6 id="边的单条插入">边的单条插入</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/rocksdb/edge_single.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发9000,吞吐量是8418,边的单条插入并发能力为9000</li>
</ul>
<h4 id="43-按id查询">4.3 按id查询</h4>
<h5 id="431-压力上限测试">4.3.1 压力上限测试</h5>
<h6 id="测试方法-2">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数-2">压力参数</h6>
<ul>
<li>持续时间:5min</li>
<li>服务异常标志:错误率大于0.00%</li>
</ul>
<h6 id="顶点的按id查询">顶点的按id查询</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/rocksdb/vertex_id_query.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发14000,吞吐量是12663,顶点的按id查询的并发能力为14000,平均延时为44ms</li>
</ul>
<h6 id="边的按id查询">边的按id查询</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/rocksdb/edge_id_query.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发13000,吞吐量是12225,边的按id查询的并发能力为13000,平均延时为12ms</li>
</ul>
</div>
<div class="td-content" style="page-break-before: always">
<h1 id="pg-fd5b165e28a07f1c35ab177b10e15dc8">2 - v0.5.6 Cluster(Cassandra)</h1>
<h3 id="1-测试环境">1 测试环境</h3>
<p>被压机器信息</p>
<table>
<thead>
<tr>
<th>CPU</th>
<th>Memory</th>
<th>网卡</th>
<th>磁盘</th>
</tr>
</thead>
<tbody>
<tr>
<td>48 Intel(R) Xeon(R) CPU E5-2650 v4 @ 2.20GHz</td>
<td>128G</td>
<td>10000Mbps</td>
<td>750GB SSD,2.7T HDD</td>
</tr>
</tbody>
</table>
<ul>
<li>起压力机器信息:与被压机器同配置</li>
<li>测试工具:apache-Jmeter-2.5.1</li>
</ul>
<p>注:起压机器和被压机器在同一机房</p>
<h3 id="2-测试说明">2 测试说明</h3>
<h4 id="21-名词定义时间的单位均为ms">2.1 名词定义(时间的单位均为ms)</h4>
<ul>
<li>Samples &ndash; 本次场景中一共完成了多少个线程</li>
<li>Average &ndash; 平均响应时间</li>
<li>Median &ndash; 统计意义上面的响应时间的中值</li>
<li>90% Line &ndash; 所有线程中90%的线程的响应时间都小于xx</li>
<li>Min &ndash; 最小响应时间</li>
<li>Max &ndash; 最大响应时间</li>
<li>Error &ndash; 出错率</li>
<li>Throughput &ndash; 吞吐量</li>
<li>KB/sec &ndash; 以流量做衡量的吞吐量</li>
</ul>
<h4 id="22-底层存储">2.2 底层存储</h4>
<p>后端存储使用15节点Cassandra集群,HugeGraph与Cassandra集群位于不同的服务器,server相关的配置文件除主机和端口有修改外,其余均保持默认。</p>
<h3 id="3-性能结果总结">3 性能结果总结</h3>
<ol>
<li>HugeGraph单条插入顶点和边的速度分别为9000和4500</li>
<li>顶点和边的批量插入速度分别为5w/s和15w/s,远大于单条插入速度</li>
<li>按id查询顶点和边的并发度可达到12000以上,且请求的平均延时小于70ms</li>
</ol>
<h3 id="4-测试结果及分析">4 测试结果及分析</h3>
<h4 id="41-batch插入">4.1 batch插入</h4>
<h5 id="411-压力上限测试">4.1.1 压力上限测试</h5>
<h6 id="测试方法">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数">压力参数</h6>
<p>持续时间:5min</p>
<h6 id="顶点的最大插入速度">顶点的最大插入速度:</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/cassandra/vertex_batch.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发3500,顶点的吞吐量是261,每秒可处理的数据:261*200=52200/s</li>
</ul>
<h6 id="边的最大插入速度">边的最大插入速度</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/cassandra/edge_batch.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发1000,边的吞吐量是323,每秒可处理的数据:323*500=161500/s</li>
</ul>
<h4 id="42-single插入">4.2 single插入</h4>
<h5 id="421-压力上限测试">4.2.1 压力上限测试</h5>
<h6 id="测试方法-1">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数-1">压力参数</h6>
<ul>
<li>持续时间:5min</li>
<li>服务异常标志:错误率大于0.00%</li>
</ul>
<h6 id="顶点的单条插入">顶点的单条插入</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/cassandra/vertex_single.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发9000,吞吐量为8400,顶点的单条插入并发能力为9000</li>
</ul>
<h6 id="边的单条插入">边的单条插入</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/cassandra/edge_single.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发4500,吞吐量是4160,边的单条插入并发能力为4500</li>
</ul>
<h4 id="43-按id查询">4.3 按id查询</h4>
<h5 id="431-压力上限测试">4.3.1 压力上限测试</h5>
<h6 id="测试方法-2">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数-2">压力参数</h6>
<ul>
<li>持续时间:5min</li>
<li>服务异常标志:错误率大于0.00%</li>
</ul>
<h6 id="顶点的按id查询">顶点的按id查询</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/cassandra/vertex_id_query.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发14500,吞吐量是13576,顶点的按id查询的并发能力为14500,平均延时为11ms</li>
</ul>
<h6 id="边的按id查询">边的按id查询</h6>
<center>
<img src="/docs/images/API-perf/v0.5.6/cassandra/edge_id_query.png" alt="image">
</center>
<p>####### 结论:</p>
<ul>
<li>并发12000,吞吐量是10688,边的按id查询的并发能力为12000,平均延时为63ms</li>
</ul>
</div>
<div class="td-content" style="page-break-before: always">
<h1 id="pg-0005aca20e30ef2795411939ccbf0fd9">3 - v0.4.4</h1>
<h3 id="1-测试环境">1 测试环境</h3>
<p>被压机器信息</p>
<table>
<thead>
<tr>
<th>机器编号</th>
<th>CPU</th>
<th>Memory</th>
<th>网卡</th>
<th>磁盘</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>24 Intel(R) Xeon(R) CPU E5-2620 v2 @ 2.10GHz</td>
<td>61G</td>
<td>1000Mbps</td>
<td>1.4T HDD</td>
</tr>
<tr>
<td>2</td>
<td>48 Intel(R) Xeon(R) CPU E5-2650 v4 @ 2.20GHz</td>
<td>128G</td>
<td>10000Mbps</td>
<td>750GB SSD,2.7T HDD</td>
</tr>
</tbody>
</table>
<ul>
<li>起压力机器信息:与编号 1 机器同配置</li>
<li>测试工具:apache-Jmeter-2.5.1</li>
</ul>
<p>注:起压机器和被压机器在同一机房</p>
<h3 id="2-测试说明">2 测试说明</h3>
<h4 id="21-名词定义时间的单位均为ms">2.1 名词定义(时间的单位均为ms)</h4>
<ul>
<li>Samples &ndash; 本次场景中一共完成了多少个线程</li>
<li>Average &ndash; 平均响应时间</li>
<li>Median &ndash; 统计意义上面的响应时间的中值</li>
<li>90% Line &ndash; 所有线程中90%的线程的响应时间都小于xx</li>
<li>Min &ndash; 最小响应时间</li>
<li>Max &ndash; 最大响应时间</li>
<li>Error &ndash; 出错率</li>
<li>Throughput &ndash; 吞吐量</li>
<li>KB/sec &ndash; 以流量做衡量的吞吐量</li>
</ul>
<h4 id="22-底层存储">2.2 底层存储</h4>
<p>后端存储使用RocksDB,HugeGraph与RocksDB都在同一机器上启动,server相关的配置文件除主机和端口有修改外,其余均保持默认。</p>
<h3 id="3-性能结果总结">3 性能结果总结</h3>
<ol>
<li>HugeGraph每秒能够处理的请求数目上限是7000</li>
<li>批量插入速度远大于单条插入,在服务器上测试结果达到22w edges/s,37w vertices/s</li>
<li>后端是RocksDB,增大CPU数目和内存大小可以增大批量插入的性能。CPU和内存扩大一倍,性能增加45%-60%</li>
<li>批量插入场景,使用SSD替代HDD,性能提升较小,只有3%-5%</li>
</ol>
<h3 id="4-测试结果及分析">4 测试结果及分析</h3>
<h4 id="41-batch插入">4.1 batch插入</h4>
<h5 id="411-压力上限测试">4.1.1 压力上限测试</h5>
<h6 id="测试方法">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数">压力参数</h6>
<p>持续时间:5min</p>
<h6 id="顶点和边的最大插入速度高性能服务器使用ssd存储rocksdb数据">顶点和边的最大插入速度(高性能服务器,使用SSD存储RocksDB数据):</h6>
<center>
<img src="/docs/images/API-perf/v0.4.4/best.png" alt="image">
</center>
<h6 id="结论">结论:</h6>
<ul>
<li>并发1000,边的吞吐量是是451,每秒可处理的数据:451*500条=225500/s</li>
<li>并发2000,顶点的吞吐量是1842.4,每秒可处理的数据:1842.4*200=368480/s</li>
</ul>
<p><strong>1. CPU和内存对插入性能的影响(服务器都使用HDD存储RocksDB数据,批量插入)</strong></p>
<center>
<img src="/docs/images/API-perf/v0.4.4/cpu-memory.png" alt="image">
</center>
<h6 id="结论-1">结论:</h6>
<ul>
<li>同样使用HDD硬盘,CPU和内存增加了1倍</li>
<li>边:吞吐量从268提升至426,性能提升了约60%</li>
<li>顶点:吞吐量从1263.8提升至1842.4,性能提升了约45%</li>
</ul>
<p><strong>2. SSD和HDD对插入性能的影响(高性能服务器,批量插入)</strong></p>
<center>
<img src="/docs/images/API-perf/v0.4.4/ssd.png" alt="image">
</center>
<h6 id="结论-2">结论:</h6>
<ul>
<li>边:使用SSD吞吐量451.7,使用HDD吞吐量426.6,性能提升5%</li>
<li>顶点:使用SSD吞吐量1842.4,使用HDD吞吐量1794,性能提升约3%</li>
</ul>
<p><strong>3. 不同并发线程数对插入性能的影响(普通服务器,使用HDD存储RocksDB数据)</strong></p>
<center>
<img src="/docs/images/API-perf/v0.4.4/threads-batch.png" alt="image">
</center>
<h6 id="结论-3">结论:</h6>
<ul>
<li>顶点:1000并发,响应时间7ms和1500并发响应时间1028ms差距悬殊,且吞吐量一直保持在1300左右,因此拐点数据应该在1300 ,且并发1300时,响应时间已达到22ms,在可控范围内,相比HugeGraph 0.2(1000并发:平均响应时间8959ms),处理能力出现质的飞跃;</li>
<li>边:从1000并发到2000并发,处理时间过长,超过3s,且吞吐量几乎在270左右浮动,因此继续增大并发线程数吞吐量不会再大幅增长,270 是一个拐点,跟HugeGraph 0.2版本(1000并发:平均响应时间31849ms)相比较,处理能力提升非常明显;</li>
</ul>
<h4 id="42-single插入">4.2 single插入</h4>
<h5 id="421-压力上限测试">4.2.1 压力上限测试</h5>
<h6 id="测试方法-1">测试方法</h6>
<p>不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数-1">压力参数</h6>
<ul>
<li>持续时间:5min</li>
<li>服务异常标志:错误率大于0.00%</li>
</ul>
<center>
<img src="/docs/images/API-perf/v0.4.4/threads-single.png" alt="image">
</center>
<h6 id="结论-4">结论:</h6>
<ul>
<li>顶点:
<ul>
<li>4000并发:正常,无错误率,平均耗时小于1ms, 6000并发无错误,平均耗时5ms,在可接受范围内;</li>
<li>8000并发:存在0.01%的错误,已经无法处理,出现connection timeout错误,顶峰应该在7000左右</li>
</ul>
</li>
<li>边:
<ul>
<li>4000并发:响应时间1ms,6000并发无任何异常,平均响应时间8ms,主要差异在于 IO network recv和send以及CPU);</li>
<li>8000并发:存在0.01%的错误率,平均耗15ms,拐点应该在7000左右,跟顶点结果匹配;</li>
</ul>
</li>
</ul>
</div>
<div class="td-content" style="page-break-before: always">
<h1 id="pg-d4233a3feb070643ef5d54a6f9c12cab">4 - v0.2</h1>
<h3 id="1-测试环境">1 测试环境</h3>
<h4 id="11-软硬件信息">1.1 软硬件信息</h4>
<p>起压和被压机器配置相同,基本参数如下:</p>
<table>
<thead>
<tr>
<th>CPU</th>
<th>Memory</th>
<th>网卡</th>
</tr>
</thead>
<tbody>
<tr>
<td>24 Intel(R) Xeon(R) CPU E5-2620 v2 @ 2.10GHz</td>
<td>61G</td>
<td>1000Mbps</td>
</tr>
</tbody>
</table>
<p>测试工具:apache-Jmeter-2.5.1</p>
<h4 id="12-服务配置">1.2 服务配置</h4>
<ul>
<li>HugeGraph版本:0.2</li>
<li>后端存储:使用服务内嵌的cassandra-3.10,单点部署;</li>
<li>后端配置修改:修改了cassandra.yaml文件中的以下两个属性,其余选项均保持默认</li>
</ul>
<pre tabindex="0"><code> batch_size_warn_threshold_in_kb: 1000
batch_size_fail_threshold_in_kb: 1000
</code></pre><ul>
<li>HugeGraphServer 与 HugeGremlinServer 与cassandra都在同一机器上启动,server 相关的配置文件除主机和端口有修改外,其余均保持默认。</li>
</ul>
<h4 id="13-名词解释">1.3 名词解释</h4>
<ul>
<li>Samples &ndash; 本次场景中一共完成了多少个线程</li>
<li>Average &ndash; 平均响应时间</li>
<li>Median &ndash; 统计意义上面的响应时间的中值</li>
<li>90% Line &ndash; 所有线程中90%的线程的响应时间都小于xx</li>
<li>Min &ndash; 最小响应时间</li>
<li>Max &ndash; 最大响应时间</li>
<li>Error &ndash; 出错率</li>
<li>Troughput &ndash; 吞吐量Â</li>
<li>KB/sec &ndash; 以流量做衡量的吞吐量</li>
</ul>
<p><em>注:时间的单位均为ms</em></p>
<h3 id="2-测试结果">2 测试结果</h3>
<h4 id="21-schema">2.1 schema</h4>
<table>
<thead>
<tr>
<th>Label</th>
<th>Samples</th>
<th>Average</th>
<th>Median</th>
<th>90%Line</th>
<th>Min</th>
<th>Max</th>
<th>Error%</th>
<th>Throughput</th>
<th>KB/sec</th>
</tr>
</thead>
<tbody>
<tr>
<td>property_keys</td>
<td>331000</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>0</td>
<td>172</td>
<td>0.00%</td>
<td>920.7/sec</td>
<td>178.1</td>
</tr>
<tr>
<td>vertex_labels</td>
<td>331000</td>
<td>1</td>
<td>2</td>
<td>2</td>
<td>1</td>
<td>126</td>
<td>0.00%</td>
<td>920.7/sec</td>
<td>193.4</td>
</tr>
<tr>
<td>edge_labels</td>
<td>331000</td>
<td>2</td>
<td>2</td>
<td>3</td>
<td>1</td>
<td>158</td>
<td>0.00%</td>
<td>920.7/sec</td>
<td>242.8</td>
</tr>
</tbody>
</table>
<p>结论:schema的接口,在1000并发持续5分钟的压力下,平均响应时间1-2ms,无压力</p>
<h4 id="22-single-插入">2.2 single 插入</h4>
<h5 id="221-插入速率测试">2.2.1 插入速率测试</h5>
<h6 id="压力参数">压力参数</h6>
<p>测试方法:固定并发量,测试server和后端的处理速率</p>
<ul>
<li>并发量:1000</li>
<li>持续时间:5min</li>
</ul>
<h6 id="性能指标">性能指标</h6>
<table>
<thead>
<tr>
<th>Label</th>
<th>Samples</th>
<th>Average</th>
<th>Median</th>
<th>90%Line</th>
<th>Min</th>
<th>Max</th>
<th>Error%</th>
<th>Throughput</th>
<th>KB/sec</th>
</tr>
</thead>
<tbody>
<tr>
<td>single_insert_vertices</td>
<td>331000</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>21</td>
<td>0.00%</td>
<td>920.7/sec</td>
<td>234.4</td>
</tr>
<tr>
<td>single_insert_edges</td>
<td>331000</td>
<td>2</td>
<td>2</td>
<td>3</td>
<td>1</td>
<td>53</td>
<td>0.00%</td>
<td>920.7/sec</td>
<td>309.1</td>
</tr>
</tbody>
</table>
<h6 id="结论">结论</h6>
<ul>
<li>顶点:平均响应时间1ms,每个请求插入一条数据,平均每秒处理920个请求,则每秒平均总共处理的数据为1*920约等于920条数据;</li>
<li>边:平均响应时间1ms,每个请求插入一条数据,平均每秒处理920个请求,则每秒平均总共处理的数据为1*920约等于920条数据;</li>
</ul>
<h5 id="222-压力上限测试">2.2.2 压力上限测试</h5>
<p>测试方法:不断提升并发量,测试server仍能正常提供服务的压力上限</p>
<h6 id="压力参数-1">压力参数</h6>
<ul>
<li>持续时间:5min</li>
<li>服务异常标志:错误率大于0.00%</li>
</ul>
<h6 id="性能指标-1">性能指标</h6>
<table>
<thead>
<tr>
<th>Concurrency</th>
<th>Samples</th>
<th>Average</th>
<th>Median</th>
<th>90%Line</th>
<th>Min</th>
<th>Max</th>
<th>Error%</th>
<th>Throughput</th>
<th>KB/sec</th>
</tr>
</thead>
<tbody>
<tr>
<td>2000(vertex)</td>
<td>661916</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>3012</td>
<td>0.00%</td>
<td>1842.9/sec</td>
<td>469.1</td>
</tr>
<tr>
<td>4000(vertex)</td>
<td>1316124</td>
<td>13</td>
<td>1</td>
<td>14</td>
<td>0</td>
<td>9023</td>
<td>0.00%</td>
<td>3673.1/sec</td>
<td>935.0</td>
</tr>
<tr>
<td>5000(vertex)</td>
<td>1468121</td>
<td>1010</td>
<td>1135</td>
<td>1227</td>
<td>0</td>
<td>9223</td>
<td>0.06%</td>
<td>4095.6/sec</td>
<td>1046.0</td>
</tr>
<tr>
<td>7000(vertex)</td>
<td>1378454</td>
<td>1617</td>
<td>1708</td>
<td>1886</td>
<td>0</td>
<td>9361</td>
<td>0.08%</td>
<td>3860.3/sec</td>
<td>987.1</td>
</tr>
<tr>
<td>2000(edge)</td>
<td>629399</td>
<td>953</td>
<td>1043</td>
<td>1113</td>
<td>1</td>
<td>9001</td>
<td>0.00%</td>
<td>1750.3/sec</td>
<td>587.6</td>
</tr>
<tr>
<td>3000(edge)</td>
<td>648364</td>
<td>2258</td>
<td>2404</td>
<td>2500</td>
<td>2</td>
<td>9001</td>
<td>0.00%</td>
<td>1810.7/sec</td>
<td>607.9</td>
</tr>
<tr>
<td>4000(edge)</td>
<td>649904</td>
<td>1992</td>
<td>2112</td>
<td>2211</td>
<td>1</td>
<td>9001</td>
<td>0.06%</td>
<td>1812.5/sec</td>
<td>608.5</td>
</tr>
</tbody>
</table>
<h6 id="结论-1">结论</h6>
<ul>
<li>顶点:
<ul>
<li>4000并发:正常,无错误率,平均耗时13ms;</li>
<li>5000并发:每秒处理5000个数据的插入,就会存在0.06%的错误,应该已经处理不了了,顶峰应该在4000</li>
</ul>
</li>
<li>边:
<ul>
<li>1000并发:响应时间2ms,跟2000并发的响应时间相差较多,主要是 IO network rec和send以及CPU几乎增加了一倍);</li>
<li>2000并发:每秒处理2000个数据的插入,平均耗时953ms,平均每秒处理1750个请求;</li>
<li>3000并发:每秒处理3000个数据的插入,平均耗时2258ms,平均每秒处理1810个请求;</li>
<li>4000并发:每秒处理4000个数据的插入,平均每秒处理1812个请求;</li>
</ul>
</li>
</ul>
<h4 id="23-batch-插入">2.3 batch 插入</h4>
<h5 id="231-插入速率测试">2.3.1 插入速率测试</h5>
<h6 id="压力参数-2">压力参数</h6>
<p>测试方法:固定并发量,测试server和后端的处理速率</p>
<ul>
<li>并发量:1000</li>
<li>持续时间:5min</li>
</ul>
<h6 id="性能指标-2">性能指标</h6>
<table>
<thead>
<tr>
<th>Label</th>
<th>Samples</th>
<th>Average</th>
<th>Median</th>
<th>90%Line</th>
<th>Min</th>
<th>Max</th>
<th>Error%</th>
<th>Throughput</th>
<th>KB/sec</th>
</tr>
</thead>
<tbody>
<tr>
<td>batch_insert_vertices</td>
<td>37162</td>
<td>8959</td>
<td>9595</td>
<td>9704</td>
<td>17</td>
<td>9852</td>
<td>0.00%</td>
<td>103.4/sec</td>
<td>393.3</td>
</tr>
<tr>
<td>batch_insert_edges</td>
<td>10800</td>
<td>31849</td>
<td>34544</td>
<td>35132</td>
<td>435</td>
<td>35747</td>
<td>0.00%</td>
<td>28.8/sec</td>
<td>814.9</td>
</tr>
</tbody>
</table>
<h6 id="结论-2">结论</h6>
<ul>
<li>顶点:平均响应时间为8959ms,处理时间过长。每个请求插入199条数据,平均每秒处理103个请求,则每秒平均总共处理的数据为199*131约等于2w条数据;</li>
<li>边:平均响应时间31849ms,处理时间过长。每个请求插入499个数据,平均每秒处理28个请求,则每秒平均总共处理的数据为28*499约等于13900条数据;</li>
</ul>
</div>
</main>
</div>
</div>
<footer class="bg-dark py-3 row d-print-none">
<div class="footer-container">
<div class="row">
<div class="col-1"></div>
<div class="col-4 text-center container-center">
<div class="footer-row">
<a href="https://www.apache.org">
<div class="footer-apache-logo">
<svg id="Layer_2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 7127.6 2890" enable-background="new 0 0 7127.6 2890"><path fill="#6d6e71" d="M7104.7 847.8c15.3 15.3 22.9 33.7 22.9 55.2s-7.6 39.9-22.9 55.4c-15.3 15.4-33.8 23.1-55.6 23.1s-40.2-7.6-55.4-22.9c-15.1-15.3-22.7-33.7-22.7-55.2s7.6-39.9 22.9-55.4c15.3-15.4 33.7-23.1 55.4-23.1C7070.9 824.9 7089.4 832.5 7104.7 847.8zM7098.1 951.9c13.3-13.6 20-29.8 20-48.7s-6.6-35-19.8-48.5c-13.2-13.4-29.4-20.1-48.6-20.1-19.2.0-35.4 6.7-48.7 20.2s-19.9 29.7-19.9 48.7 6.6 35.2 19.7 48.6c13.1 13.4 29.3 20.1 48.5 20.1S7084.7 965.4 7098.1 951.9zm-11-63.8c0 14-6.1 22.8-18.4 26.4l22.5 30.5H7073l-20.3-28.3h-18.6V945h-14.7v-84.6h31.8c12.8.0 22 2.2 27.6 6.6C7084.4 871.4 7087.1 878.4 7087.1 888.1zM7068.2 9e2c3-2.4 4.4-6.5 4.4-12s-1.5-9.4-4.5-11.6-8.4-3.2-16-3.2h-18v30.5h17.5C7059.7 903.6 7065.3 902.4 7068.2 9e2z"/><path fill="#6d6e71" d="M1803.6 499.8v155.4h-20V499.8h-56.8v-19.2h133.9v19.2H1803.6z"/><path fill="#6d6e71" d="M2082.2 655.2v-76.9H1977v76.9h-20V480.5h20v78.9h105.2v-78.9h20v174.7h-20z"/><path fill="#6d6e71" d="M2241.4 499.8v57.4h88.1v19.2h-88.1v59.8h101.8v19h-121.8V480.5H2340v19.2H2241.4z"/><path fill="#d22128" d="M1574.5 1852.4l417.3-997.6h80.1l417.3 997.6h-105.4l-129.3-311.9h-448.2l-127.9 311.9H1574.5zM2032.6 970l-205.1 493.2h404.7L2032.6 970z"/><path fill="#d22128" d="M2596.9 1852.4V854.8H3010c171.4.0 295.1 158.8 295.1 313.3.0 163-115.2 316.1-286.6 316.1h-324.6v368.1h-97zm97-455.3h318.9c118 0 193.9-108.2 193.9-229 0-125.1-92.7-226.2-202.3-226.2h-310.5v455.2z"/><path fill="#d22128" d="M3250.5 1852.4l417.3-997.6h80.1l417.3 997.6h-105.4l-129.3-311.9h-448.2l-127.9 311.9H3250.5zM3708.6 970l-205.1 493.2h404.7L3708.6 970z"/><path fill="#d22128" d="M4637.3 849.1c177 0 306.3 89.9 368.1 217.8l-78.7 47.8c-63.2-132.1-186.9-177-295.1-177-238.9.0-369.5 213.6-369.5 414.5.0 220.6 161.6 420.1 373.7 420.1 112.4.0 244.5-56.2 307.7-185.5l81.5 42.1c-64.6 148.9-241.7 231.8-394.8 231.8-274 0-466.5-261.3-466.5-514.2C4163.8 1106.3 4336.6 849.1 4637.3 849.1z"/><path fill="#d22128" d="M5949.1 854.8v997.6h-98.4v-466.5h-591.5v466.5h-96.9V854.8h96.9v444h591.5v-444H5949.1z"/><path fill="#d22128" d="M6844.6 1765.2v87.1h-670.2V854.8H6832v87.1h-560.6v359.7h489v82.9h-489v380.8H6844.6z"/><path fill="#6d6e71" d="M1667.6 2063.6c11.8 3.5 22.2 8.3 31 14.2l-10.3 22.6c-9-6-18.6-10.4-28.9-13.4-10.2-2.9-20-4.4-29.2-4.4-13.6.0-24.5 2.4-32.6 7.3s-12.2 11.8-12.2 20.7c0 7.6 2.3 14 6.8 19s10.2 8.9 17 11.7c6.8 2.8 16.1 6 28 9.6 14.4 4.6 26 8.9 34.7 12.9 8.8 4 16.3 9.9 22.5 17.8 6.2 7.8 9.3 18.2 9.3 31 0 11.7-3.2 21.8-9.5 30.6-6.3 8.7-15.3 15.5-26.8 20.3-11.6 4.8-24.9 7.2-40 7.2s-29.7-2.9-43.9-8.7c-14.2-5.8-26.4-13.6-36.6-23.4l10.7-21.6c9.6 9.4 20.7 16.7 33.3 21.9 12.6 5.2 24.8 7.8 36.8 7.8 15.3.0 27.3-3 36.1-8.9s13.2-13.9 13.2-23.9c0-7.8-2.3-14.3-6.9-19.4-4.6-5.1-10.3-9-17.1-11.9-6.8-2.8-16.1-6-28-9.6-14.2-4.2-25.7-8.3-34.6-12.2-8.9-3.9-16.4-9.7-22.5-17.5-6.1-7.7-9.2-17.9-9.2-30.6.0-10.9 3-20.4 9-28.6s14.6-14.6 25.6-19.1c11.1-4.5 23.8-6.8 38.2-6.8C1643.8 2058.3 1655.7 2060.1 1667.6 2063.6z"/><path fill="#6d6e71" d="M1980.1 2072.8c16.8 9.4 30.2 22.3 40 38.4 9.8 16.2 14.8 33.9 14.8 53.3.0 19.5-4.9 37.4-14.8 53.6-9.8 16.3-23.2 29.1-40 38.6s-35.3 14.3-55.2 14.3c-20.3.0-38.8-4.7-55.7-14.3-16.8-9.5-30.2-22.4-40-38.6-9.8-16.3-14.8-34.1-14.8-53.6s4.9-37.3 14.8-53.5c9.8-16.2 23.2-29 40-38.3 16.8-9.4 35.4-14 55.7-14C1944.8 2058.6 1963.2 2063.3 1980.1 2072.8zM1881.9 2092.7c-13.1 7.4-23.6 17.5-31.4 30.1-7.8 12.6-11.8 26.5-11.8 41.7.0 15.3 3.9 29.3 11.8 42 7.8 12.7 18.3 22.8 31.4 30.2 13.1 7.4 27.4 11.1 42.9 11.1s29.7-3.7 42.7-11.1 23.3-17.4 31.1-30.2c7.7-12.7 11.6-26.7 11.6-42s-3.9-29.2-11.6-41.8c-7.7-12.6-18.1-22.6-31.1-30s-27.2-11.2-42.6-11.2C1909.4 2081.5 1895.1 2085.2 1881.9 2092.7z"/><path fill="#6d6e71" d="M2186.5 2082.4v74h98.4v23.2h-98.4v90.2h-24.1v-210.6h133.8v23.2H2186.5z"/><path fill="#6d6e71" d="M2491.6 2082.4v187.4h-24.1v-187.4h-68.4v-23.2h161.4v23.2H2491.6z"/><path fill="#6d6e71" d="M2871.8 2269.8l-56.8-177.4-57.6 177.4h-24.5l-70.5-210.6h25.9l57.9 182.7 57.1-182.4 24.1-.3 57.7 182.7 57.1-182.7h25l-70.6 210.6H2871.8z"/><path fill="#6d6e71" d="M3087.3 2216.6l-23.5 53.2h-25.6l94.4-210.6h25l94.1 210.6h-26.1l-23.5-53.2H3087.3zM3144.5 2086.6l-46.9 106.8h94.4l-47.5-106.8z"/><path fill="#6d6e71" d="M3461.1 2202.7c-6 .4-10.7.6-14.1.6h-56v66.5h-24v-210.6h80c26.2.0 46.6 6.2 61.2 18.5 14.5 12.3 21.8 29.8 21.8 52.3.0 17.2-4.1 31.7-12.2 43.3-8.1 11.6-19.8 20-35 25l49.2 71.5h-27.3L3461.1 2202.7zM3491.3 2167.6c10.3-8.4 15.5-20.8 15.5-37 0-15.9-5.2-27.9-15.5-36s-25.1-12.2-44.3-12.2h-56v97.8h56C3466.2 2180.2 3481 2176 3491.3 2167.6z"/><path fill="#6d6e71" d="M3688.3 2082.4v69.2h106.2v23.2h-106.2v72.1h122.8v22.9h-146.9v-210.6h142.9v23.2H3688.3z"/><path fill="#6d6e71" d="M4147 2082.4v74h98.4v23.2H4147v90.2h-24.1v-210.6h133.8v23.2H4147z"/><path fill="#6d6e71" d="M4523.3 2072.8c16.8 9.4 30.2 22.3 40 38.4 9.8 16.2 14.8 33.9 14.8 53.3.0 19.5-4.9 37.4-14.8 53.6-9.8 16.3-23.2 29.1-40 38.6s-35.3 14.3-55.2 14.3c-20.3.0-38.8-4.7-55.7-14.3-16.8-9.5-30.2-22.4-40-38.6-9.8-16.3-14.8-34.1-14.8-53.6s4.9-37.3 14.8-53.5c9.8-16.2 23.2-29 40-38.3 16.8-9.4 35.4-14 55.7-14C4488.1 2058.6 4506.5 2063.3 4523.3 2072.8zM4425.2 2092.7c-13.1 7.4-23.6 17.5-31.4 30.1-7.8 12.6-11.8 26.5-11.8 41.7.0 15.3 3.9 29.3 11.8 42 7.8 12.7 18.3 22.8 31.4 30.2 13.1 7.4 27.4 11.1 42.9 11.1s29.7-3.7 42.7-11.1 23.3-17.4 31.1-30.2c7.7-12.7 11.6-26.7 11.6-42s-3.9-29.2-11.6-41.8c-7.7-12.6-18.1-22.6-31.1-30s-27.2-11.2-42.6-11.2C4452.6 2081.5 4438.3 2085.2 4425.2 2092.7z"/><path fill="#6d6e71" d="M4854.7 2247.7c-15.7 15.5-37.3 23.3-64.8 23.3-27.7.0-49.4-7.8-65.1-23.3-15.7-15.5-23.6-37-23.6-64.6v-124h24.1v124c0 20.3 5.8 36.1 17.3 47.5 11.6 11.4 27.3 17.1 47.3 17.1 20.1.0 35.8-5.7 47.1-17 11.4-11.3 17-27.2 17-47.7v-124h24.1v124C4878.2 2210.7 4870.4 2232.2 4854.7 2247.7z"/><path fill="#6d6e71" d="M5169.5 2269.8l-126.3-169.1v169.1h-24.1v-210.6h25l126.3 169.3v-169.3h23.8v210.6H5169.5z"/><path fill="#6d6e71" d="M5478.4 2073.1c16.4 9.3 29.4 21.9 38.9 37.9 9.6 16 14.3 33.9 14.3 53.5s-4.8 37.6-14.3 53.6c-9.5 16.1-22.6 28.7-39.3 37.9-16.6 9.2-35.2 13.8-55.5 13.8h-84.3v-210.6h85.2C5443.7 2059.2 5462 2063.8 5478.4 2073.1zM5362.3 2246.9h61.4c15.5.0 29.6-3.5 42.3-10.6s22.8-16.9 30.2-29.5c7.4-12.5 11.1-26.5 11.1-42s-3.8-29.4-11.3-41.9-17.7-22.3-30.6-29.6c-12.8-7.2-27-10.9-42.6-10.9h-60.5v164.5z"/><path fill="#6d6e71" d="M5668.6 2216.6l-23.5 53.2h-25.6l94.4-210.6h25l94.1 210.6h-26l-23.5-53.2H5668.6zM5725.8 2086.6l-46.9 106.8h94.4l-47.5-106.8z"/><path fill="#6d6e71" d="M5991 2082.4v187.4h-24v-187.4h-68.4v-23.2H6060v23.2h-69z"/><path fill="#6d6e71" d="M6175.9 2269.8v-210.6h24.1v210.6H6175.9z"/><path fill="#6d6e71" d="M6493.7 2072.8c16.8 9.4 30.2 22.3 40 38.4 9.8 16.2 14.8 33.9 14.8 53.3.0 19.5-4.9 37.4-14.8 53.6-9.8 16.3-23.2 29.1-40 38.6s-35.3 14.3-55.2 14.3c-20.3.0-38.8-4.7-55.7-14.3-16.8-9.5-30.2-22.4-40-38.6-9.8-16.3-14.8-34.1-14.8-53.6s4.9-37.3 14.8-53.5c9.8-16.2 23.2-29 40-38.3 16.8-9.4 35.4-14 55.7-14C6458.5 2058.6 6476.9 2063.3 6493.7 2072.8zM6395.6 2092.7c-13.1 7.4-23.6 17.5-31.4 30.1-7.8 12.6-11.8 26.5-11.8 41.7.0 15.3 3.9 29.3 11.8 42 7.8 12.7 18.3 22.8 31.4 30.2 13.1 7.4 27.4 11.1 42.9 11.1s29.7-3.7 42.7-11.1 23.3-17.4 31.1-30.2c7.7-12.7 11.6-26.7 11.6-42s-3.9-29.2-11.6-41.8c-7.7-12.6-18.1-22.6-31.1-30s-27.2-11.2-42.6-11.2C6423 2081.5 6408.8 2085.2 6395.6 2092.7z"/><path fill="#6d6e71" d="M6826.5 2269.8l-126.3-169.1v169.1h-24.1v-210.6h25l126.3 169.3v-169.3h23.8v210.6H6826.5z"/><linearGradient id="SVGID_1_" gradientUnits="userSpaceOnUse" x1="-4516.6152" y1="-2338.7222" x2="-4108.4111" y2="-1861.3982" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset="0" style="stop-color:#F69923"/><stop offset=".3123" style="stop-color:#F79A23"/><stop offset=".8383" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_1_)" d="M1230.1 13.7c-45.3 26.8-120.6 102.5-210.5 212.3l82.6 155.9c58-82.9 116.9-157.5 176.3-221.2 4.6-5.1 7-7.5 7-7.5-2.3 2.5-4.6 5-7 7.5-19.2 21.2-77.5 89.2-165.5 224.4 84.7-4.2 214.9-21.6 321.1-39.7 31.6-177-31-258-31-258S1323.4-41.4 1230.1 13.7z"/><path fill="none" d="M1090.2 903.1c.6-.1 1.2-.2 1.8-.3l-11.9 1.3c-.7.3-1.4.7-2.1 1C1082.1 904.4 1086.2 903.7 1090.2 903.1z"/><path fill="none" d="M1005.9 1182.3c-6.7 1.5-13.7 2.7-20.7 3.7C992.3 1185 999.2 1183.8 1005.9 1182.3z"/><path fill="none" d="M432.9 1808.8c.9-2.3 1.8-4.7 2.6-7 18.2-48 36.2-94.7 54-140.1 20-51 39.8-100.4 59.3-148.3 20.6-50.4 40.9-99.2 60.9-146.3 21-49.4 41.7-97 62-142.8 16.5-37.3 32.8-73.4 48.9-108.3 5.4-11.7 10.7-23.2 16-34.6 10.5-22.7 21-44.8 31.3-66.5 9.5-20 19-39.6 28.3-58.8 3.1-6.4 6.2-12.8 9.3-19.1.5-1 1-2 1.5-3.1l-10.2 1.1-8-15.9c-.8 1.6-1.6 3.1-2.4 4.6-14.5 28.8-28.9 57.9-43.1 87.2-8.2 16.9-16.4 34-24.6 51-22.6 47.4-44.8 95.2-66.6 143.3-22.1 48.6-43.7 97.5-64.9 146.5-20.8 48.1-41.3 96.2-61.2 144.2-20 48-39.5 95.7-58.5 143.2-19.9 49.5-39.2 98.7-58 147.2-4.2 10.9-8.5 21.9-12.7 32.8-15 39.2-29.7 77.8-44 116l12.7 25.1 11.4-1.2c.4-1.1.8-2.3 1.3-3.4C396.7 1905.4 414.9 1856.4 432.9 1808.8z"/><path fill="none" d="M980 1186.8c.1.0.1.0.1-.1C980.1 1186.8 980.1 1186.8 980 1186.8z"/><path fill="#be202e" d="M952.6 1323c-10.6 1.9-21.4 3.8-32.5 5.7-.1.0-.1.1-.2.1 5.6-.8 11.2-1.7 16.6-2.6C942 1325.2 947.3 1324.1 952.6 1323z"/><path opacity=".35" fill="#be202e" d="M952.6 1323c-10.6 1.9-21.4 3.8-32.5 5.7-.1.0-.1.1-.2.1 5.6-.8 11.2-1.7 16.6-2.6C942 1325.2 947.3 1324.1 952.6 1323z"/><path fill="#be202e" d="M980.3 1186.7C980.2 1186.7 980.2 1186.7 980.3 1186.7c-.1.1-.2.1-.2.1 1.8-.2 3.5-.5 5.2-.8 7-1 13.9-2.2 20.7-3.7C997.5 1183.8 989 1185.2 980.3 1186.7z"/><path opacity=".35" fill="#be202e" d="M980.3 1186.7C980.2 1186.7 980.2 1186.7 980.3 1186.7c-.1.1-.2.1-.2.1 1.8-.2 3.5-.5 5.2-.8 7-1 13.9-2.2 20.7-3.7C997.5 1183.8 989 1185.2 980.3 1186.7z"/><linearGradient id="SVGID_2_" gradientUnits="userSpaceOnUse" x1="-7537.7339" y1="-2391.4075" x2="-4625.4141" y2="-2391.4075" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_2_)" d="M858.6 784.7c25.1-46.9 50.5-92.8 76.2-137.4 26.7-46.4 53.7-91.3 80.9-134.7 1.6-2.6 3.2-5.2 4.8-7.7 27-42.7 54.2-83.7 81.6-122.9L1019.5 226c-6.2 7.6-12.5 15.3-18.8 23.2-23.8 29.7-48.6 61.6-73.9 95.5-28.6 38.2-58 78.9-87.8 121.7-27.6 39.5-55.5 80.9-83.5 123.7-23.8 36.5-47.7 74-71.4 112.5-.9 1.4-1.8 2.9-2.6 4.3L789 919.2C811.8 873.6 835.1 828.7 858.6 784.7z"/><linearGradient id="SVGID_3_" gradientUnits="userSpaceOnUse" x1="-7186.1777" y1="-2099.3059" x2="-5450.7183" y2="-2099.3059" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset="0" style="stop-color:#282662"/><stop offset=".0954839" style="stop-color:#662E8D"/><stop offset=".7882" style="stop-color:#9F2064"/><stop offset=".9487" style="stop-color:#CD2032"/></linearGradient><path fill="url(#SVGID_3_)" d="M369 1981c-14.2 39.1-28.5 78.9-42.9 119.6-.2.6-.4 1.2-.6 1.8-2 5.7-4.1 11.5-6.1 17.2-9.7 27.4-18 52.1-37.3 108.2 31.7 14.5 57.1 52.5 81.1 95.6-2.6-44.7-21-86.6-56.2-119.1 156.1 7 290.6-32.4 360.1-146.6 6.2-10.2 11.9-20.9 17-32.2-31.6 40.1-70.8 57.1-144.5 53-.2.1-.3.1-.5.2.2-.1.3-.1.5-.2 108.6-48.6 163.1-95.3 211.2-172.6 11.4-18.3 22.5-38.4 33.8-60.6-94.9 97.5-205 125.3-320.9 104.2l-86.9 9.5C374.4 1966.3 371.7 1973.6 369 1981z"/><linearGradient id="SVGID_4_" gradientUnits="userSpaceOnUse" x1="-7374.1626" y1="-2418.5454" x2="-4461.8428" y2="-2418.5454" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_4_)" d="M409.6 1786.3c18.8-48.5 38.1-97.7 58-147.2 19-47.4 38.5-95.2 58.5-143.2s40.4-96.1 61.2-144.2c21.2-49 42.9-97.8 64.9-146.5 21.8-48.1 44-95.9 66.6-143.3 8.1-17.1 16.3-34.1 24.6-51 14.2-29.3 28.6-58.4 43.1-87.2.8-1.6 1.6-3.1 2.4-4.6L681.4 706.8c-1.8 2.9-3.5 5.8-5.3 8.6-25.1 40.9-50 82.7-74.4 125.4-24.7 43.1-49 87.1-72.7 131.7-20 37.6-39.6 75.6-58.6 113.9-3.8 7.8-7.6 15.5-11.3 23.2-23.4 48.2-44.6 94.8-63.7 139.5-21.7 50.7-40.7 99.2-57.5 145.1-11 30.2-21 59.4-30.1 87.4-7.5 24-14.7 47.9-21.5 71.8-16 56.3-29.9 112.4-41.2 168.3L353 1935.1c14.3-38.1 28.9-76.8 44-116C401.1 1808.2 405.4 1797.3 409.6 1786.3z"/><linearGradient id="SVGID_5_" gradientUnits="userSpaceOnUse" x1="-7161.7642" y1="-2379.1431" x2="-5631.2524" y2="-2379.1431" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset="0" style="stop-color:#282662"/><stop offset=".0954839" style="stop-color:#662E8D"/><stop offset=".7882" style="stop-color:#9F2064"/><stop offset=".9487" style="stop-color:#CD2032"/></linearGradient><path fill="url(#SVGID_5_)" d="M243.5 1729.4c-13.6 68.2-23.2 136.2-28 203.8-.2 2.4-.4 4.7-.5 7.1-33.7-54-124-106.8-123.8-106.2 64.6 93.7 113.7 186.7 120.9 278-34.6 7.1-82-3.2-136.8-23.3 57.1 52.5 1e2 67 116.7 70.9-52.5 3.3-107.1 39.3-162.1 80.8 80.5-32.8 145.5-45.8 192.1-35.3C148.1 2414.2 74.1 2645 0 2890c22.7-6.7 36.2-21.9 43.9-42.6 13.2-44.4 100.8-335.6 238-718.2 3.9-10.9 7.8-21.8 11.8-32.9 1.1-3 2.2-6.1 3.3-9.2 14.5-40.1 29.5-81.1 45.1-122.9 3.5-9.5 7.1-19 10.7-28.6.1-.2.1-.4.2-.6l-107.9-213.2C244.6 1724.4 244 1726.9 243.5 1729.4z"/><linearGradient id="SVGID_6_" gradientUnits="userSpaceOnUse" x1="-7374.1626" y1="-2117.1309" x2="-4461.8428" y2="-2117.1309" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_6_)" d="M805.6 937c-3.1 6.3-6.2 12.7-9.3 19.1-9.3 19.2-18.8 38.8-28.3 58.8-10.3 21.7-20.7 43.9-31.3 66.5-5.3 11.4-10.6 22.9-16 34.6-16.1 35-32.4 71.1-48.9 108.3-20.3 45.8-41 93.4-62 142.8-20 47.1-40.3 95.9-60.9 146.3-19.5 47.9-39.3 97.3-59.3 148.3-17.8 45.4-35.9 92.1-54 140.1-.9 2.3-1.8 4.7-2.6 7-18 47.6-36.2 96.6-54.6 146.8-.4 1.1-.8 2.3-1.3 3.4l86.9-9.5c-1.7-.3-3.5-.5-5.2-.9 103.9-13 242.1-90.6 331.4-186.5 41.1-44.2 78.5-96.3 113-157.3 25.7-45.4 49.8-95.8 72.8-151.5 20.1-48.7 39.4-101.4 58-158.6-23.9 12.6-51.2 21.8-81.4 28.2-5.3 1.1-10.7 2.2-16.1 3.1-5.5 1-11 1.8-16.6 2.6.1.0.1-.1.2-.1 96.9-37.3 158-109.2 202.4-197.4-25.5 17.4-66.9 40.1-116.6 51.1-6.7 1.5-13.7 2.7-20.7 3.7-1.7.3-3.5.6-5.2.8.1.0.1.0.1-.1h.1c33.6-14.1 62-29.8 86.6-48.4 5.3-4 10.4-8.1 15.3-12.3 7.5-6.5 14.7-13.3 21.5-20.5 4.4-4.6 8.6-9.3 12.7-14.2 9.6-11.5 18.7-23.9 27.1-37.3 2.6-4.1 5.1-8.3 7.6-12.6 3.2-6.2 6.3-12.3 9.3-18.3 13.5-27.2 24.4-51.5 33-72.8 4.3-10.6 8.1-20.5 11.3-29.7 1.3-3.7 2.5-7.2 3.7-10.6 3.4-10.2 6.2-19.3 8.4-27.3 3.3-12 5.3-21.5 6.4-28.4-3.3 2.6-7.1 5.2-11.3 7.7-29.3 17.5-79.5 33.4-119.9 40.8l79.8-8.8-79.8 8.8c-.6.1-1.2.2-1.8.3-4 .7-8.1 1.3-12.2 2 .7-.3 1.4-.7 2.1-1l-273 29.9C806.6 935 806.1 936 805.6 937z"/><linearGradient id="SVGID_7_" gradientUnits="userSpaceOnUse" x1="-7554.8232" y1="-2132.0981" x2="-4642.5034" y2="-2132.0981" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_7_)" d="M1112.9 385.1c-24.3 37.3-50.8 79.6-79.4 127.5-1.5 2.5-3 5.1-4.5 7.6-24.6 41.5-50.8 87.1-78.3 137-23.8 43.1-48.5 89.3-74.3 139C854 839.5 830.8 885.4 807 934l273-29.9c79.5-36.6 115.1-69.7 149.6-117.6 9.2-13.2 18.4-27 27.5-41.3 28-43.8 55.6-92 80.1-139.9 23.7-46.3 44.7-92.2 60.7-133.5 10.2-26.3 18.4-50.8 24.1-72.3 5-19 8.9-36.9 11.9-54.1C1327.9 363.5 1197.6 380.9 1112.9 385.1z"/><path fill="#be202e" d="M936.5 1326.1c-5.5 1-11 1.8-16.6 2.6C925.5 1328 931 1327.1 936.5 1326.1z"/><path opacity=".35" fill="#be202e" d="M936.5 1326.1c-5.5 1-11 1.8-16.6 2.6C925.5 1328 931 1327.1 936.5 1326.1z"/><linearGradient id="SVGID_8_" gradientUnits="userSpaceOnUse" x1="-7374.1626" y1="-2027.484" x2="-4461.8433" y2="-2027.484" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_8_)" d="M936.5 1326.1c-5.5 1-11 1.8-16.6 2.6C925.5 1328 931 1327.1 936.5 1326.1z"/><path fill="#be202e" d="M980 1186.8c1.8-.2 3.5-.5 5.2-.8C983.5 1186.3 981.8 1186.6 980 1186.8z"/><path opacity=".35" fill="#be202e" d="M980 1186.8c1.8-.2 3.5-.5 5.2-.8C983.5 1186.3 981.8 1186.6 980 1186.8z"/><linearGradient id="SVGID_9_" gradientUnits="userSpaceOnUse" x1="-7374.1626" y1="-2037.7417" x2="-4461.8433" y2="-2037.7417" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_9_)" d="M980 1186.8c1.8-.2 3.5-.5 5.2-.8C983.5 1186.3 981.8 1186.6 980 1186.8z"/><path fill="#be202e" d="M980.2 1186.7z"/><path opacity=".35" fill="#be202e" d="M980.2 1186.7z"/><linearGradient id="SVGID_10_" gradientUnits="userSpaceOnUse" x1="-5738.0635" y1="-2039.799" x2="-5094.3457" y2="-2039.799" gradientTransform="matrix(0.4226 -0.9063 0.9063 0.4226 5117.8774 -2859.9343)"><stop offset=".3233" style="stop-color:#9E2064"/><stop offset=".6302" style="stop-color:#C92037"/><stop offset=".7514" style="stop-color:#CD2335"/><stop offset="1" style="stop-color:#E97826"/></linearGradient><path fill="url(#SVGID_10_)" d="M980.2 1186.7z"/></svg>
</div>
</a>
<ul class="footer-link">
<li><a class="white" href="http://www.apache.org">Foundation</a></li>
<li><a class="white" href="http://www.apache.org/licenses/">License</a></li>
<li><a class="white" href="https://www.apache.org/security/">Security</a></li>
<li><a class="white" href="http://www.apache.org/events/current-event">Events</a></li>
<li><a class="white" href="http://www.apache.org/foundation/sponsorship.html">Sponsorship</a></li>
<li><a class="white" href="http://www.apache.org/foundation/thanks.html">Thanks</a></li>
</ul>
</div>
</div>
<div class="col-6 text-white text-center container-center">
<p>Copyright &copy; 2022 The Apache Software Foundation, Licensed under the <a class="white" href="https://www.apache.org/licenses/LICENSE-2.0">Apache License Version 2.0</a></p>
<p>Apache and the Apache feather logo are trademarks of The Apache Software Foundation.</p>
</div>
<div class="col-1"></div>
</div>
</div>
</footer>
</div>
<script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.1/dist/umd/popper.min.js"
integrity="sha384-9/reFTGAW83EW2RDu2S0VKaIzap3H66lZH81PoYlFhbGU+6BZp6G7niu735Sk7lN"
crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.6.1/dist/js/bootstrap.min.js"
integrity="sha512-UR25UO94eTnCVwjbXozyeVd6ZqpaAE9naiEUBK/A+QDbfSTQFhPGj5lOR6d8tsgbBk84Ggb5A3EkjsOgPRPcKA=="
crossorigin="anonymous"></script>
<script src='/js/tabpane-persist.js'></script>
<script src="/js/main.min.1a2e43037d7eeb7eb548659ffab8adc920ddeef68063a09913f04392dd3c1f19.js" integrity="sha256-Gi5DA31&#43;6361SGWf&#43;ritySDd7vaAY6CZE/BDkt08Hxk=" crossorigin="anonymous"></script>
<script src='/js/prism.js'></script>
</body>
</html>