Maison > développement back-end > tutoriel php > Création d'une application CLI avec Laravel et Docker

Création d'une application CLI avec Laravel et Docker

Barbara Streisand
Libérer: 2024-12-01 06:06:12
original
489 Les gens l'ont consulté

Creating a CLI Application With Laravel and Docker

Qu'est-ce qu'une application CLI ?

Une application CLI (Command-Line Interface) est un programme informatique qui interagit avec l'utilisateur via des commandes textuelles saisies dans un terminal ou une console. Contrairement aux applications Web qui s'appuient sur une interface utilisateur graphique (GUI), les applications CLI sont basées sur du texte et sont souvent utilisées pour les tâches d'automatisation, d'administration système et de traitement de données.

Pourquoi Laravel et Docker ?

Laravel est un framework PHP puissant qui simplifie le développement d'applications Web. Sa syntaxe élégante, ses fonctionnalités robustes et son vaste écosystème en font un excellent choix pour créer des applications CLI. Avec l'outil de ligne de commande Artisan de Laravel, vous pouvez créer et gérer rapidement des commandes, ce qui facilite l'automatisation des tâches et des scripts.

Docker est une plateforme de conteneurisation qui regroupe les applications et leurs dépendances dans des conteneurs portables. En utilisant Docker, nous pouvons créer des environnements isolés pour nos applications Laravel, garantissant ainsi la cohérence et la reproductibilité dans différents environnements de développement et de production.

Dans cet article, nous explorerons comment exploiter Laravel et Docker pour créer des applications CLI robustes et efficaces.

Mise en place du projet Laravel

Créer un nouveau projet Laravel

Pour commencer, créons un nouveau projet Laravel. Vous pouvez utiliser le programme d'installation de Laravel pour configurer rapidement un nouveau projet :

laravel new my-cli-app
Copier après la connexion
Copier après la connexion
Copier après la connexion

Cette commande créera un nouveau répertoire nommé my-cli-app et initialisera un nouveau projet Laravel à l'intérieur.

Configuration de la commande artisanale

L'outil de ligne de commande intégré de Laravel, artisan, est le cœur du framework. Nous pouvons l'utiliser pour créer et gérer divers aspects de notre application. Pour créer une nouvelle commande, nous utiliserons la commande make:command Artisan :

php artisan make:command GreetUser

Copier après la connexion
Copier après la connexion
Copier après la connexion

Cette commande générera une nouvelle classe de commandes nommée GreetUser dans le répertoire app/Console/Commands. La structure de base d'une classe de commandes ressemble à ceci :

<?php

namespace App\Console\Commands;

use Illuminate\Console\Command;

class GreetUser extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'greet:user {name?}';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'Greet a user';

    /**
     * Execute the console command.
     *
     * @return int
     */
    public function handle()
    {
        $name = $this->argument('name');

        if ($name) {
            $this->info("Hello, {$name}!");
        } else {
            $this->info('Hello, world!');
        }

        return Command::SUCCESS;
    }
}

Copier après la connexion
Copier après la connexion

Dans cet exemple :

- $signature : Définit le nom de la commande et tous les arguments ou options facultatifs. La partie {name?} indique un argument facultatif nommé name.
- $description : Fournit une brève description de la commande.
- handle() : Contient la logique de base de la commande. Il accède à l'argument de nom en utilisant $this->argument('name') et imprime un message de bienvenue sur la console.

Pour exécuter cette commande, utilisez la commande suivante dans votre terminal :

php artisan greet:user JohnDoe

Copier après la connexion
Copier après la connexion

Cela affichera :

laravel new my-cli-app
Copier après la connexion
Copier après la connexion
Copier après la connexion

Écriture de la logique de commande

Logique de commande de base

La méthode handle() est l'endroit où la vraie magie se produit. C'est ici que vous définirez la logique de base de votre commande. Vous pouvez accéder aux arguments et options de commande, interagir avec le framework Laravel et effectuer diverses tâches.

Voici un exemple de commande qui récupère les données d'une API et les traite :

php artisan make:command GreetUser

Copier après la connexion
Copier après la connexion
Copier après la connexion

Dans cet exemple :

- Récupération de données : Nous utilisons la façade Http pour envoyer une requête HTTP GET à l'URL spécifiée.
- Traitement des données : Si la demande aboutit, nous analysons la réponse JSON et traitons les données selon les besoins.
- Sortie : Nous utilisons les méthodes d'information et d'erreur pour afficher les messages sur la console.

Tester la commande

Pour tester votre commande, exécutez-la simplement à l'aide de la commande php artisan :

<?php

namespace App\Console\Commands;

use Illuminate\Console\Command;

class GreetUser extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'greet:user {name?}';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'Greet a user';

    /**
     * Execute the console command.
     *
     * @return int
     */
    public function handle()
    {
        $name = $this->argument('name');

        if ($name) {
            $this->info("Hello, {$name}!");
        } else {
            $this->info('Hello, world!');
        }

        return Command::SUCCESS;
    }
}

Copier après la connexion
Copier après la connexion

N'oubliez pas de remplacer https://api.example.com/data par un point de terminaison d'API réel.

Cela déclenchera la méthode handle() de la commande FetchData et vous devriez voir la sortie appropriée dans votre terminal.

Conteneuriser l'application avec Docker

Docker est un outil puissant pour conteneuriser des applications. En conteneurisant votre application Laravel, vous pouvez garantir des environnements cohérents dans différentes configurations de développement et de production.

Création d'un fichier Docker

Un Dockerfile est un document texte qui contient des instructions sur la façon de créer une image Docker. Voici un Dockerfile de base pour une application Laravel :

php artisan greet:user JohnDoe

Copier après la connexion
Copier après la connexion

Création d'un fichier de composition Docker

Un fichier Docker Compose définit et exécute des applications Docker multi-conteneurs. Voici un fichier Docker Compose de base pour une application Laravel :

Hello, JohnDoe!
Copier après la connexion

Ce fichier Docker Compose définit deux services :

  • app : crée l'image Docker à l'aide du Dockerfile et mappe le port 8000 de votre machine hôte au port 9000 du conteneur. Il monte également le répertoire actuel en tant que volume sur le conteneur, permettant des modifications de code en direct.
  • base de données : extrait une image MySQL et configure une base de données avec les informations d'identification spécifiées.

Créer et exécuter l'image Docker

Construire l'image

Pour créer l'image Docker, accédez au répertoire racine de votre projet dans votre terminal et exécutez la commande suivante :

<?php

namespace App\Console\Commands;

use Illuminate\Console\Command;
use Illuminate\Support\Facades\Http;

class FetchData extends Command
{
    protected $signature = 'fetch:data {url}';

    protected $description = 'Fetch data from a given URL';

    public function handle()
    {
        $url = $this->argument('url');

        $response = Http::get($url);

        if ($response->successful()) {
            $data = $response->json();
            // Process the data here
            $this->info('Data fetched and processed successfully!');
        } else {
            $this->error('Failed to fetch data.');
        }
    }
}

Copier après la connexion

Cette commande construira l'image Docker définie dans le Dockerfile et lui attribuera un nom (généralement le nom du service du fichier docker-compose.yml).

Exécuter le conteneur

Une fois l'image construite, vous pouvez démarrer le conteneur à l'aide de la commande suivante :

laravel new my-cli-app
Copier après la connexion
Copier après la connexion
Copier après la connexion

Cette commande démarrera les conteneurs d'application et de base de données en mode détaché, vous permettant d'accéder à votre application dans votre navigateur. Vous pouvez accéder à votre application sur http://localhost:8000.

Pour arrêter les conteneurs, utilisez la commande suivante :

php artisan make:command GreetUser

Copier après la connexion
Copier après la connexion
Copier après la connexion

Meilleures pratiques et sujets avancés

Organisation et modularisation du commandement

À mesure que votre application CLI se développe, il est important de garder vos commandes organisées et modulaires. Pensez à diviser les commandes complexes en commandes plus petites et plus ciblées. Vous pouvez utiliser des fournisseurs de services et des façades pour injecter des dépendances et partager la logique entre les commandes.

Gestion des erreurs et journalisation

La mise en œuvre d'une gestion et d'une journalisation robustes des erreurs est cruciale pour le débogage et la surveillance de vos applications CLI. Laravel fournit un système de journalisation puissant que vous pouvez utiliser pour enregistrer les erreurs, les avertissements et les messages d'information. Vous pouvez également utiliser des outils de journalisation externes tels que Loggly ou Papertrail pour des fonctionnalités de journalisation plus avancées.

Test des applications CLI

L'écriture de tests unitaires pour votre logique de commande est essentielle pour garantir la qualité et la maintenabilité du code. Vous pouvez utiliser PHPUnit ou d'autres frameworks de test pour écrire des tests qui couvrent différents scénarios et cas extrêmes.

Déploiement et CI/CD

Pour déployer votre application Dockerized Laravel, vous pouvez utiliser des outils d'orchestration de conteneurs comme Kubernetes ou Docker Swarm. Ces outils vous permettent de gérer et de faire évoluer votre application sur plusieurs hôtes.
Vous pouvez également intégrer votre application aux pipelines CI/CD pour automatiser les processus de création, de test et de déploiement. Les outils CI/CD populaires incluent Jenkins, GitLab CI/CD et CircleCI.

En suivant ces bonnes pratiques et techniques avancées, vous pouvez créer des applications CLI puissantes et efficaces avec Laravel et Docker.

Conclusion

Dans cet article, nous avons exploré comment créer des applications CLI robustes et efficaces à l'aide de Laravel et Docker. En tirant parti de la puissance de ces outils, vous pouvez créer des outils de ligne de commande qui automatisent les tâches, traitent les données et interagissent avec l'infrastructure de votre application.

Nous avons couvert les bases de la création de commandes Laravel, de l'écriture de la logique des commandes et de la conteneurisation de votre application avec Docker. Nous avons également discuté des meilleures pratiques en matière d'organisation des commandes, de gestion des erreurs, de tests et de déploiement.

Alors que vous continuez à créer et à améliorer vos applications CLI, n'oubliez pas de garder votre code propre, bien testé et maintenable. En suivant ces directives et en explorant les fonctionnalités avancées de Laravel et Docker, vous pouvez créer des outils CLI puissants et flexibles qui rationalisent vos flux de travail.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal