mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 10:23:17 +00:00
Add timing for cache profile and use call stats for toolbar
This commit is contained in:
@@ -66,6 +66,15 @@ class CacheStatisticsSubscriber implements EventSubscriberInterface
|
|||||||
return [];
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getTimeSpent()
|
||||||
|
{
|
||||||
|
if ($this->cache instanceof TraceableCache) {
|
||||||
|
return $this->cache->getTotalTime();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
public function getCacheType()
|
public function getCacheType()
|
||||||
{
|
{
|
||||||
return $this->cacheType;
|
return $this->cacheType;
|
||||||
|
@@ -30,6 +30,11 @@ class CacheDataCollector implements DataCollectorInterface
|
|||||||
*/
|
*/
|
||||||
private $summary;
|
private $summary;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var int
|
||||||
|
*/
|
||||||
|
private $timeSpent = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
@@ -70,15 +75,17 @@ class CacheDataCollector implements DataCollectorInterface
|
|||||||
$this->startProfile = new CacheProfile($this->statsListener->getInitialStats() ?: []);
|
$this->startProfile = new CacheProfile($this->statsListener->getInitialStats() ?: []);
|
||||||
$this->endProfile = new CacheProfile($this->statsListener->getCurrentStats() ?: []);
|
$this->endProfile = new CacheProfile($this->statsListener->getCurrentStats() ?: []);
|
||||||
|
|
||||||
|
$this->timeSpent = $this->statsListener->getTimeSpent();
|
||||||
|
$this->calls = $this->statsListener->getCalls();
|
||||||
|
$this->callSummary = $this->statsListener->getCallSummary();
|
||||||
|
|
||||||
$this->summary = new CacheProfileSummary(
|
$this->summary = new CacheProfileSummary(
|
||||||
$this->statsListener->getCacheType(),
|
$this->statsListener->getCacheType(),
|
||||||
$this->statsListener->getCacheNamespace(),
|
$this->statsListener->getCacheNamespace(),
|
||||||
$this->startProfile,
|
$this->startProfile,
|
||||||
$this->endProfile
|
$this->endProfile,
|
||||||
|
$this->callSummary
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->calls = $this->statsListener->getCalls();
|
|
||||||
$this->callSummary = $this->statsListener->getCallSummary();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -97,6 +104,14 @@ class CacheDataCollector implements DataCollectorInterface
|
|||||||
return $this->endProfile;
|
return $this->endProfile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
public function getTotalTime()
|
||||||
|
{
|
||||||
|
return $this->timeSpent;
|
||||||
|
}
|
||||||
|
|
||||||
public function getCalls()
|
public function getCalls()
|
||||||
{
|
{
|
||||||
return $this->calls;
|
return $this->calls;
|
||||||
|
@@ -24,18 +24,30 @@ class CacheProfileSummary
|
|||||||
*/
|
*/
|
||||||
private $finalProfile;
|
private $finalProfile;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private $callSummaryData;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $cacheType
|
* @param string $cacheType
|
||||||
* @param string $namespace
|
* @param string $namespace
|
||||||
* @param CacheProfile $initialProfile
|
* @param CacheProfile $initialProfile
|
||||||
* @param CacheProfile $finalProfile
|
* @param CacheProfile $finalProfile
|
||||||
|
* @param array $callSummaryData
|
||||||
*/
|
*/
|
||||||
public function __construct($cacheType, $namespace, CacheProfile $initialProfile, CacheProfile $finalProfile)
|
public function __construct(
|
||||||
{
|
$cacheType,
|
||||||
$this->cacheType = (string) $cacheType;
|
$namespace,
|
||||||
$this->cacheNamespace = (string) $namespace;
|
CacheProfile $initialProfile,
|
||||||
|
CacheProfile $finalProfile,
|
||||||
|
array $callSummaryData
|
||||||
|
) {
|
||||||
|
$this->cacheType = (string)$cacheType;
|
||||||
|
$this->cacheNamespace = (string)$namespace;
|
||||||
$this->initialProfile = $initialProfile;
|
$this->initialProfile = $initialProfile;
|
||||||
$this->finalProfile = $finalProfile;
|
$this->finalProfile = $finalProfile;
|
||||||
|
$this->callSummaryData = $callSummaryData;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -59,7 +71,11 @@ class CacheProfileSummary
|
|||||||
*/
|
*/
|
||||||
public function getHits()
|
public function getHits()
|
||||||
{
|
{
|
||||||
return (int) max(0, $this->finalProfile->getHits() - $this->initialProfile->getHits());
|
if (isset($this->callSummaryData['hits'])) {
|
||||||
|
return (int) $this->callSummaryData['hits'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return (int)max(0, $this->finalProfile->getHits() - $this->initialProfile->getHits());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -67,7 +83,11 @@ class CacheProfileSummary
|
|||||||
*/
|
*/
|
||||||
public function getMisses()
|
public function getMisses()
|
||||||
{
|
{
|
||||||
return (int) max(0, $this->finalProfile->getMisses() - $this->initialProfile->getMisses());
|
if (isset($this->callSummaryData['misses'])) {
|
||||||
|
return (int) $this->callSummaryData['misses'];
|
||||||
|
}
|
||||||
|
|
||||||
|
return (int)max(0, $this->finalProfile->getMisses() - $this->initialProfile->getMisses());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -75,6 +95,10 @@ class CacheProfileSummary
|
|||||||
*/
|
*/
|
||||||
public function getCalls()
|
public function getCalls()
|
||||||
{
|
{
|
||||||
|
if (isset($this->callSummaryData['calls'])) {
|
||||||
|
return (int) $this->callSummaryData['calls'];
|
||||||
|
}
|
||||||
|
|
||||||
return $this->getHits() + $this->getMisses();
|
return $this->getHits() + $this->getMisses();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -86,7 +110,7 @@ class CacheProfileSummary
|
|||||||
$calls = $this->getCalls();
|
$calls = $this->getCalls();
|
||||||
|
|
||||||
if ($calls == 0) {
|
if ($calls == 0) {
|
||||||
return (float) 0;
|
return (float)0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->getHits() / $calls;
|
return $this->getHits() / $calls;
|
||||||
@@ -100,7 +124,7 @@ class CacheProfileSummary
|
|||||||
$calls = $this->getCalls();
|
$calls = $this->getCalls();
|
||||||
|
|
||||||
if ($calls == 0) {
|
if ($calls == 0) {
|
||||||
return (float) 0;
|
return (float)0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->getMisses() / $calls;
|
return $this->getMisses() / $calls;
|
||||||
|
@@ -5,6 +5,7 @@ namespace Alchemy\Phrasea\Core\Profiler;
|
|||||||
use Alchemy\Phrasea\Cache\Cache as PhraseaCache;
|
use Alchemy\Phrasea\Cache\Cache as PhraseaCache;
|
||||||
use Alchemy\Phrasea\Cache\Exception;
|
use Alchemy\Phrasea\Cache\Exception;
|
||||||
use Doctrine\Common\Cache\Cache;
|
use Doctrine\Common\Cache\Cache;
|
||||||
|
use Symfony\Component\Stopwatch\Stopwatch;
|
||||||
|
|
||||||
class TraceableCache implements Cache, PhraseaCache
|
class TraceableCache implements Cache, PhraseaCache
|
||||||
{
|
{
|
||||||
@@ -32,12 +33,15 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
'calls_by_key' => [],
|
'calls_by_key' => [],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
private $stopWatch;
|
||||||
|
|
||||||
/*s*
|
/*s*
|
||||||
* @param PhraseaCache $cache
|
* @param PhraseaCache $cache
|
||||||
*/
|
*/
|
||||||
public function __construct(PhraseaCache $cache)
|
public function __construct(PhraseaCache $cache, Stopwatch $stopwatch = null)
|
||||||
{
|
{
|
||||||
$this->cache = $cache;
|
$this->cache = $cache;
|
||||||
|
$this->stopWatch = $stopwatch ?: new Stopwatch();
|
||||||
}
|
}
|
||||||
|
|
||||||
private function collect($type, $id, $hit = true, $result = null)
|
private function collect($type, $id, $hit = true, $result = null)
|
||||||
@@ -90,6 +94,14 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
return $this->namespace;
|
return $this->namespace;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
public function getTotalTime()
|
||||||
|
{
|
||||||
|
return $this->stopWatch->getEvent('cache')->getDuration();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
@@ -116,7 +128,9 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
public function fetch($id)
|
public function fetch($id)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
|
$this->stopWatch->start('cache');
|
||||||
$value = $this->cache->fetch($id);
|
$value = $this->cache->fetch($id);
|
||||||
|
$this->stopWatch->stop('cache');
|
||||||
}
|
}
|
||||||
catch (\Exception $ex) {
|
catch (\Exception $ex) {
|
||||||
$value = false;
|
$value = false;
|
||||||
@@ -138,7 +152,11 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
{
|
{
|
||||||
$this->collect('contains', $id);
|
$this->collect('contains', $id);
|
||||||
|
|
||||||
return $this->cache->contains($id);
|
$this->stopWatch->start('cache');
|
||||||
|
$result = $this->cache->contains($id);
|
||||||
|
$this->stopWatch->stop('cache');
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -158,7 +176,11 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
{
|
{
|
||||||
$this->collect('save', $id);
|
$this->collect('save', $id);
|
||||||
|
|
||||||
return $this->cache->save($id, $data, $lifeTime);
|
$this->stopWatch->start('cache');
|
||||||
|
$result = $this->cache->save($id, $data, $lifeTime);
|
||||||
|
$this->stopWatch->stop('cache');
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -173,7 +195,11 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
{
|
{
|
||||||
$this->collect('delete', $id);
|
$this->collect('delete', $id);
|
||||||
|
|
||||||
return $this->cache->delete($id);
|
$this->stopWatch->start('cache');
|
||||||
|
$result = $this->cache->delete($id);
|
||||||
|
$this->stopWatch->stop('cache');
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -202,7 +228,11 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
*/
|
*/
|
||||||
public function getStats()
|
public function getStats()
|
||||||
{
|
{
|
||||||
return $this->cache->getStats();
|
$this->stopWatch->start('cache');
|
||||||
|
$result = $this->cache->getStats();
|
||||||
|
$this->stopWatch->stop('cache');
|
||||||
|
|
||||||
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -222,7 +252,9 @@ class TraceableCache implements Cache, PhraseaCache
|
|||||||
public function flushAll()
|
public function flushAll()
|
||||||
{
|
{
|
||||||
$this->collect('flush-all', null);
|
$this->collect('flush-all', null);
|
||||||
|
$this->stopWatch->start('cache');
|
||||||
$this->cache->flushAll();
|
$this->cache->flushAll();
|
||||||
|
$this->stopWatch->stop('cache');
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -13,7 +13,7 @@
|
|||||||
{% endset %}
|
{% endset %}
|
||||||
{% set icon %}
|
{% set icon %}
|
||||||
<img width="20" height="28" alt="Cache" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAcCAYAAABh2p9gAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQRJREFUeNpi/P//PwM1ARMDlcGogZQDlpMnT7pxc3NbA9nhQKxOpL5rQLwJiPeBsI6Ozl+YBOOOHTv+AOllQNwtLS39F2owKYZ/gRq8G4i3ggxEToggWzvc3d2Pk+1lNL4fFAs6ODi8JzdS7mMRVyDVoAMHDsANdAPiOCC+jCQvQKqBQB/BDbwBxK5AHA3E/kB8nKJkA8TMQBwLxaBIKQbi70AvTADSBiSadwFXpCikpKQU8PDwkGTaly9fHFigkaKIJid4584dkiMFFI6jkTJII0WVmpHCAixZQEXWYhDeuXMnyLsVlEQKI45qFBQZ8eRECi4DBaAlDqle/8A48ip6gAADANdQY88Uc0oGAAAAAElFTkSuQmCC"/>
|
<img width="20" height="28" alt="Cache" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAcCAYAAABh2p9gAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQRJREFUeNpi/P//PwM1ARMDlcGogZQDlpMnT7pxc3NbA9nhQKxOpL5rQLwJiPeBsI6Ozl+YBOOOHTv+AOllQNwtLS39F2owKYZ/gRq8G4i3ggxEToggWzvc3d2Pk+1lNL4fFAs6ODi8JzdS7mMRVyDVoAMHDsANdAPiOCC+jCQvQKqBQB/BDbwBxK5AHA3E/kB8nKJkA8TMQBwLxaBIKQbi70AvTADSBiSadwFXpCikpKQU8PDwkGTaly9fHFigkaKIJid4584dkiMFFI6jkTJII0WVmpHCAixZQEXWYhDeuXMnyLsVlEQKI45qFBQZ8eRECi4DBaAlDqle/8A48ip6gAADANdQY88Uc0oGAAAAAElFTkSuQmCC"/>
|
||||||
<span class="sf-toolbar-status{% if 75 > collector.summary.hitRatio %} sf-toolbar-status-green{% endif %}">{{ '%0.2f'|format(collector.summary.hitRatio * 100) }} %</span> cache hit ratio
|
<span class="sf-toolbar-status{% if 75 > collector.summary.hitRatio %} sf-toolbar-status-green{% endif %}">{{ '%0.2f'|format(collector.summary.hitRatio * 100) }} %</span> in {{ collector.totalTime }} ms
|
||||||
{% endset %}
|
{% endset %}
|
||||||
{% include '@WebProfiler/Profiler/toolbar_item.html.twig' with { 'link': profiler_url } %}
|
{% include '@WebProfiler/Profiler/toolbar_item.html.twig' with { 'link': profiler_url } %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
@@ -21,6 +21,10 @@
|
|||||||
{% block menu %}
|
{% block menu %}
|
||||||
<span class="label">
|
<span class="label">
|
||||||
<strong>Cache</strong>
|
<strong>Cache</strong>
|
||||||
|
<span class="count">
|
||||||
|
<span>{{ collector.summary.hits }}</span>
|
||||||
|
<span>{{ '%0.0f'|format(collector.totalTime) }} ms</span>
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user