dr.Brain

doctor Brain

мир глазами веб-разработчика

PHP: оптимизация

правила, которые необходимо соблюдать при работе с нагруженными PHP-проектами

dr.Brain

время чтения 3 мин.

Photo by Kenny Eliason on Unsplash

Известно, что оптимизация PHP для высоконагруженных сайтов требует комплексного подхода, включающего высокое качество кода, корректное управление базами данных, верным образом настроенное кэширование, оптимальное взаимодействие с сервером и многие другие параметры.

В предложенном материале подобран обширный список правил, улучшающих работу высоконагруженных PHP-проектов. Каждое правило дополнено практическим примером.

Применяйте кеширование опкодов

Правило: включайте OPcache.

Пример:

; Enable OPcache in php.ini
opcache.enable=1
opcache.memory_consumption=128
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=10000
opcache.revalidate_freq=60

Оптимизируйте запросы к базе данных

Правило: Используйте индексированные столбцы и избегайте избыточной информации в операторах SELECT.

Пример:

-- Instead of SELECT *
SELECT id, name, price FROM products WHERE category_id = 1;

Кешируйте данные

Правило: кешируйте часто используемые данные с помощью Memcached.

Пример:

$memcached = new Memcached();
$memcached->addServer('localhost', 11211);
$key = 'products_list';
$products = $memcached->get($key);

if ($products === FALSE) {
    $products = get_products_from_database(); // Fetch from DB
    $memcached->set($key, $products, 600); // Cache for 10 minutes
}

Применяйте постоянные соединения

Правило: Постоянные подключения к базе данных уменьшают расходование ресурсов.

Пример:

$pdo = new PDO('mysql:host=localhost;dbname=test', 'user', 'password', [
    PDO::ATTR_PERSISTENT => true
]);

Сокращайте количество операций ввода и вывода

Правило: Работая с данными, минимизируйте обращение к файлам.

Пример:

// Avoid repeated file reads
$settings = include('config.php'); // Cache this in a variable if used multiple times

Оптимизируйте конфигурацию PHP

Правило: Проработайте настройки в php.ini

Пример:

memory_limit=256M
max_execution_time=30

Используйте автозагрузчики

Правило: Для эффективной работы с библиотеками пользуйтесь автозагрузчиком Composer

Пример:

require 'vendor/autoload.php'; // Composer's autoloader

// Use classes
$object = new MyClass();

Не забывайте про балансировку нагрузки

Правило: Распределяйте трафик по нескольким серверам. Настройте Nginx

Пример:

ttp {
    upstream backend {
        server backend1.example.com;
        server backend2.example.com;
    }

    server {
        location / {
            proxy_pass http://backend;
        }
    }
}

Используйте асинхронную обработку данных

Правило: Применяйте фоновые процессы для решения различных задач.

Пример:

// Using a queue system like Redis
$redis = new Redis();
$redis->connect('localhost');
$redis->rPush('email_queue', json_encode($emailData));

// Worker process to handle email sending
$emailData = json_decode($redis->lPop('email_queue'), true);
send_email($emailData);

Уменьшайте количество зависимостей

Правило: Включайте в проект только необходимые библиотеки и зависимости.

Пример:

composer install --no-dev // Install production dependencies only

Оптимизируйте алгоритмы и циклы

Правило: Избегайте использования неэффективных циклов и алгоритмов.

Пример:

// Instead of inefficient loops
foreach ($items as $item) {
    // Process item
}

// Use optimized algorithms and data structures
$items = array_map('processItem', $items);

Работайте над эффективностью структуры данных

Правило: Выбирайте структуры данных, соответствующие поставленным задачам.

Пример:

// Using associative arrays for quick lookups
$data = ['key1' => 'value1', 'key2' => 'value2'];
$value = $data['key1'];

Оптимизируйте сессии

Правило: Эффективно используйте сессионное хранилище

Пример:

; Use Redis for session storage
session.save_handler = redis
session.save_path = "tcp://localhost:6379"

Используйте HTTP/2

Правило: Преимущества HTTP/2 повышают производительность проекта. Настройте HTTP/2 в Nginx.

Пример:

server {
    listen 443 ssl http2;
    # Other SSL configuration
}

Реализуйте gzip-сжатие

Правило: Для улучшения трафика сжимайте ответы. Включите Gzip в Nginx.

Пример:

http {
    gzip on;
    gzip_types text/plain text/css application/json application/javascript;
}

Минимизируйте фронтенд

Правило: Оптимизируйте HTML, CSS, JavaScript, поработайте над качеством и размерами изображений.

Пример:

# Minify CSS and JS files
uglifyjs script.js -o script.min.js

Используйте географически распределенную сетевую структуру (CDN)

Правило: Отправьте статический контент в CDN.

Пример:

<link rel="stylesheet" href="https://cdn.example.com/styles.css">
<script src="https://cdn.example.com/scripts.js"></script>

Фиксируйте ошибки

Правило: Для своевременной отладки ведите постоянное логирование ошибок.

Пример:

; Log errors to a file
error_log = /var/log/php_errors.log
log_errors = On

Постоянно анализируйте производительность

Правило: Используйте инструменты мониторинга производительности системы. Например, установите и настройте New Relic.

Пример:

# Install New Relic PHP agent
sudo newrelic-install install

# Configure New Relic in php.ini
newrelic.enabled = true

Проводите регулярное тестирование системы

Правило: Тестируйте эффективность всей системы. Для работы с php-скриптами используйте Xdebug.

Пример:

# Install Xdebug
sudo pecl install xdebug

# Enable Xdebug profiling in php.ini
xdebug.profiler_enable = 1
xdebug.profiler_output_dir = "/tmp/xdebug"

Заключение

Следуя этим правилам и реализуя предоставленные примеры, можно значительно повысить производительность и масштабируемость высоконагруженных PHP-проектов.


Спасибо за внимание.


Перевод статьи MD ARIFUL HAQUE “20 Rules to Optimize PHP for High-Traffic Websites”


Новые публикации

Далее

Категории

О нас

Frontend & Backend. Статьи, обзоры, заметки, код, уроки.