Heim  >  Artikel  >  Backend-Entwicklung  >  Einfache Bereitstellung von PHP-Anwendungen: Erweiterte Fähigkeiten und Praktiken des Deployers

Einfache Bereitstellung von PHP-Anwendungen: Erweiterte Fähigkeiten und Praktiken des Deployers

WBOY
WBOYOriginal
2023-07-12 11:18:081460Durchsuche

Einfache Bereitstellung von PHP-Anwendungen: Fortgeschrittene Fähigkeiten und Praktiken des Bereitstellers

Einführung:
In der modernen Webentwicklung ist es häufig erforderlich, die entwickelten PHP-Anwendungen auf dem Server bereitzustellen, was das Packen und Hochladen des Codes vom lokalen auf den Remote-Server umfasst eine Reihe von Bereitstellungsaufgaben usw. Deployer ist ein leistungsstarkes und benutzerfreundliches PHP-Bereitstellungstool, mit dem wir diese Bereitstellungsaufgaben problemlos erledigen und die Entwicklungseffizienz verbessern können. In diesem Artikel werden die erweiterten Fähigkeiten und Praktiken von Deployer vorgestellt, um Entwicklern dabei zu helfen, Deployer besser zum Bereitstellen von PHP-Anwendungen zu nutzen.

1. Deployer installieren
Zuerst müssen wir Deployer über Composer installieren. Öffnen Sie das Terminal, geben Sie das Stammverzeichnis Ihres PHP-Projekts ein und führen Sie den folgenden Befehl aus, um Deployer zu installieren:

composer require deployer/deployer --dev

Nach Abschluss der Installation wird der Kerncode von Deployer in das Herstellerverzeichnis heruntergeladen.

2. Schreiben Sie das Bereitstellungsskript
Erstellen Sie eine Datei deploy.php im Projektstammverzeichnis, um das Deployer-Bereitstellungsskript zu schreiben. Das Folgende ist ein Beispiel für eine deploy.php-Datei: deploy.php文件,用于编写Deployer的部署脚本。下面是一个示例的deploy.php文件:

<?php
require 'recipe/common.php';

// 项目名称
set('application', 'MyApp');

// 项目仓库地址
set('repository', 'git@github.com:username/repo.git');

// 部署服务器
server('production', 'example.com', 22)
    ->user('deploy')
    ->identityFile('~/.ssh/id_rsa')
    ->set('deploy_path', '/var/www/html');

// 部署任务
task('deploy', function () {
    // 克隆最新的代码到指定目录
    run('git clone {{repository}} {{release_path}}');

    // 安装依赖包
    run('cd {{release_path}} && composer install --no-dev');

    // 执行其他的部署任务

    // 设置软链
    run('ln -nfs {{release_path}}/public {{deploy_path}}/current');
});

// 执行部署任务
after('deploy', 'success');

在这个示例中,我们定义了一个名为production

dep deploy production

In diesem Beispiel definieren wir einen Server mit dem Namen produktion und geben die Serveradresse und den Benutzernamen, die private Schlüsseldatei und an Bereitstellungsverzeichnis. In der Bereitstellungsaufgabe klonen wir zunächst den neuesten Code über git in das angegebene Verzeichnis, führen dann die Composer-Installation aus, um die abhängigen Pakete zu installieren, und richten schließlich einen Softlink ein, um den Code im angegebenen Verzeichnis bereitzustellen.


3. Bereitstellung ausführen

Nachdem wir das Bereitstellungsskript abgeschlossen haben, können wir die Bereitstellungsaufgabe über die Befehlszeile ausführen. Geben Sie im Terminal das Stammverzeichnis des Projekts ein und führen Sie den folgenden Befehl aus:

server('staging', 'staging.example.com', 22)
    ->user('deploy')
    ->identityFile('~/.ssh/id_rsa')
    ->set('deploy_path', '/var/www/staging');

task('deploy:staging', function () {
    // 部署到测试环境
});

Dieser Befehl packt den Code, lädt ihn auf den angegebenen Server hoch und führt eine Reihe von Vorgängen aus, die in der Bereitstellungsaufgabe definiert sind. Während der Ausführung der Bereitstellungsaufgabe zeigt Deployer die Ausgabe im Terminal in Echtzeit an, sodass Entwickler den Status der Bereitstellung in Echtzeit sehen können.


4. Erweiterte Fähigkeiten und Praktiken

Zusätzlich zu den grundlegenden Bereitstellungsfunktionen bietet Deployer auch viele erweiterte Funktionen und praktische Fähigkeiten. Nachfolgend stellen wir einige davon vor.
  1. Bereitstellung in mehreren Umgebungen: Die Bereitstellung in mehreren Umgebungen kann durch die Definition verschiedener Server und Bereitstellungsaufgaben erreicht werden, z. B. Testumgebung, Vorabversionsumgebung und Produktionsumgebung.
    // 安装deployer/recipes插件,用于自动化部署
    composer require deployer/recipes
    
    require 'recipe/laravel.php'; // 启用Laravel插件
    require 'recipe/phinx.php'; // 启用Phinx插件
  1. Verwenden Sie die Plug-Ins von Deployer: Deployer bietet viele nützliche Plug-Ins, die eine automatisierte Bereitstellung, Datenbankmigration, Dateisicherung und andere Funktionen realisieren können. Diese Plugins können über Composer installiert und dann im Bereitstellungsskript aktiviert werden.
    task('deploy:my_task', function () {
        // 自定义的部署任务
    });
    
    after('deploy', 'deploy:my_task');
  1. Passen Sie Ihre eigenen Bereitstellungsaufgaben an: Mit Deployer können Entwickler ihre eigenen Bereitstellungsaufgaben vollständig anpassen. Sie können spezifische Aufgabenfunktionen entsprechend den Anforderungen des Projekts schreiben und diese im Bereitstellungsskript aufrufen.

rrreee
Zusammenfassung:

Mit Deployer, einem leistungsstarken und flexiblen Bereitstellungstool, können wir die Bereitstellung von PHP-Anwendungen problemlos abschließen. In diesem Artikel wird die grundlegende Verwendung von Deployer vorgestellt und anhand von Beispielcode veranschaulicht, wie Bereitstellungsskripts geschrieben und Bereitstellungsaufgaben ausgeführt werden. Darüber hinaus haben wir auch einige fortgeschrittene Techniken und Praktiken von Deployer eingeführt, in der Hoffnung, Entwicklern dabei zu helfen, Deployer besser anzuwenden und die Entwicklungseffizienz zu verbessern. 🎜

Das obige ist der detaillierte Inhalt vonEinfache Bereitstellung von PHP-Anwendungen: Erweiterte Fähigkeiten und Praktiken des Deployers. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn