Это профилировщик, написанный на PHP, который считывает информацию о запуске виртуальной машины PHP извне процесса.
Вы можете обнаружить узкие места производительности или утечки памяти в своих скриптах, не меняя целевой скрипт и не загружая расширения.
🔗 Github
#инструменты
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🔥3❤1
🐘 PHP для начинающих (и напоминание для опытных)
🔹 Query Scopes
Смотришь на свой код и замечаешь одно и то же в пяти местах:
Это не переиспользование кода. Это его копирование. Разница важная.
▪️ Local Scope — прячем логику в модель
Теперь вместо цепочки условий — читаемый вызов
▪️ Scope с параметром
Иногда нужна гибкость. Scope принимает аргументы:
▪️ Global Scope — когда условие должно быть всегда
Если SoftDeletes работает по всему приложению — это глобальный скоуп под капотом. Можно написать свой:
Теперь все запросы к этой модели автоматически фильтруются по тенанту. Без единого where в контроллерах.
Библиотека пхпшника
#php_азбука
🔹 Query Scopes
Смотришь на свой код и замечаешь одно и то же в пяти местах:
->where('status', 'active')->where('deleted_at', null)
->where('status', 'active')->where('deleted_at', null)
->where('status', 'active')->where('deleted_at', null)Это не переиспользование кода. Это его копирование. Разница важная.
▪️ Local Scope — прячем логику в модель
// User.php
public function scopeActive(Builder $query): Builder
{
return $query->where('status', 'active')
->whereNull('deleted_at');
}
public function scopeVerified(Builder $query): Builder
{
return $query->whereNotNull('email_verified_at');
}
Теперь вместо цепочки условий — читаемый вызов
// Было
User::where('status', 'active')
->whereNull('deleted_at')
->whereNotNull('email_verified_at')
->get();
// Стало
User::active()->verified()->get();
▪️ Scope с параметром
Иногда нужна гибкость. Scope принимает аргументы:
public function scopeOlderThan(Builder $query, int $days): Builder
{
return $query->where('created_at', '<', now()->subDays($days));
}
phpUser::active()->olderThan(30)->get();
▪️ Global Scope — когда условие должно быть всегда
Если SoftDeletes работает по всему приложению — это глобальный скоуп под капотом. Можно написать свой:
// В модели
protected static function booted(): void
{
static::addGlobalScope('tenant', function (Builder $builder) {
$builder->where('tenant_id', auth()->user()?->tenant_id);
});
}
Теперь все запросы к этой модели автоматически фильтруются по тенанту. Без единого where в контроллерах.
Библиотека пхпшника
#php_азбука
👍8❤4🔥2🥱1
⚙️ Laravel Process Pipe
С версии Laravel 10.7 появилась нативная поддержка конвейера процессов (pipe). Теперь можно легко передавать вывод одного процесса на вход другого — прямо из PHP-кода, без костылей.
Это аналог привычного cat example.txt | grep -i "laravel" в терминале, только внутри Laravel.
Зачем это нужно?
— Обработка файлов и потоков данных без временных переменных
— Чистый и читаемый код вместо вызовов shell_exec
— Удобное тестирование через фейковые процессы
Маленькая фича, но приятная 🙂
Библиотека пхпшника
#vardump
С версии Laravel 10.7 появилась нативная поддержка конвейера процессов (pipe). Теперь можно легко передавать вывод одного процесса на вход другого — прямо из PHP-кода, без костылей.
use Illuminate\Process\Pipe;
use Illuminate\Support\Facades\Process;
$result = Process::pipe(function (Pipe $pipe) {
$pipe->command('cat example.txt'),
$pipe->command('grep -i "laravel"'),
});
if ($result->successful()) {
// ...
}
Это аналог привычного cat example.txt | grep -i "laravel" в терминале, только внутри Laravel.
Зачем это нужно?
— Обработка файлов и потоков данных без временных переменных
— Чистый и читаемый код вместо вызовов shell_exec
— Удобное тестирование через фейковые процессы
Маленькая фича, но приятная 🙂
Библиотека пхпшника
#vardump
👍3❤2😁1
Почитали тут свежий отчёт по рынку ИИ-ускорителей в РФ: оказывается, 54% компаний тормозят внедрение ИИ исключительно из-за конских цен на инфраструктуру.
Ну, то есть написать пет-проект с вызовом API это задача на вечер, а вот запустить агента в продакшн так, чтобы он не сжёг бюджет отдела за неделю — суровая инженерия.
По сути, сейчас мало уметь собирать RAG. Нужно считать токены, настраивать
Также в программе:
— оценка качества, трейсинг и защита от деградации пайплайнов;
— мультиагентные паттерны и интеграция по протоколу
— локальный деплой Open Source под 152-ФЗ (когда данные нельзя выносить наружу).
Кажется, это единственный адекватный roadmap по переходу от блокнотов к enterprise-решениям.
Прямо сейчас можно урвать курс с увесистой скидкой(49 000 ₽ 62 990 ₽ за базовый тариф и 99 000 ₽ 124 990 ₽ за продвинутый трек) , но стоит поторопиться — на потоке осталось всего 5 мест.
👉 Зафиксировать цену и начать собирать агентов, за которых не стыдно в проде
Ну, то есть написать пет-проект с вызовом API это задача на вечер, а вот запустить агента в продакшн так, чтобы он не сжёг бюджет отдела за неделю — суровая инженерия.
По сути, сейчас мало уметь собирать RAG. Нужно считать токены, настраивать
time-travel дебаг в LangGraph и уметь роутить запросы на лету. Всё это мы учли в обновлённом курсе по разработке AI-агентов, где акцент сделан именно на AgentOps и жёсткий контроль ресурсов.Также в программе:
— оценка качества, трейсинг и защита от деградации пайплайнов;
— мультиагентные паттерны и интеграция по протоколу
MCP;— локальный деплой Open Source под 152-ФЗ (когда данные нельзя выносить наружу).
Кажется, это единственный адекватный roadmap по переходу от блокнотов к enterprise-решениям.
Прямо сейчас можно урвать курс с увесистой скидкой
👉 Зафиксировать цену и начать собирать агентов, за которых не стыдно в проде
🥱2
Forwarded from Библиотека собеса по PHP | вопросы с собеседований
Баг, который живёт в проде месяцами и проявляется только под нагрузкой 👇
📦 Задание
Команда пишет модуль биллинга. Ты написал быстрый класс-обёртку для работы с тарифами. Код прошёл ревью, всё работало на стейджинге. В проде через неделю начались жалобы: у части пользователей неправильно считается стоимость. Причём только в пиковые часы.
// src/Billing/TariffCalculator.php
class TariffCalculator
{
private static TariffConfig $config;
private static array $cache = [];
public static function init(array $rawConfig): void
{
self::$config = new TariffConfig($rawConfig);
}
public static function calculate(int $userId, int $units): float
{
$key = $userId . ':' . $units;
if (isset(self::$cache[$key])) {
return self::$cache[$key];
}
$price = self::$config->getBasePrice()
* $units
* self::$config->getUserMultiplier($userId);
self::$cache[$key] = $price;
return $price;
}
public static function resetCache(): void
{
self::$cache = [];
}
}
// src/Billing/TariffConfig.php
class TariffConfig
{
private float $basePrice;
private array $multipliers;
public function __construct(array $config)
{
$this->basePrice = (float) $config['base_price'];
$this->multipliers = $config['multipliers'] ?? [];
}
public function getBasePrice(): float
{
return $this->basePrice;
}
public function getUserMultiplier(int $userId): float
{
return $this->multipliers[$userId] ?? 1.0;
}
}
// bootstrap.php — вызывается один раз при старте воркера
TariffCalculator::init(loadConfigFromDB());
// Где-то в обработчике запроса
$price = TariffCalculator::calculate($user->id, $request->units);
🔹 Задачи
— Найти все архитектурные и логические проблемы в коде (их несколько)
— Объяснить, почему баг проявляется только под нагрузкой и не воспроизводится на стейджинге
— Предложить правильное решение
Ставьте → 🔥 если нравится формат. Если нет → 🌚
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥13❤2👍1🌚1
Наш подписчик спрашивает
«Я PHP-разработчик с опытом 1,5 года. Но ощущаю, что топчусь на месте. Какие навыки стоит развивать, чтобы сдвинуть с мертвой точки через год-два ? Углубляться в фреймворки или лучше прокачивать soft skills?»
Алексей, PHP Developer
— Какие технические навыки необходимы для роста
— Насколько важны фреймворки и архитектура
— Какие soft skills действительно ценят
P.S. Если хотите задать вопрос, заполните нашу гугл-форму. Это займет 5 минут.
#междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2❤1😁1