Сжатие содержимого с помощью PHP ob_start() vs Apache Deflate/Gzip?
Большинство сайтов хотят сжать свой контент, чтобы сэкономить на пропускной способности. Однако, когда дело доходит до серверов Apache, работающих под управлением PHP, есть два способа сделать это: с PHP или с apache. Итак, какой из них быстрее или проще на вашем сервере?
Например, в PHP я запускаю следующую функцию в начале моих страниц, чтобы включить ее:
/**
* Gzip compress page output
* Original function came from wordpress.org
*/
function gzip_compression() {
//If no encoding was given - then it must not be able to accept gzip pages
if( empty($_SERVER['HTTP_ACCEPT_ENCODING']) ) { return false; }
//If zlib is not ALREADY compressing the page - and ob_gzhandler is set
if (( ini_get('zlib.output_compression') == 'On'
OR ini_get('zlib.output_compression_level') > 0 )
OR ini_get('output_handler') == 'ob_gzhandler' ) {
return false;
}
//Else if zlib is loaded start the compression.
if ( extension_loaded( 'zlib' ) AND (strpos($_SERVER['HTTP_ACCEPT_ENCODING'], 'gzip') !== FALSE) ) {
ob_start('ob_gzhandler');
}
}
другой вариант - использовать Apache deflate или gzip (оба они очень близко). Чтобы включить их, вы можете добавить что-то подобное в ваш .htaccess файл.
AddOutputFilterByType DEFLATE text/html text/plain text/xml application/x-httpd-php
Поскольку PHP - это язык сценариев (который должен быть загружен PHP), я бы предположил, что метод apache будет 1) более стабильным и 2) быстрее. Но предположения не имеют большого смысла в реальном мире.
В конце концов, вы бы предположили, что с огромными финансовыми окнами поддержки... мы не поедем туда.
Ответы
Ответ 1
Мы запускаем... много веб-серверов, обрабатывающих 60M/uniques/day. Обычно это не стоит упоминать, но ваш вопрос кажется основанным на опыте.
Мы запускаем это с помощью apache. То, что выходит, на другом конце того же (или достаточно близко, чтобы не иметь значения), независимо от выбранного вами метода.
Мы выбираем apache по нескольким причинам:
- Нулевое обслуживание, мы просто включили его. Никто не должен поддерживать некоторую структуру случая.
- Производительность, на наших серверах тестов, где Apache выполнял работу незначительно лучше.
- Apache применит выходной фильтр ко всему, в отличие от PHP. В некоторых случаях на одном сервере хранятся другие типы контента, мы хотели бы сжать наши .css и .js
Одно предупреждение, некоторые браузеры или другие приложения целенаправленно управляют заголовками клиента, указывающими, что поддерживается сжатие. Некоторые делают это, чтобы облегчить свою работу с точки зрения безопасности на стороне клиента (например, такие приложения, как norton internet security и т.д.). Вы можете либо проигнорировать это, либо попытаться добавить лишние случаи для повторной записи запросов, чтобы выглядеть нормальным (браузеры поддерживают его, приложение или прокси-сервер просто futzed для облегчения своей жизни).
В качестве альтернативы, если вы используете команду flush() для отправки вывода в браузер ранее, и вы применяете сжатие, вам может потребоваться заполнить конец строки пробелом, чтобы убедить сервер отправить данные раньше.