백엔드 개발 PHP7 Linux 환경에서 PHP7.0을 설치하는 방법

Linux 환경에서 PHP7.0을 설치하는 방법

May 20, 2021 am 09:27 AM
php7

이 글에서는 Linux 환경에서 PHP7.0을 설치하는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

Linux 환경에서 PHP7.0을 설치하는 방법

PHP7과 HHVM의 비교

실제 시나리오에서 PHP7의 성능은 실제로 HHVM과 동일하며 일부 시나리오에서는 HHVM을 초과하기도 합니다. HHVM의 운영 및 유지 관리는 복잡하며 다중 스레드 모델입니다. 즉, 스레드로 인해 충돌이 발생하면 전체 서비스가 중단되고 자동으로 다시 시작되지 않습니다. 또한 JIT를 사용하는데, 이는 다시 시작한 후 예열이 필요하다는 것을 의미합니다. 예열하지 않으면 성능이 저하됩니다. 게다가 멀티스레드 모델은 디버깅이 어려워 안정성을 추구하는 웹 서비스에는 매우 부적합하다.

Nginx 및 PHP7.0 이전 버전은 다음 기사를 참조할 수 있습니다: Linux 환경 Nginx 설치 및 디버깅 및 PHP 설치

PHP7.0의 공식 버전은 2015년 11월쯤 출시되었습니다. 현재 PHP7.0.2 버전입니다. 2015년 8월 php7의 첫 번째 베타 버전으로 시작하여 현재 정식 버전이 출시되었습니다.

linux 버전: 64비트 CentOS 6.6

Nginx 버전: nginx1.8.0

php 버전: php-7.0.2

Download

# wget  http://php.net/get/php-7.0.2.tar.gz/from/a/mirror
로그인 후 복사

설치하기 전에 설치 도움말 파일을 읽어보는 것이 좋습니다. install

# tar zxvf php-7.0.2.tar.gz
# cd php-7.0.2
로그인 후 복사

먼저 설치 도움말을 확인하세요

# ./configure   --help
# ./configure --prefix=/usr/local/php \
 --with-curl \
 --with-freetype-dir \
 --with-gd \
 --with-gettext \
 --with-iconv-dir \
 --with-kerberos \
 --with-libdir=lib64 \
 --with-libxml-dir \
 --with-mysqli \
 --with-openssl \
 --with-pcre-regex \
 --with-pdo-mysql \
 --with-pdo-sqlite \
 --with-pear \
 --with-png-dir \
 --with-xmlrpc \
 --with-xsl \
 --with-zlib \
 --enable-fpm \
 --enable-bcmath \
 --enable-libxml \
 --enable-inline-optimization \
 --enable-gd-native-ttf \
 --enable-mbregex \
 --enable-mbstring \
 --enable-opcache \
 --enable-pcntl \
 --enable-shmop \
 --enable-soap \
 --enable-sockets \
 --enable-sysvsem \
 --enable-xml \
 --enable-zip
로그인 후 복사

구성이 잘못된 경우 필요한 모듈을 직접 설치해야 하며, 종속 라이브러리를 함께 설치하려면 직접 yum

# yum -y install libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel mysql pcre-devel
로그인 후 복사

참고: 구성할 수 없는 구성이 여러 가지 있습니다. php7beta3을 설치할 때 yum을 해야 합니다. 이제 php- 7.0.2에서는 더 이상 그렇지 않습니다.

# yum -y install curl-devel
# yum -y install libxslt-devel
로그인 후 복사

컴파일 및 설치

# make &&  make install
로그인 후 복사

구성 파일

#  cp php.ini-development /usr/local/php/lib/php.ini
# 
 cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf # 
 cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf
# 
 cp -R ./sapi/fpm/php-fpm /etc/init.d/php-fpm
로그인 후 복사

주의할 점은 php7의 www.conf 구성 파일에서 phpfpm의 포트 번호와 기타 정보를 구성한다는 점입니다. 기본 포트 번호 9000을 수정하면, 그런 다음 nginx 구성을 변경해야 합니다

Start

#  /etc/init.d/php-fpm
로그인 후 복사

View phpinfo()

php7 및 php5 성능 분석 비교

<?php
//time /usr/local/php5/bin/php search_by_key.php
$a = array();
    for($i=0;$i<600000;$i++){
        $a[$i] = $i;
        }

    foreach($a as $i)
    {
        array_key_exists($i, $a);
    }
?>
로그인 후 복사

600,000개 요소의 배열 생성 , 키를 찾아 확인합니다. 키가 존재하는지 여부를 확인합니다.

PHP 버전 5.4.44

[root@localhost www5.4.44]# time /usr/local/php5.4.44/bin/php search_by_key.php

real 0m0.351s

user 0m0.300s

sys 0m0 .050s

PHP 버전 5.5.28

[root@localhost www]# 시간 /usr/local/php/bin/php search_by_key.php

real 0m0.361s

user 0m0.304s

sys 0m0.05 7s

PHP 버전 7.0.0

[root@localhost www7]# time /usr/local/php7/bin/php search_by_key.php

real 0m0.114s

user 0m0.097s

sys 0m0.017s

php7의 성능이 php5의 3배인 것은 당연합니다!

opcache 구성

공식 웹사이트 주소: http://php.net/opcache


더 나은 성능을 얻으려면 다음 권장 설정을 사용하세요.

opcache.memory_consumption=128
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=4000
opcache.revalidate_freq=60
opcache.fast_shutdown=1
opcache.enable_cli=1
로그인 후 복사

opcache.save_comments를 비활성화하고 opcache.enable_file_override를 활성화할 수도 있습니다. 위의 구성은 프로덕션 환경에서 사용하기 전에 엄격하게 테스트되어야 한다는 점을 기억해야 합니다. 위 구성에는 알려진 문제가 있으므로 일부 프레임워크 및 애플리케이션, 특히 주석 주석을 사용하는 문서가 있는 경우 예외가 발생합니다.

vim /usr/local/php7/etc/php.ini
로그인 후 복사

# Join

Restart

# killall php-fpm
#  /etc/init.d/php-fpm
로그인 후 복사

위 그림이 선명하지 않다면 글 마지막에 있는 Opcache 상태 테스트 코드를 이용하시면 됩니다 (https://gist.github.com/ck-on) /4959032) 데모용:




Opcache 상태 테스트 코드(https://gist.github.com/ck-on/4959032) 데모용:

<?php
/*
OCP - Opcache Control Panel (aka Zend Optimizer+ Control Panel for PHP)
Author: _ck_ (with contributions by GK, stasilok)
Version: 0.1.6
Free for any kind of use or modification, I am not responsible for anything, please share your improvements
 
* revision history
0.1.6 2013-04-12 moved meta to footer so graphs can be higher and reduce clutter
0.1.5 2013-04-12 added graphs to visualize cache state, please report any browser/style bugs
0.1.4 2013-04-09 added "recheck" to update files when using large revalidate_freq (or validate_timestamps=Off)
0.1.3 2013-03-30 show host and php version, can bookmark with hashtag ie. #statistics - needs new layout asap
0.1.2 2013-03-25 show optimization levels, number formatting, support for start_time in 7.0.2
0.1.1 2013-03-18 today Zend completely renamed Optimizer+ to OPcache, adjusted OCP to keep working
0.1.0 2013-03-17 added group/sort indicators, replaced "accelerator_" functions with "opcache_"
0.0.6 2013-03-16 transition support as Zend renames product and functions for PHP 5.5 (stasilok)
0.0.5 2013-03-10 added refresh button (GK)
0.0.4 2013-02-18 added file grouping and sorting (click on headers) - code needs cleanup but gets the job done
0.0.2 2013-02-14 first public release
 
* known problems/limitations:
Unlike APC, the Zend OPcache API
- cannot determine when a file was put into the cache
- cannot change settings on the fly
- cannot protect opcache functions by restricting execution to only specific scripts/paths
 
* todo:
Extract variables for prefered ordering and better layout instead of just dumping into tables
File list filter
 
*/
 
// ini_set(&#39;display_errors&#39;,1); error_reporting(-1);
if ( count(get_included_files())>1 || php_sapi_name()==&#39;cli&#39; || empty($_SERVER[&#39;REMOTE_ADDR&#39;]) ) { die; } // weak block against indirect access
 
$time=time();
define(&#39;CACHEPREFIX&#39;,function_exists(&#39;opcache_reset&#39;)?&#39;opcache_&#39;:(function_exists(&#39;accelerator_reset&#39;)?&#39;accelerator_&#39;:&#39;&#39;));
 
if ( !empty($_GET[&#39;RESET&#39;]) ) {	
if ( function_exists(CACHEPREFIX.&#39;reset&#39;) ) { call_user_func(CACHEPREFIX.&#39;reset&#39;); }
header( &#39;Location: &#39;.str_replace(&#39;?&#39;.$_SERVER[&#39;QUERY_STRING&#39;],&#39;&#39;,$_SERVER[&#39;REQUEST_URI&#39;]) );
exit;
}
 
if ( !empty($_GET[&#39;RECHECK&#39;]) ) {
if ( function_exists(CACHEPREFIX.&#39;invalidate&#39;) ) {
$recheck=trim($_GET[&#39;RECHECK&#39;]); $files=call_user_func(CACHEPREFIX.&#39;get_status&#39;);
if (!empty($files[&#39;scripts&#39;])) {
foreach ($files[&#39;scripts&#39;] as $file=>$value) {
if ( $recheck===&#39;1&#39; || strpos($file,$recheck)===0 ) call_user_func(CACHEPREFIX.&#39;invalidate&#39;,$file);
}
}
header( &#39;Location: &#39;.str_replace(&#39;?&#39;.$_SERVER[&#39;QUERY_STRING&#39;],&#39;&#39;,$_SERVER[&#39;REQUEST_URI&#39;]) );
} else { echo &#39;Sorry, this feature requires Zend Opcache newer than April 8th 2013&#39;; }
exit;
}
 
?><!DOCTYPE html>
<html>
<head>
<title>OCP - Opcache Control Panel</title>
<meta name="ROBOTS" content="NOINDEX,NOFOLLOW,NOARCHIVE" />
 
<style type="text/css">
body {background-color: #fff; color: #000;}
body, td, th, h1, h2 {font-family: sans-serif;}
pre {margin: 0px; font-family: monospace;}
a:link,a:visited {color: #000099; text-decoration: none;}
a:hover {text-decoration: underline;}
table {border-collapse: collapse; width: 600px; }
.center {text-align: center;}
.center table { margin-left: auto; margin-right: auto; text-align: left;}
.center th { text-align: center !important; }
.middle {vertical-align:middle;}
td, th { border: 1px solid #000; font-size: 75%; vertical-align: baseline; padding: 3px; }
h1 {font-size: 150%;}
h2 {font-size: 125%;}
.p {text-align: left;}
.e {background-color: #ccccff; font-weight: bold; color: #000; width:50%; white-space:nowrap;}
.h {background-color: #9999cc; font-weight: bold; color: #000;}
.v {background-color: #cccccc; color: #000;}
.vr {background-color: #cccccc; text-align: right; color: #000; white-space: nowrap;}
.b {font-weight:bold;}
.white, .white a {color:#fff;}
img {float: right; border: 0px;}
hr {width: 600px; background-color: #cccccc; border: 0px; height: 1px; color: #000;}
.meta, .small {font-size: 75%; }
.meta {margin: 2em 0;}
.meta a, th a {padding: 10px; white-space:nowrap; }
.buttons {margin:0 0 1em;}
.buttons a {margin:0 15px; background-color: #9999cc; color:#fff; text-decoration:none; padding:1px; border:1px solid #000; display:inline-block; width:5em; text-align:center;}
#files td.v a {font-weight:bold; color:#9999cc; margin:0 10px 0 5px; text-decoration:none; font-size:120%;}
#files td.v a:hover {font-weight:bold; color:#ee0000;}
.graph {display:inline-block; width:145px; margin:1em 0 1em 1px; border:0; vertical-align:top;}
.graph table {width:100%; height:150px; border:0; padding:0; margin:5px 0 0 0; position:relative;}
.graph td {vertical-align:middle; border:0; padding:0 0 0 5px;}
.graph .bar {width:25px; text-align:right; padding:0 2px; color:#fff;}
.graph .total {width:34px; text-align:center; padding:0 5px 0 0;}
.graph .total p {border:1px dashed #888; border-right:0; height:99%; width:12px; position:absolute; bottom:0; left:17px; z-index:-1;}
.graph .total span {background:#fff; font-weight:bold;}
.graph .actual {text-align:right; font-weight:bold; padding:0 5px 0 0;}
.graph .red {background:#ee0000;}
.graph .green {background:#00cc00;}
.graph .brown {background:#8B4513;}
</style>
<!--[if lt IE 9]><script type="text/javascript" defer="defer">
window.οnlοad=function(){var i,t=document.getElementsByTagName(&#39;table&#39;);for(i=0;i<t.length;i++){if(t[i].parentNode.className==&#39;graph&#39;)t[i].style.height=150-(t[i].clientHeight-150)+&#39;px&#39;;}}
</script><![endif]-->
</head>
 
<body>
<p class="center">
 
<h1><a href="?">Opcache Control Panel</a></h1>
 
<p class="buttons">
<a href="?ALL=1">Details</a>
<a href="?FILES=1&GROUP=2&SORT=3">Files</a>
<a href="?RESET=1" οnclick="return confirm(&#39;RESET cache ?&#39;)">Reset</a>
<?php if ( function_exists(CACHEPREFIX.&#39;invalidate&#39;) ) { ?>
<a href="?RECHECK=1" οnclick="return confirm(&#39;Recheck all files in the cache ?&#39;)">Recheck</a>
<?php } ?>
<a href="?" οnclick="window.location.reload(true); return false">Refresh</a>
</p>
 
<?php
 
if ( !function_exists(CACHEPREFIX.&#39;get_status&#39;) ) { echo &#39;<h2>Opcache not detected?</h2>&#39;; die; }
 
if ( !empty($_GET[&#39;FILES&#39;]) ) { echo &#39;<h2>files cached</h2>&#39;; files_display(); echo &#39;</p></body></html>&#39;; exit; }
 
if ( !(isset($_REQUEST[&#39;GRAPHS&#39;]) && !$_REQUEST[&#39;GRAPHS&#39;]) && CACHEPREFIX==&#39;opcache_&#39;) { graphs_display(); if ( !empty($_REQUEST[&#39;GRAPHS&#39;]) ) { exit; } }
 
ob_start(); phpinfo(8); $phpinfo = ob_get_contents(); ob_end_clean(); // some info is only available via phpinfo? sadly buffering capture has to be used
if ( !preg_match( &#39;/module\_Zend (Optimizer\+|OPcache).+?(\<table[^>]*\>.+?\<\/table\>).+?(\<table[^>]*\>.+?\<\/table\>)/s&#39;, $phpinfo, $opcache) ) { } // todo
 
if ( function_exists(CACHEPREFIX.&#39;get_configuration&#39;) ) { echo &#39;<h2>general</h2>&#39;; $configuration=call_user_func(CACHEPREFIX.&#39;get_configuration&#39;); }
 
$host=function_exists(&#39;gethostname&#39;)?@gethostname():@php_uname(&#39;n&#39;); if (empty($host)) { $host=empty($_SERVER[&#39;SERVER_NAME&#39;])?$_SERVER[&#39;HOST_NAME&#39;]:$_SERVER[&#39;SERVER_NAME&#39;]; }
$version=array(&#39;Host&#39;=>$host);
$version[&#39;PHP Version&#39;]=&#39;PHP &#39;.(defined(&#39;PHP_VERSION&#39;)?PHP_VERSION:&#39;???&#39;).&#39; &#39;.(defined(&#39;PHP_SAPI&#39;)?PHP_SAPI:&#39;&#39;).&#39; &#39;.(defined(&#39;PHP_OS&#39;)?&#39; &#39;.PHP_OS:&#39;&#39;);
$version[&#39;Opcache Version&#39;]=empty($configuration[&#39;version&#39;][&#39;version&#39;])?&#39;???&#39;:$configuration[&#39;version&#39;][CACHEPREFIX.&#39;product_name&#39;].&#39; &#39;.$configuration[&#39;version&#39;][&#39;version&#39;];
print_table($version);
 
if ( !empty($opcache[2]) ) { echo preg_replace(&#39;/\<tr\>\<td class\="e"\>[^>]+\<\/td\>\<td class\="v"\>[0-9\,\. ]+\<\/td\>\<\/tr\>/&#39;,&#39;&#39;,$opcache[2]); }
 
if ( function_exists(CACHEPREFIX.&#39;get_status&#39;) && $status=call_user_func(CACHEPREFIX.&#39;get_status&#39;) ) {
$uptime=array();
if ( !empty($status[CACHEPREFIX.&#39;statistics&#39;][&#39;start_time&#39;]) ) {
$uptime[&#39;uptime&#39;]=time_since($time,$status[CACHEPREFIX.&#39;statistics&#39;][&#39;start_time&#39;],1,&#39;&#39;);
}
if ( !empty($status[CACHEPREFIX.&#39;statistics&#39;][&#39;last_restart_time&#39;]) ) {
$uptime[&#39;last_restart&#39;]=time_since($time,$status[CACHEPREFIX.&#39;statistics&#39;][&#39;last_restart_time&#39;]);
}
if (!empty($uptime)) {print_table($uptime);}
if ( !empty($status[&#39;cache_full&#39;]) ) { $status[&#39;memory_usage&#39;][&#39;cache_full&#39;]=$status[&#39;cache_full&#39;]; }
echo &#39;<h2 id="memory">memory</h2>&#39;;
print_table($status[&#39;memory_usage&#39;]);
unset($status[CACHEPREFIX.&#39;statistics&#39;][&#39;start_time&#39;],$status[CACHEPREFIX.&#39;statistics&#39;][&#39;last_restart_time&#39;]);
echo &#39;<h2 id="statistics">statistics</h2>&#39;;
print_table($status[CACHEPREFIX.&#39;statistics&#39;]);
}
 
if ( empty($_GET[&#39;ALL&#39;]) ) { meta_display(); exit; }
if ( !empty($configuration[&#39;blacklist&#39;]) ) { echo &#39;<h2 id="blacklist">blacklist</h2>&#39;; print_table($configuration[&#39;blacklist&#39;]); }
 
if ( !empty($opcache[3]) ) { echo &#39;<h2 id="runtime">runtime</h2>&#39;; echo $opcache[3]; }
 
$name=&#39;zend opcache&#39;; $functions=get_extension_funcs($name);
if (!$functions) { $name=&#39;zend optimizer+&#39;; $functions=get_extension_funcs($name); }
if ($functions) { echo &#39;<h2 id="functions">functions</h2>&#39;; print_table($functions); } else { $name=&#39;&#39;; }
 
$level=trim(CACHEPREFIX,&#39;_&#39;).&#39;.optimization_level&#39;;
if (isset($configuration[&#39;directives&#39;][$level])) {
echo &#39;<h2 id="optimization">optimization levels</h2>&#39;;	
$levelset=strrev(base_convert($configuration[&#39;directives&#39;][$level], 10, 2));
$levels=array(
1=>&#39;<a href="http://wikipedia.org/wiki/Common_subexpression_elimination">Constants subexpressions elimination</a> (CSE) true, false, null, etc.<br />Optimize series of ADD_STRING / ADD_CHAR<br />Convert CAST(IS_BOOL,x) into BOOL(x)<br />Convert <a href="http://www.php.net/manual/internals2.opcodes.init-fcall-by-name.php">INIT_FCALL_BY_NAME</a> + <a href="http://www.php.net/manual/internals2.opcodes.do-fcall-by-name.php">DO_FCALL_BY_NAME</a> into <a href="http://www.php.net/manual/internals2.opcodes.do-fcall.php">DO_FCALL</a>&#39;,
2=>&#39;Convert constant operands to expected types<br />Convert conditional <a href="http://php.net/manual/internals2.opcodes.jmp.php">JMP</a> with constant operands<br />Optimize static <a href="http://php.net/manual/internals2.opcodes.brk.php">BRK</a> and <a href="<a href="http://php.net/manual/internals2.opcodes.cont.php">CONT</a>&#39;,
3=>&#39;Convert $a = $a + expr into $a += expr<br />Convert $a++ into ++$a<br />Optimize series of <a href="http://php.net/manual/internals2.opcodes.jmp.php">JMP</a>&#39;,
4=>&#39;PRINT and ECHO optimization (<a href="https://github.com/zend-dev/ZendOptimizerPlus/issues/73">defunct</a>)&#39;,
5=>&#39;Block Optimization - most expensive pass<br />Performs many different optimization patterns based on <a href="http://wikipedia.org/wiki/Control_flow_graph">control flow graph</a> (CFG)&#39;,
9=>&#39;Optimize <a href="http://wikipedia.org/wiki/Register_allocation">register allocation</a> (allows re-usage of temporary variables)&#39;,
10=>&#39;Remove NOPs&#39;
);
echo &#39;<table width="600" border="0" cellpadding="3"><tbody><tr class="h"><th>Pass</th><th>Description</th></tr>&#39;;
foreach ($levels as $pass=>$description) {
$disabled=substr($levelset,$pass-1,1)!==&#39;1&#39; || $pass==4 ? &#39; white&#39;:&#39;&#39;;
echo &#39;<tr><td class="v center middle&#39;.$disabled.&#39;">&#39;.$pass.&#39;</td><td class="v&#39;.$disabled.&#39;">&#39;.$description.&#39;</td></tr>&#39;;
}
echo &#39;</table>&#39;;
}
 
if ( isset($_GET[&#39;DUMP&#39;]) ) {
if ($name) { echo &#39;<h2 id="ini">ini</h2>&#39;; print_table(ini_get_all($name,true)); }
foreach ($configuration as $key=>$value) { echo &#39;<h2>&#39;,$key,&#39;</h2>&#39;; print_table($configuration[$key]); }
exit;
}
 
meta_display();
 
echo &#39;</p></body></html>&#39;;
 
exit;
 
function time_since($time,$original,$extended=0,$text=&#39;ago&#39;) {	
$time = $time - $original;
$day = $extended? floor($time/86400) : round($time/86400,0);
$amount=0; $unit=&#39;&#39;;
if ( $time < 86400) {
if ( $time < 60)	{ $amount=$time; $unit=&#39;second&#39;; }
elseif ( $time < 3600) { $amount=floor($time/60); $unit=&#39;minute&#39;; }
else	{ $amount=floor($time/3600); $unit=&#39;hour&#39;; }	
}
elseif ( $day < 14) { $amount=$day; $unit=&#39;day&#39;; }
elseif ( $day < 56) { $amount=floor($day/7); $unit=&#39;week&#39;; }
elseif ( $day < 672) { $amount=floor($day/30); $unit=&#39;month&#39;; }
else {	$amount=intval(2*($day/365))/2; $unit=&#39;year&#39;; }
if ( $amount!=1) {$unit.=&#39;s&#39;;}	
if ($extended && $time>60) { $text=&#39; and &#39;.time_since($time,$time<86400?($time<3600?$amount*60:$amount*3600):$day*86400,0,&#39;&#39;).$text; }
return $amount.&#39; &#39;.$unit.&#39; &#39;.$text;
}
 
function print_table($array,$headers=false) {
if ( empty($array) || !is_array($array) ) {return;}
echo &#39;<table border="0" cellpadding="3" width="600">&#39;;
if (!empty($headers)) {
if (!is_array($headers)) {$headers=array_keys(reset($array));}
echo &#39;<tr class="h">&#39;;
foreach ($headers as $value) { echo &#39;<th>&#39;,$value,&#39;</th>&#39;; }
echo &#39;</tr>&#39;;
}
foreach ($array as $key=>$value) {
echo &#39;<tr>&#39;;
if ( !is_numeric($key) ) {
$key=ucwords(str_replace(&#39;_&#39;,&#39; &#39;,$key));
echo &#39;<td class="e">&#39;,$key,&#39;</td>&#39;;
if ( is_numeric($value) ) {
if ( $value>1048576) { $value=round($value/1048576,1).&#39;M&#39;; }
elseif ( is_float($value) ) { $value=round($value,1); }
}
}
if ( is_array($value) ) {
foreach ($value as $column) {
echo &#39;<td class="v">&#39;,$column,&#39;</td>&#39;;
}
echo &#39;</tr>&#39;;
}
else { echo &#39;<td class="v">&#39;,$value,&#39;</td></tr>&#39;; }
}
echo &#39;</table>&#39;;
}
 
function files_display() {	
$status=call_user_func(CACHEPREFIX.&#39;get_status&#39;);
if ( empty($status[&#39;scripts&#39;]) ) {return;}
if ( isset($_GET[&#39;DUMP&#39;]) ) { print_table($status[&#39;scripts&#39;]); exit;}
$time=time(); $sort=0;
$nogroup=preg_replace(&#39;/\&?GROUP\=[\-0-9]+/&#39;,&#39;&#39;,$_SERVER[&#39;REQUEST_URI&#39;]);
$nosort=preg_replace(&#39;/\&?SORT\=[\-0-9]+/&#39;,&#39;&#39;,$_SERVER[&#39;REQUEST_URI&#39;]);
$group=empty($_GET[&#39;GROUP&#39;])?0:intval($_GET[&#39;GROUP&#39;]); if ( $group<0 || $group>9) { $group=1;}
$groupset=array_fill(0,9,&#39;&#39;); $groupset[$group]=&#39; class="b" &#39;;
echo &#39;<p class="meta">
<a &#39;,$groupset[0],&#39;href="&#39;,$nogroup,&#39;">ungroup</a> |
<a &#39;,$groupset[1],&#39;href="&#39;,$nogroup,&#39;&GROUP=1">1</a> |
<a &#39;,$groupset[2],&#39;href="&#39;,$nogroup,&#39;&GROUP=2">2</a> |
<a &#39;,$groupset[3],&#39;href="&#39;,$nogroup,&#39;&GROUP=3">3</a> |
<a &#39;,$groupset[4],&#39;href="&#39;,$nogroup,&#39;&GROUP=4">4</a> |
<a &#39;,$groupset[5],&#39;href="&#39;,$nogroup,&#39;&GROUP=5">5</a>
</p>&#39;;
if ( !$group ) { $files =& $status[&#39;scripts&#39;]; }
else {	
$files=array();
foreach ($status[&#39;scripts&#39;] as $data) {
if ( preg_match(&#39;@^[/]([^/]+[/]){&#39;.$group.&#39;}@&#39;,$data[&#39;full_path&#39;],$path) ) {
if ( empty($files[$path[0]])) { $files[$path[0]]=array(&#39;full_path&#39;=>&#39;&#39;,&#39;files&#39;=>0,&#39;hits&#39;=>0,&#39;memory_consumption&#39;=>0,&#39;last_used_timestamp&#39;=>&#39;&#39;,&#39;timestamp&#39;=>&#39;&#39;); }
$files[$path[0]][&#39;full_path&#39;]=$path[0];
$files[$path[0]][&#39;files&#39;]++;
$files[$path[0]][&#39;memory_consumption&#39;]+=$data[&#39;memory_consumption&#39;];	
$files[$path[0]][&#39;hits&#39;]+=$data[&#39;hits&#39;];
if ( $data[&#39;last_used_timestamp&#39;]>$files[$path[0]][&#39;last_used_timestamp&#39;]) {$files[$path[0]][&#39;last_used_timestamp&#39;]=$data[&#39;last_used_timestamp&#39;];}
if ( $data[&#39;timestamp&#39;]>$files[$path[0]][&#39;timestamp&#39;]) {$files[$path[0]][&#39;timestamp&#39;]=$data[&#39;timestamp&#39;];}	
}	
}
}
if ( !empty($_GET[&#39;SORT&#39;]) ) {
$keys=array(
&#39;full_path&#39;=>SORT_STRING,
&#39;files&#39;=>SORT_NUMERIC,
&#39;memory_consumption&#39;=>SORT_NUMERIC,
&#39;hits&#39;=>SORT_NUMERIC,
&#39;last_used_timestamp&#39;=>SORT_NUMERIC,
&#39;timestamp&#39;=>SORT_NUMERIC
);
$titles=array(&#39;&#39;,&#39;path&#39;,$group?&#39;files&#39;:&#39;&#39;,&#39;size&#39;,&#39;hits&#39;,&#39;last used&#39;,&#39;created&#39;);
$offsets=array_keys($keys);
$key=intval($_GET[&#39;SORT&#39;]);
$direction=$key>0?1:-1;
$key=abs($key)-1;
$key=isset($offsets[$key])&&!($key==1&&empty($group))?$offsets[$key]:reset($offsets);
$sort=array_search($key,$offsets)+1;
$sortflip=range(0,7); $sortflip[$sort]=-$direction*$sort;
if ( $keys[$key]==SORT_STRING) {$direction=-$direction; }
$arrow=array_fill(0,7,&#39;&#39;); $arrow[$sort]=$direction>0?&#39; ▼&#39;:&#39; ▲&#39;;
$direction=$direction>0?SORT_DESC:SORT_ASC;
$column=array(); foreach ($files as $data) { $column[]=$data[$key]; }
array_multisort($column, $keys[$key], $direction, $files);
}
 
echo &#39;<table border="0" cellpadding="3" width="960" id="files">
<tr class="h">&#39;;
foreach ($titles as $column=>$title) {
if ($title) echo &#39;<th><a href="&#39;,$nosort,&#39;&SORT=&#39;,$sortflip[$column],&#39;">&#39;,$title,$arrow[$column],&#39;</a></th>&#39;;
}
echo &#39; </tr>&#39;;
foreach ($files as $data) {
echo &#39;<tr>
<td class="v" nowrap><a title="recheck" href="?RECHECK=&#39;,rawurlencode($data[&#39;full_path&#39;]),&#39;">x</a>&#39;,$data[&#39;full_path&#39;],&#39;</td>&#39;,
($group?&#39;<td class="vr">&#39;.number_format($data[&#39;files&#39;]).&#39;</td>&#39;:&#39;&#39;),
&#39;<td class="vr">&#39;,number_format(round($data[&#39;memory_consumption&#39;]/1024)),&#39;K</td>&#39;,
&#39;<td class="vr">&#39;,number_format($data[&#39;hits&#39;]),&#39;</td>&#39;,
&#39;<td class="vr">&#39;,time_since($time,$data[&#39;last_used_timestamp&#39;]),&#39;</td>&#39;,
&#39;<td class="vr">&#39;,empty($data[&#39;timestamp&#39;])?&#39;&#39;:time_since($time,$data[&#39;timestamp&#39;]),&#39;</td>
</tr>&#39;;
}
echo &#39;</table>&#39;;
}
 
function graphs_display() {
$graphs=array();
$colors=array(&#39;green&#39;,&#39;brown&#39;,&#39;red&#39;);
$primes=array(223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987);
$configuration=call_user_func(CACHEPREFIX.&#39;get_configuration&#39;);
$status=call_user_func(CACHEPREFIX.&#39;get_status&#39;);
 
$graphs[&#39;memory&#39;][&#39;total&#39;]=$configuration[&#39;directives&#39;][&#39;opcache.memory_consumption&#39;];
$graphs[&#39;memory&#39;][&#39;free&#39;]=$status[&#39;memory_usage&#39;][&#39;free_memory&#39;];
$graphs[&#39;memory&#39;][&#39;used&#39;]=$status[&#39;memory_usage&#39;][&#39;used_memory&#39;];
$graphs[&#39;memory&#39;][&#39;wasted&#39;]=$status[&#39;memory_usage&#39;][&#39;wasted_memory&#39;];
 
$graphs[&#39;keys&#39;][&#39;total&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;max_cached_keys&#39;];	
foreach ($primes as $prime) { if ($prime>=$graphs[&#39;keys&#39;][&#39;total&#39;]) { $graphs[&#39;keys&#39;][&#39;total&#39;]=$prime; break;} }
$graphs[&#39;keys&#39;][&#39;free&#39;]=$graphs[&#39;keys&#39;][&#39;total&#39;]-$status[CACHEPREFIX.&#39;statistics&#39;][&#39;num_cached_keys&#39;];
$graphs[&#39;keys&#39;][&#39;scripts&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;num_cached_scripts&#39;];
$graphs[&#39;keys&#39;][&#39;wasted&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;num_cached_keys&#39;]-$status[CACHEPREFIX.&#39;statistics&#39;][&#39;num_cached_scripts&#39;];
 
$graphs[&#39;hits&#39;][&#39;total&#39;]=0;
$graphs[&#39;hits&#39;][&#39;hits&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;hits&#39;];
$graphs[&#39;hits&#39;][&#39;misses&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;misses&#39;];
$graphs[&#39;hits&#39;][&#39;blacklist&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;blacklist_misses&#39;];
$graphs[&#39;hits&#39;][&#39;total&#39;]=array_sum($graphs[&#39;hits&#39;]);
 
$graphs[&#39;restarts&#39;][&#39;total&#39;]=0;
$graphs[&#39;restarts&#39;][&#39;manual&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;manual_restarts&#39;];
$graphs[&#39;restarts&#39;][&#39;keys&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;hash_restarts&#39;];
$graphs[&#39;restarts&#39;][&#39;memory&#39;]=$status[CACHEPREFIX.&#39;statistics&#39;][&#39;oom_restarts&#39;];
$graphs[&#39;restarts&#39;][&#39;total&#39;]=array_sum($graphs[&#39;restarts&#39;]);
 
foreach ( $graphs as $caption=>$graph) {
echo &#39;<p class="graph"><p class="h">&#39;,$caption,&#39;</p><table border="0" cellpadding="0" cellspacing="0">&#39;;	
foreach ($graph as $label=>$value) {
if ($label==&#39;total&#39;) { $key=0; $total=$value; $totaldisplay=&#39;<td rowspan="3" class="total"><span>&#39;.($total>999999?round($total/1024/1024).&#39;M&#39;:($total>9999?round($total/1024).&#39;K&#39;:$total)).&#39;</span><p></p></td>&#39;; continue;}
$percent=$total?floor($value*100/$total):&#39;&#39;; $percent=!$percent||$percent>99?&#39;&#39;:$percent.&#39;%&#39;;
echo &#39;<tr>&#39;,$totaldisplay,&#39;<td class="actual">&#39;, ($value>999999?round($value/1024/1024).&#39;M&#39;:($value>9999?round($value/1024).&#39;K&#39;:$value)),&#39;</td><td class="bar &#39;,$colors[$key],&#39;" height="&#39;,$percent,&#39;">&#39;,$percent,&#39;</td><td>&#39;,$label,&#39;</td></tr>&#39;;
$key++; $totaldisplay=&#39;&#39;;
}
echo &#39;</table></p>&#39;,"\n";
}
}
 
function meta_display() {
?>
<p class="meta">
<a href="http://files.zend.com/help/Zend-Server-6/content/zendoptimizerplus.html">directives guide</a> |
<a href="http://files.zend.com/help/Zend-Server-6/content/zend_optimizer+_-_php_api.htm">functions guide</a> |
<a href="https://wiki.php.net/rfc/optimizerplus">wiki.php.net</a> |
<a href="http://pecl.php.net/package/ZendOpcache">pecl</a> |
<a href="https://github.com/zend-dev/ZendOptimizerPlus/">Zend source</a> |
<a href="https://gist.github.com/ck-on/4959032/?ocp.php">OCP latest</a>
</p>
<?php
}
로그인 후 복사

추천 학습: php 비디오 튜토리얼

위 내용은 Linux 환경에서 PHP7.0을 설치하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

php7.0에 mongo 확장을 설치하는 방법 php7.0에 mongo 확장을 설치하는 방법 Nov 21, 2022 am 10:25 AM

php7.0에서 mongo 확장을 설치하는 방법: 1. mongodb 사용자 그룹 및 사용자를 생성합니다. 2. mongodb 소스 코드 패키지를 다운로드하고 소스 코드 패키지를 "/usr/local/src/" 디렉터리에 넣습니다. "src/" 디렉터리를 입력합니다. 4. 소스 코드 패키지의 압축을 풉니다. 5. mongodb 파일 디렉터리를 생성합니다. 6. "mongodb/" 디렉터리에 파일을 복사합니다. 7. mongodb 구성 파일을 생성하고 구성을 수정합니다.

php7에서 tcp 포트가 작동하지 않는 것을 감지했을 때 문제를 해결하는 방법 php7에서 tcp 포트가 작동하지 않는 것을 감지했을 때 문제를 해결하는 방법 Mar 22, 2023 am 09:30 AM

php5에서는 fsockopen() 함수를 사용하여 TCP 포트를 감지할 수 있습니다. 이 기능은 네트워크 연결을 열고 일부 네트워크 통신을 수행하는 데 사용할 수 있습니다. 그러나 php7에서는 fsockopen() 함수에 포트를 열 수 없거나 서버에 연결할 수 없는 등의 몇 가지 문제가 발생할 수 있습니다. 이 문제를 해결하기 위해, 우리는 소켓_create() 함수와 소켓_연결() 함수를 사용하여 TCP 포트를 감지할 수 있습니다.

php7.0에 플러그인이 설치되어 있는데 여전히 설치되지 않은 것으로 표시되면 어떻게 해야 합니까? php7.0에 플러그인이 설치되어 있는데 여전히 설치되지 않은 것으로 표시되면 어떻게 해야 합니까? Apr 02, 2024 pm 07:39 PM

PHP 7.0에서 설치된 플러그인이 표시되지 않는 문제를 해결하려면: 플러그인 구성을 확인하고 플러그인을 활성화하세요. 구성 변경 사항을 적용하려면 PHP를 다시 시작하세요. 플러그인 파일 권한이 올바른지 확인하세요. 플러그인이 올바르게 작동하도록 하려면 누락된 종속성을 설치하세요. 다른 모든 단계가 실패하면 PHP를 다시 빌드하세요. 다른 가능한 원인으로는 호환되지 않는 플러그인 버전, 잘못된 버전 로드 또는 PHP 구성 문제 등이 있습니다.

PHP 서버 환경 FAQ 가이드: 일반적인 문제를 신속하게 해결 PHP 서버 환경 FAQ 가이드: 일반적인 문제를 신속하게 해결 Apr 09, 2024 pm 01:33 PM

PHP 서버 환경에 대한 일반적인 솔루션에는 올바른 PHP 버전이 설치되어 있는지, 관련 파일이 모듈 디렉터리에 복사되었는지 확인하는 것이 포함됩니다. SELinux를 일시적으로 또는 영구적으로 비활성화합니다. 필요한 확장이 추가되고 올바르게 설정되었는지 확인하려면 PHP.ini를 확인하고 구성하십시오. PHP-FPM 서비스를 시작하거나 다시 시작합니다. 해결 문제에 대해서는 DNS 설정을 확인하세요.

php7.0을 설치하고 배포하는 방법 php7.0을 설치하고 배포하는 방법 Nov 30, 2022 am 09:56 AM

php7.0 설치 및 배포 방법: 1. PHP 공식 웹사이트로 이동하여 로컬 시스템에 해당하는 설치 버전을 다운로드합니다. 2. 다운로드한 zip 파일을 지정된 디렉터리에 추출합니다. 3. 명령줄 창을 열고 다음으로 이동합니다. "E:\php7" 디렉토리 "php -v" 명령을 실행하세요.

시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? 시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? Mar 31, 2025 pm 11:54 PM

시스템이 다시 시작된 후 UnixSocket의 권한을 자동으로 설정하는 방법. 시스템이 다시 시작될 때마다 UnixSocket의 권한을 수정하려면 다음 명령을 실행해야합니다.

Docker 환경에서 PECL을 사용하여 확장자를 설치할 때 오류가 발생하는 이유는 무엇입니까? 그것을 해결하는 방법? Docker 환경에서 PECL을 사용하여 확장자를 설치할 때 오류가 발생하는 이유는 무엇입니까? 그것을 해결하는 방법? Apr 01, 2025 pm 03:06 PM

Docker 환경을 사용할 때 Docker 환경에 Extensions를 설치하기 위해 PECL을 사용하여 오류의 원인 및 솔루션. 종종 일부 두통이 발생합니다 ...

php8과 php7 중 어느 것이 더 낫나요? php8과 php7 중 어느 것이 더 낫나요? Nov 16, 2023 pm 03:09 PM

PHP7과 비교하여 PHP8은 성능, 새로운 기능 및 구문 개선, 유형 시스템, 오류 처리 및 확장 측면에서 몇 가지 장점과 개선 사항을 가지고 있습니다. 그러나 사용할 버전을 선택하는 것은 특정 요구 사항과 프로젝트 상황에 따라 다릅니다. 자세한 소개: 1. 성능 향상, PHP8은 코드 실행 속도를 향상시킬 수 있는 JIT(Just-in-Time) 컴파일러를 도입합니다. 2. 새로운 기능 및 구문 개선, PHP8은 명명된 매개 변수 및 선택적 매개 변수 선언을 지원합니다. 함수 만들기 호출이 더 유연해졌습니다. 익명 클래스, 속성 유형 선언 등이 도입되었습니다.

See all articles