Home >Backend Development >PHP Tutorial >PHP test hidef performance

PHP test hidef performance

墨辰丷
墨辰丷Original
2018-06-11 16:44:151716browse

This article mainly introduces the use of hidef extension instead of define in PHP to improve performance. This article focuses on testing the performance of hidef. It also introduces the installation method and usage examples. Friends in need can refer to the following

Website needs new Add a constant, open the local config.php file, and think of the hidef and apc solutions to improve define performance that were tested a few years ago.
My program has different configurations for the development, testing, and production servers. In terms of constants, I use an array to define all the constants that need to be defined, and then check whether there is an apc_load_constants function. If not, batch define . When using apc, every time you add a constant, you need to modify $key to take effect.

Now after the test and production server php are upgraded to 5.4, the opcode cache uses Zend opcache, and APC is no longer installed. Because the apc user cache is used, I installed apcu additionally, and the usage is exactly the same as apc, so there is no need to change the program at all. However, apcu does not support apc_load_constants and apc_define_constants, so the apc solution cannot be used. I went to the official website and installed the latest version of hidef 0.1.13, stable released on July 12, 2012, more than a year ago.

Written a simple program to test the define time. It takes about 2.8ms to run 1000 times. So for a medium-sized website (for example, PHP runs 10 million times a day), if 25 constants are defined per page, it will take about 10000000*25/1000*2.8=700000ms per day, which is 700 seconds. Using hidef can save almost 700s of PHP running time a day.
Let’s take a look at the reading performance. The test reads a constant 1w times, and the values ​​are all 1, which are 37ms and 0.7ms respectively. So if it is used 10 million times a day and an average of 20 constants are used per page, it will take 740 seconds, while using hidef is 14 seconds, well, another more than 700 seconds.
Saving 1400 seconds of PHP running time a day may be insignificant, but it is always good and worth trying. After all, the chance of defining parameters changing is very small.
When the define parameters need to be modified, modify the configuration file and then reload php-fpm.

For specific installation methods of hidef, please refer to: Installation and use of hidef, a PHP extension that improves define performance

Search for "hidef" in Baidu, and the third place is a copy of my blog post Website: (The installation and use of hidef, a PHP extension that I published to improve define performance, was not found on the first three pages. Obviously, Baidu has some deviations in identifying the original.

Baidu search for "hidef php ", that website ranks first, the second is the official website, and mine is in the third.
gg searches for "hidef php", the first official website, the third is another original article, and mine is in the fourth. Identification of gg Not bad!

360 Search for "hidef php", the first is the copy site, the second is mine, and the third is another original article.
So this article was born, let’s see if it can help It’s okay to rank the first article or this one. 0

Attached is the program sample code of the original configuration constants:

The code is as follows:

if (function_exists('apc_load_constants')) {
            function define_array($key, $arr, $case_sensitive = false) {
                if (!apc_load_constants($key, $case_sensitive)) {
                    apc_define_constants($key, $arr, $case_sensitive);
                }
            }
        } else {
            function define_array($key, $arr, $case_sensitive = false) {
                foreach ($arr as $name => $value) {
                    define($name, $value, $case_sensitive);
                }
            }
        }
        $constants = array(
            'HX'   => 1,
            'BLOG_URL'   => '//www.jb51.net/',
            'WWW_URL'   => '//www.jb51.net/',
        );
        define_array('hx_defined',$constants);


Attached is the code for testing the define speed.

The code is as follows:

<?php
$t1 = microtime(1);
    $constants = array(
        &#39;hx1&#39;       => 1,
        &#39;hx2&#39;       => &#39;2&#39;,
        &#39;hx3&#39;       => &#39;3&#39;,
        &#39;hx4&#39;       => &#39;4&#39;,
        &#39;hx5&#39;       => &#39;5&#39;,
        &#39;hx6&#39;       => &#39;6&#39;,
        &#39;hx7&#39;       => &#39;7&#39;,
        &#39;hx8&#39;       => &#39;8&#39;,
        &#39;hx9&#39;       => &#39;9&#39;,
        &#39;hx10&#39;       => &#39;10&#39;,
    );
    function define_array($key, $arr) {
        foreach ($arr as $name => $value) {
            define($name.$i, $value);
        }
    }
    
    for($i=0;$i<100;$i++) {
        define_array($i,$constants);
    }
    
    
$t2 = microtime(1);
echo ($t2-$t1)*1000;
//读性能
$t1 = microtime(1);
for($i=0;$i<10000;$i++) {
    $t = hx1;
}    
$t2 = microtime(1);
echo &#39; &#39;.($t2-$t1)*1000;
$t1 = microtime(1);
for($i=0;$i<10000;$i++) {
    $t = HX;
}    
$t2 = microtime(1);
echo &#39; &#39;.($t2-$t1)*1000;

Summary: The above is the entire content of this article, I hope it can help everyone learn Helpful.

Related recommendations:

php operations for reading, editing and saving files

How to use php combined with html5 websocket communication

How to implement web service in php

The above is the detailed content of PHP test hidef performance. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn