Laravel Ingest робить імпорт даних безболісним

0
Перекладено ШІ
Оригінал: Laravel News
Оновлено: 25 березня, 2026
Laravel Ingest — конфігураційний ETL‑пакет для Laravel, який замінює одноразові імпортні скрипти декларативними класами та обробляє файли від сотень до мільйонів рядків з фіксованим використанням пам'яті. Хочете дізнатися, як налаштувати валідацію, обробку дублікатів, режим dry‑run і моніторинг імпортів через Artisan та REST‑інтерфейс?

Laravel Ingest від Robin Kopp — пакет ETL (Extract, Transform, Load), керований конфігурацією, який замінює одноразові імпортні скрипти декларативними класами-імпортерами. Він обробляє файли від кількох сотень до десятків мільйонів рядків, пропускаючи їх через PHP Generators і Laravel Queues та зберігаючи постійне споживання пам’яті незалежно від розміру файлу.

# Основні можливості

# Визначення імпортера

Після встановлення пакета і виконання міграцій створіть клас-імпортер, що реалізує IngestDefinition і повертає IngestConfig. За конвенцією такі класи розміщують у просторі імен App\Ingest:

namespace App\Ingest;
 
use App\Models\Product;
use LaravelIngest\Contracts\IngestDefinition;
use LaravelIngest\DTOs\IngestConfig;
use LaravelIngest\Enums\DuplicateStrategy;
use LaravelIngest\Enums\SourceType;
 
class ProductImporter implements IngestDefinition
{
    public function getConfig(): IngestConfig
    {
        return IngestConfig::for(Product::class)
            ->fromSource(SourceType::UPLOAD)
            ->keyedBy('sku')
            ->onDuplicate(DuplicateStrategy::UPDATE)
            ->map('Product Name', 'name')
            ->relate('Category', 'category', Category::class, 'slug')
            ->validate([
                'sku' => 'required|string',
                'Product Name' => 'required|string|min:3',
            ]);
    }
}

Зареєструйте імпортер у своєму AppServiceProvider, використовуючи тег пакета:

use LaravelIngest\IngestServiceProvider;
 
$this->app->tag([ProductImporter::class], IngestServiceProvider::INGEST_DEFINITION_TAG);

# Запуск імпортів

Після реєстрації пакет надає і Artisan-команду, і HTTP-ендпоїнт для кожного імпортера.

Через CLI:

php artisan ingest:run product-importer --file=products.csv

Через API (multipart form upload):

POST /api/v1/ingest/upload/product-importer

Для dry-run додайте прапорець --dry-run до Artisan-команди — файл перевірять, а база не зміниться.

# Моніторинг

Пакет містить декілька Artisan-команд для перевірки запущених або завершених імпортів:

php artisan ingest:list              # List registered importers
php artisan ingest:status {id}       # Show progress and row statistics
php artisan ingest:cancel {id}       # Stop an in-progress import
php artisan ingest:retry {id}        # Reprocess only the failed rows

Такі самі REST-ендпоїнти також доступні:

# Події

Пакет диспатчить події впродовж усього життєвого циклу імпорту — IngestRunStarted, ChunkProcessed, RowProcessed, IngestRunCompleted і IngestRunFailed — які можна слухати для сповіщень або кастомних побічних ефектів.

Laravel Ingest доступний на GitHub, а повну документацію — на Laravel Ingest docs.

Популярні

Logomark Logotype

Використання повнотекстового пошуку в Laravel

Laravel пропонує потужні можливості повнотекстового пошуку за допомогою методів whereFullText та orWhereFullText, що дозволяють здійснювати складні запити до бази даних. Дізнайтеся, як реалізувати ефективний пошук для вашого блогу чи системи управління контентом

Logomark Logotype

Створення CLI-додатка за допомогою Laravel та Docker

Зазирніть у світ Laravel, де потужний CLI-фреймворк відкриває нові можливості для розробки командного інтерфейсу. Дізнайтеся, як створити просту утиліту для перевірки акцій, яка працює з Docker, та які переваги це може принести у вашому проєкті!

Logomark Logotype

Claude Agent тепер інтегрований в AI Assistant для PhpStorm

Ви коли-небудь задумувалися, як полегшити свою роботу в Laravel? У нашій статті ми розглядаємо, як інтеграція Claude Code в PhpStorm може підвищити вашу продуктивність, спростивши процес написання коду та навчання нових розробників. Читайте далі, щоб дізнатися більше про переваги та функціональність цього потужного поєднання