手记

php 缓存使用监控测试代码

php 缓存使用监控测试代码。

将以下代码存在PHP WEB网站下面,然后通过IE浏览器进行访问。

#cat ocpcache.php

<?php

/*

* Fetch configuration and status information from OpCache

*/

$config = opcache_get_configuration();

$status = opcache_get_status();

/*

* Turn bytes into a human readable format

* @param $bytes

*/

function size_for_humans($bytes) {

    if ($bytes > 1048576) {

        return sprintf("%.2f&nbsp;MB", $bytes/1048576);

    } else if ($bytes > 1024) {

        return sprintf("%.2f&nbsp;kB", $bytes/1024);

    } else return sprintf("%d&nbsp;bytes", $bytes);

}

?>

<!DOCTYPE html>

<meta charset="utf-8">

<html><head>

<style>

body{

    font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;

    margin:auto;

    position:relative;

    width:1024px;

}

text{

    font:10px sans-serif;

}

form{

    position: absolute;

    right:210px;

    top:50px;

}

#graph{

    position: absolute;

    right:0px;

    top:80px;

}

#stats{

    position: absolute;

    right:234px;

    top:240px;

}

tbody tr:nth-child(even) {

    background-color:#eee;

}

p.capitalize{

    text-transform:capitalize;

}

.tabs{

    position:relative;

    min-height:200px;

    clear:both;

    margin:25px 0;

}

.tab{

    float:left;

}

.tab label{

    background: #eee;

    padding:10px;

    border:1px solid #ccc;

    margin-left:-1px;

    position:relative;

    left:1px;

}

.tab [type=radio]{

    display: none;

}

.content{

    position:absolute;

    top:28px;

    left: 0;

    background:white;

    padding:20px;

    border:1px solid #ccc;

    height:500px;

    width:480px;

    overflow-y:auto;

    overflow-x:hidden;

}

.content table {

    width:100%;

}

.clickable {

    cursor: hand; 

    cursor: pointer; 

}

[type=radio]:checked ~ label{

    background: white;

    border-bottom:1px solid white;

    z-index:2;

}

[type=radio]:checked ~ label ~ .content{

    z-index: 1;

}

</style>

<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/d3/3.0.1/d3.v3.min.js"></script>

<script language="javascript">

var hidden = {};

function toggleVisible(head, row) {

    if (!hidden[row]) {

        d3.selectAll(row)

            .transition().style('display', 'none');

        hidden[row] = true;

        d3.select(head).transition().style('color', '#ccc');

    } else {

        d3.selectAll(row)

            .transition().style('display');

        hidden[row] = false;

        d3.select(head).transition().style('color', '#000');

    }

}

</script>

</head>

<body>

  <h1>PHP <?= phpversion()?> OpCache <?= $config['version']['version']?></h1>

  <form>

    <label><input type="radio" name="dataset" value="memory" checked> Memory</label>

    <label><input type="radio" name="dataset" value="keys"> Keys</label>

    <label><input type="radio" name="dataset" value="hits"> Hits</label>

  </form>

  <div id="stats">

  </div>

  <div class="tabs">


    <div class="tab">

      <input type="radio" id="tab-status" name="tab-group-1" checked>

      <label for="tab-status">Status</label>

      <div class="content">

      <table>

<?php

foreach($status as $key=>$value) {

  if($key=='scripts') continue;

  if(is_array($value)) {

    foreach($value as $k=>$v) {

      if($v===false) $value = "false";

      if($v===true) $value = "true";

      if($k=='used_memory' || $k=='free_memory' || $k == 'wasted_memory') $v = size_for_humans($v);

      if($k=='current_wasted_percentage' || $k=='opcache_hit_rate') $v = number_format($v,2).'%';

      if($k=='blacklist_miss_ratio') $v = number_format($v,2);

      echo "<tr><th align=\"left\">$k</th><td align=\"right\">$v</td></tr>\n";

    }

    continue;

  }

  if($value===false) $value = "false";

  if($value===true) $value = "true";

  echo "<tr><th align=\"left\">$key</th><td align=\"right\">$value</td></tr>\n";

}

?>

      </table>

      </div>

    </div>


    <div class="tab">

      <input type="radio" id="tab-config" name="tab-group-1">

      <label for="tab-config">Configuration</label>

      <div class="content">

      <table>

<?php

foreach($config['directives'] as $key=>$value) {

  if($value===false) $value = "false";

  if($value===true) $value = "true";

  if($key == 'opcache.memory_consumption') $value = size_for_humans($value);

  echo "<tr><th align=\"left\">$key</th><td align=\"right\">$value</td></tr>\n";

}

?>

      </table>

      </div>

    </div>


    <div class="tab">

      <input type="radio" id="tab-scripts" name="tab-group-1">

      <label for="tab-scripts">Scripts (<?=count($status["scripts"]); ?>)</label>

      <div class="content">

      <table >

      <tr>

        <th width="10%">Hits</th>

        <th width="20%">Memory</th>

        <th width="70%">Path</th>

      </tr>

<?php

foreach($status['scripts'] as $key=>$data) {

    $dirs[dirname($key)][basename($key)]=$data;

}

asort($dirs);

$id = 1;

foreach($dirs as $dir => $files) {

    $count = count($files);

    

    if ($count > 1) {

        echo "<tr>";

        echo "<th class=\"clickable\" id=\"head-{$id}\" colspan=\"3\"  '#row-{$id}')\">{$dir} ({$count} files)</th>";

        echo "</tr>";    

    }

    

    foreach ($files as $file => $data) {

        echo "<tr id=\"row-{$id}\">";

        echo "<td>{$data["hits"]}</td>";

        echo "<td>" .size_for_humans($data["memory_consumption"]). "</td>";

        

        if ($count > 1) {

            echo "<td>{$file}</td>";

        } else echo "<td>{$dir}/{$file}</td>";       

        echo "</tr>";

    }    

    ++$id;

}

?>

      </table>

      </div>

    </div>


  </div>


  <div id="graph">

  </div>

<?php 

$mem = $status['memory_usage'];

$stats = $status['opcache_statistics'];

$free_keys = $stats['max_cached_keys'] - $stats['num_cached_keys'];

echo <<<EOB

<script>

var dataset = {

  memory: [{$mem['used_memory']},{$mem['free_memory']},{$mem['wasted_memory']}],

  keys: [{$stats['num_cached_keys']},{$free_keys},0],

  hits: [{$stats['hits']},{$stats['misses']},0]

};

EOB;

?>

var width = 600,

    height = 400,

    radius = Math.min(width, height) / 2;

var color = d3.scale.category20();

var pie = d3.layout.pie()

    .sort(null);


var arc = d3.svg.arc()

    .innerRadius(radius - 20)

    .outerRadius(radius - 50);

var svg = d3.select("#graph").append("svg")

    .attr("width", width)

    .attr("height", height)

  .append("g")

    .attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");


var path = svg.selectAll("path")

    .data(pie(dataset.memory))

  .enter().append("path")

    .attr("fill", function(d, i) { return color(i); })

    .attr("d", arc)

    .each(function(d) { this._current = d; }); // store the initial values


d3.selectAll("input").on("change", change);

set_text("memory");

function set_text(t) {

  if(t=="memory") {

    d3.select("#stats").html(

      "<table><tr><th style='background:#1f77b4;' align=right>Used</th><td align=right><?php echo size_for_humans($mem['used_memory'])?></td></tr>"+

      "<tr><th style='background:#aec7e8;' align=right>Free</th><td align=right><?php echo size_for_humans($mem['free_memory'])?></td></tr>"+

      "<tr><th style='background:#ff7f0e;' align=right>Wasted</th><td align=right><?php echo size_for_humans($mem['wasted_memory'])?></td></tr>"+

      "<tr><th style='background:#ff7f0e;'> </th><td align=right><?php echo number_format($mem['current_wasted_percentage'],2)?>%</td></tr></table>"

    );

  } else if(t=="keys") {

    d3.select("#stats").html(

      "<table><tr><th style='background:#1f77b4;'>Cached keys</th><td align=right>"+dataset[t][0]+"</td></tr>"+

      "<tr><th style='background:#aec7e8;'>Free Keys</th><td align=right>"+dataset[t][1]+"</td></tr></table>"

    );

  } else if(t=="hits") {

    d3.select("#stats").html(

      "<table><tr><th style='background:#1f77b4;' align=right>Cache Hits</th><td align=right>"+dataset[t][0]+"</td></tr>"+

      "<tr><th style='background:#aec7e8;' align=right>Misses</th><td align=right>"+dataset[t][1]+"</td></tr></table>"

    );

  }

}

function change() {

  path = path.data(pie(dataset[this.value])); // update the data

  path.transition().duration(750).attrTween("d", arcTween); // redraw the arcs

  set_text(this.value);

}

function arcTween(a) {

  var i = d3.interpolate(this._current, a);

  this._current = i(0);

  return function(t) {

    return arc(i(t));

  };

}

</script>

</body>

</html>  

0人推荐
随时随地看视频
慕课网APP