PHP Portal | Программирование
4.85K subscribers
408 photos
20 videos
2 files
209 links
Присоединяйтесь к нашему каналу и погрузитесь в мир для PHP-разработчика

Связь: @devmangx
Download Telegram
💡 Быстрый совет по Laravel: Ограничение скорости выполнения задач

Когда-нибудь приходилось ограничивать частоту выполнения задач?

Будь то защита API от перегрузки или ограничение количества задач для пользователей бесплатного тарифа, Laravel позволяет легко задавать лимиты и использовать их прямо из коробки

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍72
Секреты стройности монолита: подходы по снятию нагрузки с БД

Статья описывает, как команда Яндекс Еды оптимизировала свой монолитный PHP-сервис, снизив нагрузку на MySQL

Основные проблемы включали высокую загрузку CPU и памяти, сложность управления изменениями в структуре базы данных и срабатывание механизма Flow Control в Galera Cluster, что приводило к задержкам и сбоям в обслуживании запросов.

Для решения этих проблем команда распределила ответственность за таблицы между командами, анализировала медленные запросы с помощью утилиты pt-query-digest и внедрила различные оптимизации, включая использование кэширования и денормализацию данных

В результате удалось значительно снизить нагрузку на базу данных и улучшить производительность системы

👉 Подробнее

➡️ @PHPgx | #cтатья
Please open Telegram to view this post
VIEW IN TELEGRAM
👍83🔥1
Общие табличные выражения (CTE) в MySQL позволяют писать более чистые и удобные для поддержки запросы, создавая временные именованные наборы результатов.

Вместо вложенных подзапросов CTE можно использовать во многих случаях

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍101
True Async

На днях был опубликован RFC, предоставляющий возможность писать асинхронный код на PHP.

Согласно этому предложению, можно будет писать код следующего вида:

Async\run(function() {

$fiber = Async\async(function() {
sleep(1);
return "Fiber completed!";
});

// Выполнение приостанавливается, пока fiber не завершится
$result = Async\await($fiber);

echo $result . "\n";

echo "Done!\n";
});

Это похоже на async/await в JavaScript и работает через механизм Event Loop.

На данный момент для написания асинхронного кода в PHP используют генераторы, Fiber (начиная с версии 8.1), а также решения вроде Swoole, AMPHP, ReactPHP.

RFC:
https://wiki.php.net/rfc/true_async

➡️ @PHPgx
Please open Telegram to view this post
VIEW IN TELEGRAM
👍302🤯2
Только недавно узнал, что namespace можно использовать как ссылку на текущий неймспейс 🤯

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14🤯8👀2
🔒 Знаете ли вы, что можно получить список маршрутов, зарегистрированных пакетами в ваших Laravel-приложениях?

Вы можете сделать это, выполнив команду:

php artisan route:list --only-vendor


Это отлично подходит для аудита ваших маршрутов и выявления тех, о которых вы могли не знать, чтобы убедиться, что они защищены и безопасны

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍141🤯1
Крутеший ресурс, если хочешь выучить SQL на практике и с нуля

Это интерактивные уроки прямо в браузере, без регистрации и бесплатно. Всё подается шаг за шагом: от базовых запросов до более сложных тем, таких как JOIN и агрегации

Весь процесс строится на упражнениях, так что теорию сразу применяешь на практике

Ссылка: https://sqlbolt.com/

👉 @PHPgx | #ресурсы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8
💡 Совет по PHP для массовой замены строк

Вы можете использовать str_replace(), передавая массивы ключей и значений в качестве параметров, без использования циклов.

Источник этого фрагмента кода: GitHub

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍183😁1
Часто при демонстрации нашего проекта заинтересованным сторонам мы заполняем базу данных фиктивными данными с помощью библиотеки Faker для PHP.

Но иногда заинтересованным сторонам сложно воспринимать данные, так как по умолчанию библиотека Faker генерирует их в формате локали en_US.

Вот небольшой совет: мы можем изменить локаль для нашего Laravel-приложения с помощью переменной окружения APP_FAKER_LOCALE.

В моем случае я обычно устанавливаю APP_FAKER_LOCALE в ru_RU, после чего Faker начинает генерировать данные, более приближенные к русскому формату.

#laravel #php

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍213
Одна из самых подробных и полезных шпаргалок для Backend-разработчиков на русском языке.

Всё, что нужно, собрано в одном месте: как устроен интернет, как работают ПК, базы данных, API, тестирование и куча всего ещё

Весь материал преисполнен разными таблицами и картинками для лучшего усвоения, вся информация подаётся кратко и понятно, а если захотите изучить детальнее — везде есть ссылки на источники.

👉 @PHPgx | #ресурсы
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍95🔥2👀2
Начиная с Laravel 11, весь middleware, который мы хотим применить в нашем приложении, необходимо настраивать в файле bootstrap.php.

Если вы переходите с более старой версии Laravel, вот различные методы, которые вам нужно знать для работы с middleware в Laravel 11 и более поздних версиях.

Здорово, что новая структура включает в себя все эти возможности 👍

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍71
URL vs URI vs URN — в чем разница?

🔹 URI (Uniform Resource Identifier)
URI — это строка символов, идентифицирующая ресурс по местоположению, имени или обоим параметрам. Это самый общий идентификатор. URL и URN являются подтипами URI.

🔹 URL (Uniform Resource Locator)
URL — это подтип URI, который указывает, как найти ресурс в сети. Он включает протокол (например, HTTPS), домен и часто путь. URL полностью описывает способ доступа к ресурсу. Например: https://example.com/path/to/resource. URL также может использоваться с другими протоколами, такими как FTP.

🔹 URN (Uniform Resource Name)
URN — это тоже подтип URI, но он идентифицирует ресурс по имени в рамках определенного пространства имен, а не по местоположению. Он использует схему urn. URN не может быть использован для нахождения ресурса. Это глобально уникальный идентификатор, который остается неизменным независимо от местоположения ресурса. Например, urn:isbn:0361450721 идентифицирует книгу по ее ISBN, который остается неизменным, даже если книга хранится в разных местах.

Проще говоря:

🔹URL — это URI, но не всякий URI является URL.
🔹URN — уникальные имена, URL — локаторы, URI объединяет оба типа.

👉 @PHPgx
Please open Telegram to view this post
VIEW IN TELEGRAM
👍92
Поскольку в сериализуемом замыкании нельзя использовать $this, рассмотрите возможность вынесения колбэков Bus::batch, основанных на Closure, в отдельные вызываемые (callable) классы.

Этот подход:
🔹Избавляет от необходимости создавать локальные переменные для свойств $this, чтобы сделать их сериализуемыми.
🔹Делает код более чистым, разделяя ответственность.
🔹Переносит логику в отдельный тестируемый класс.

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
👍42
Vito — это самохостимое веб-приложение для управления серверами и деплоя PHP-приложений.

Поддерживает управление базами данных, настройку файрвола, установку SSL-сертификатов и управление cron-заданиями.

👉 https://github.com/vitodeploy/vito

👉 @PHPgx | #ресурсы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍81
HTTP/2 vs HTTP/3 — В чем разница?

HTTP/1 появился в 1996 году, а уже в 1997 вышел HTTP/1.1.

Следующий крупный шаг произошел только спустя ~20 лет — в 2015 году был стандартизирован HTTP/2. А в 2022 году официально утвердили HTTP/3.

В чем разница?

HTTP/1.1
Постоянные соединения — повторное использование соединений вместо открытия новых
Потоковая передача (Chunked Transfer) — отправка данных частями вместо ожидания полного ответа
Улучшенное кеширование — заголовки для управления кешем и соединениями
Последовательные запросы — блокируют друг друга (HoL-блокировка на уровне запросов)
Требуется несколько соединений — браузеры открывали несколько TCP-соединений для скорости

HTTP/1.1 заложил фундаментальные механизмы, актуальные и сегодня.

HTTP/2
Мультиплексирование — несколько запросов в одном TCP-соединении
Сжатие заголовков (HPACK) — уменьшение накладных расходов
Приоритизация потоков — критически важные ресурсы загружаются первыми
HoL-блокировка — потерянный пакет блокирует все потоки

HTTP/2 оптимизировал TCP, но остался ограничен его архитектурой.

HTTP/3
Основан на QUIC (UDP) — больше нет узких мест TCP
Независимые потоки — потеря пакетов в одном потоке не мешает другим
Быстрые рукопожатия — транспорт и шифрование настраиваются за один шаг
Обязательное шифрование (TLS 1.3) — безопасность по умолчанию
Миграция соединений — стабильная работа при смене сети

Вывод: HTTP/2 оптимизировал TCP, но HTTP/3 меняет правила игры с QUIC — быстрее, надежнее и безопаснее по умолчанию.

👉 @PHPgx
Please open Telegram to view this post
VIEW IN TELEGRAM
👍142
При работе с загрузкой изображений в Laravel важно проверять их ширину и высоту.

Например, если пользователи загружают аватары, лучше убедиться, что размеры остаются единообразными.

Не проблема! Класс Rule в Laravel позволяет легко валидировать размеры изображения с понятным синтаксисом.

Вот пример кода 👆

👉 @PHPgx | #tips
Please open Telegram to view this post
VIEW IN TELEGRAM
10👍3
This media is not supported in your browser
VIEW IN TELEGRAM
Ищешь игры, которые помогут тебе выучить и практиковать SQL?

Попробуй SQL Noir — детективная игра по SQL

Пиши запросы, анализируй данные и раскрывай дела!

👉 Попробовать - https://www.sqlnoir.com/
👉 Исходники доступны на GitHub

👉 @PHPgx | #ресурсы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8😁1