


Über Laravel Sail
Laravel Sail ist die offizielle Entwicklungsumgebung für das Laravel-Framework. Sail bietet eine einfache Befehlszeilenschnittstelle (CLI) zum einfachen Einrichten und Verwalten einer Laravel-Anwendungsentwicklungsumgebung mit Docker. Im Folgenden erklären wir die Hauptfunktionen und die Verwendung von Laravel Sail.
Vorteile der Verwendung von Laravel Sail
-
Erstellen Sie eine vom Betriebssystem unabhängige Entwicklungsumgebung
- Sail verwendet Docker, um die Entwicklungsumgebung für Laravel-Anwendungen zu containerisieren. Dadurch können Sie eine Entwicklungsumgebung erstellen, die unabhängig vom Betriebssystem ist.
-
Einfache Einrichtung der Entwicklungsumgebung
- Mit Sail können Sie mit nur wenigen Befehlen eine Laravel-Entwicklungsumgebung einrichten. Selbst komplexe Entwicklungsumgebungen mit MySQL, Redis, MailHog usw. können problemlos erstellt werden.
-
Einfache Verwaltung von Projekten mit unterschiedlichen Versionen
- Zum Beispiel hängt die Version von Laravel von der Version von PHP ab, aber indem Sie die Umgebung für jedes Projekt in der Datei docker-compose.yml festlegen, können Sie problemlos die Version wechseln.
Wenn Sie ein Projekt mit Docker und Laravel Sail erstellen, sieht die Struktur wie im Diagramm oben aus.
Verwendung
Entwicklungsumgebung
- Mac
- PHP v8.3
- Laravel v11
- Docker
Voraussetzungen
Bevor Sie ein Laravel-Projekt erstellen, laden Sie Docker Desktop herunter und starten Sie es.
https://www.docker.com/products/docker-desktop/
1. Erstellen eines Laravel-Projekts
Führen Sie den folgenden Befehl aus, um ein neues Laravel-Projekt zu erstellen und Laravel Sail einzurichten.
curl -s "https://laravel.build/example-app" | bash cd example-app
Dadurch werden die Laravel-Projektdateien erstellt. Die Entwicklungsumgebung ist in der generierten Datei docker-compose.yml beschrieben.
Geben Sie Dienste mit der with-Abfrage an
Wenn Sie die PHP-Version angeben oder PostgreSQL anstelle von MySQL verwenden möchten, können Sie beim Generieren des Projekts with=
curl -s "https://laravel.build/example-app?php=81&with=pgsql,redis" | bash
2. Segel starten
Gehen Sie in das Projektverzeichnis und starten Sie Sail.
./vendor/bin/sail up -d
Dieser Befehl startet die Docker-Container und führt die Laravel-Anwendung aus.
※Registrieren eines Alias
Die Eingabe von ./vendor/bin/sail kann umständlich sein. Speichern Sie es daher als Alias-Segel in der Konfigurationsdatei Ihrer Shell.
Überprüfen Sie den Pfad der von Ihnen verwendeten Shell mit dem folgenden Befehl
echo $SHELL
Beispiel: /bin/zsh
Bearbeiten der Shell-Konfigurationsdatei
- Für zsh
Die Shell-Konfigurationsdatei ist ~/.zshrc.
Um einen Alias hinzuzufügen, führen Sie den folgenden Befehl aus
curl -s "https://laravel.build/example-app" | bash cd example-app
- Für Bash
Die Shell-Konfigurationsdatei ist ~/.bash_profile oder ~/.bashrc.
Um einen Alias hinzuzufügen, führen Sie den folgenden Befehl aus:
curl -s "https://laravel.build/example-app?php=81&with=pgsql,redis" | bash
Mit den oben genannten Einstellungen können Sie den Segelbefehl in verkürzter Form ausführen.
./vendor/bin/sail up -d
3. Segelbefehle verwenden
Mit Sail können Sie verschiedene Entwicklungsaufgaben ausführen. Hier sind einige Beispiele.
- Anwendung starten:
echo $SHELL
- Anwendung stoppen:
echo "alias sail='sh $([ -f sail ] && echo sail || echo vendor/bin/sail)'" >> ~/.zshrc source ~/.zshrc
- Artisan-Befehle ausführen:
echo "alias sail='sh $([ -f sail ] && echo sail || echo vendor/bin/sail)'" >> ~/.bash_profile source ~/.bash_profile
- Composer-Befehle ausführen:
sail up -d
- Npm-Befehle ausführen:
sail up -d
4. Änderung der Dienste
Auch nach der Erstellung des Projekts können Sie die Dienste ändern, indem Sie die Datei docker-compose.yml, die Docker-Konfigurationsdatei, ändern. Hier werden wir die PHP-Version und die verwendete Datenbank ändern.
Ändern der PHP-Version
Überprüfen Sie zunächst die aktuelle PHP-Version
sail down
Ändern Sie als Nächstes die in der Datei docker-compose.yml beschriebenen Entwicklungsumgebungsinformationen.
sail artisan migrate
Build-Kontext und Image auf 8.1 ändern.
sail composer install
Nachdem Sie docker-compose.yml geändert haben, stoppen Sie die Anwendung.
sail npm install
Als nächstes erstellen Sie die Docker-Container neu, um die Änderungen widerzuspiegeln.
sail php -v PHP 8.3.12 (cli) (built: Sep 27 2024 03:53:05) (NTS)
Starten Sie die Anwendung neu.
services: laravel.test: build: context: "./vendor/laravel/sail/runtimes/8.3" dockerfile: Dockerfile args: WWWGROUP: "${WWWGROUP}" image: "sail-8.3/app"
Überprüfen Sie, ob sich die PHP-Version geändert hat.
services: laravel.test: build: context: "./vendor/laravel/sail/runtimes/8.1" dockerfile: Dockerfile args: WWWGROUP: "${WWWGROUP}" image: "sail-8.1/app"
Die PHP-Version wurde von PHP 8.3 auf PHP 8.1 geändert.
Ändern der verwendeten Datenbank
Ändern Sie ein mit MySQL erstelltes Projekt in PostgreSQL.
Führen Sie den Sail-Installationsbefehl aus
sail down
Wählen Sie pgsql
sail build --no-cache
Überprüfen Sie die Datei docker-compose.yml und bestätigen Sie, dass die pgsql-Einträge hinzugefügt wurden.
sail up -d
ext, öffnen Sie die .env-Datei im Projektverzeichnis und bestätigen Sie, dass DB_CONNECTION=pgsql und DB_HOST=pgsql festgelegt sind.
Wenn nicht, ändern Sie sie manuell.
sail php -v PHP 8.1.30 (cli) (built: Sep 27 2024 04:07:29) (NTS)
Nachdem Sie die Änderungen in docker-compose.yml und .env bestätigt haben, stoppen Sie die Anwendung.
sail php artisan sail:install
Als nächstes erstellen Sie die Docker-Container neu, um die Änderungen widerzuspiegeln.
┌ Which services would you like to install? ───────────────────┐ │ ◼ mysql ┃ │ │ › ◻ pgsql │ │ │ ◻ mariadb │ │ │ ◻ redis │ │ │ ◻ memcached │ │ └────────────────────────────────────────────────── 1 selected ┘ Use the space bar to select options.
Starten Sie die Anwendung neu.
services: laravel.test: ... depends_on: - mysql - redis - meilisearch - mailpit - selenium - pgsql ... pgsql: image: 'postgres:17' ports: - '${FORWARD_DB_PORT:-5432}:5432' environment: PGPASSWORD: '${DB_PASSWORD:-secret}' POSTGRES_DB: '${DB_DATABASE}' POSTGRES_USER: '${DB_USERNAME}' POSTGRES_PASSWORD: '${DB_PASSWORD:-secret}' volumes: - 'sail-pgsql:/var/lib/postgresql/data' - './vendor/laravel/sail/database/pgsql/create-testing-database.sql:/docker-entrypoint-initdb.d/10-create-testing-database.sql' networks: - sail healthcheck: test: - CMD - pg_isready - '-q' - '-d' - '${DB_DATABASE}' - '-U' - '${DB_USERNAME}' retries: 3 timeout: 5s
Führen Sie die Migrationsdateien aus.
DB_CONNECTION=pgsql DB_HOST=pgsql DB_PORT=5432 DB_DATABASE=laravel DB_USERNAME=sail DB_PASSWORD=******
Starten Sie eine Shell in Docker und überprüfen Sie pgsql
Zeigen Sie die Liste der aktuell ausgeführten Docker-Container an.
curl -s "https://laravel.build/example-app" | bash cd example-app
curl -s "https://laravel.build/example-app?php=81&with=pgsql,redis" | bash
Überprüfen Sie den Containernamen der Anwendung und starten Sie die Bash der Anwendung in Docker.
./vendor/bin/sail up -d
Mit pgsql verbinden.
echo $SHELL
Sie werden zur Eingabe eines Passworts aufgefordert. Geben Sie daher das in der .env-Datei angegebene DB_PASSWORD ein.
echo "alias sail='sh $([ -f sail ] && echo sail || echo vendor/bin/sail)'" >> ~/.zshrc source ~/.zshrc
Überprüfen Sie die Tabellen in pgsql
echo "alias sail='sh $([ -f sail ] && echo sail || echo vendor/bin/sail)'" >> ~/.bash_profile source ~/.bash_profile
Auf diese Weise können Sie auch nach der Erstellung des Projekts von MySQL zu PostgreSQL wechseln.
Abschluss
In diesem Artikel erfahren Sie, wie Sie mit Laravel Sail eine Entwicklungsumgebung effizient einrichten und verwalten. Durch die Auswahl geeigneter Dienste und die Anpassung der Einstellungen entsprechend den Projektanforderungen können Sie eine flexiblere und leistungsfähigere Entwicklungsumgebung erreichen.
Das obige ist der detaillierte Inhalt von[Laravel vx Docker] Richten Sie mit Laravel Sail effizient eine Laravel-App-Entwicklungsumgebung ein. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Absolute -Sitzungs -Zeitlimit startet zum Zeitpunkt der Erstellung der Sitzung, während eine Zeitlimit in der Leerlaufsitzung zum Zeitpunkt der No -Operation des Benutzers beginnt. Das Absolute -Sitzungs -Zeitlimit ist für Szenarien geeignet, in denen eine strenge Kontrolle des Sitzungslebenszyklus erforderlich ist, z. B. finanzielle Anwendungen. Das Timeout der Leerlaufsitzung eignet sich für Anwendungen, die die Benutzer für lange Zeit aktiv halten, z. B. soziale Medien.

Der Serversitzungsausfall kann durch Befolgen der Schritte gelöst werden: 1. Überprüfen Sie die Serverkonfiguration, um sicherzustellen, dass die Sitzung korrekt festgelegt wird. 2. Überprüfen Sie die Client -Cookies, bestätigen Sie, dass der Browser es unterstützt und korrekt senden. 3. Überprüfen Sie die Speicherdienste wie Redis, um sicherzustellen, dass sie normal arbeiten. 4. Überprüfen Sie den Anwendungscode, um die korrekte Sitzungslogik sicherzustellen. Durch diese Schritte können Konversationsprobleme effektiv diagnostiziert und repariert werden und die Benutzererfahrung verbessert werden.

Session_Start () iscrucialinphPFormAnagingUSSERSIONS.1) ItinitiatesanewSessionifnoneExists, 2) Wiederaufnahmen und 3) setaSessionCookieforContinuityAcrossRequests, aktivierende Anwendungen wie

Das Festlegen des HTTPonly -Flags ist für Sitzungscookies von entscheidender Bedeutung, da es effektiv verhindern und die Informationen zur Benutzersitzung schützen kann. Insbesondere 1) Das Httponly -Flag verhindert, dass JavaScript auf Cookies zugreift, 2) Das Flag kann durch SetCookies eingestellt werden und in PHP und Flasche 3), obwohl es nicht von allen Angriffen von allen Angriffen verhindert werden kann, Teil der Gesamtsicherheitsrichtlinie sein sollte.

PhpSsionSsionSolvetheProblemofMaintainingStateAcrossmultipehttprequestsBoringDataontheserverandassociatingitittprequests.1) Sie starteten die Stundeataserver-Seite, typischerweise infileSordatabasen, undusaSasionIdinacookookookotenData

PHPSSIONS CANSTORESTRINGEN, ZUGNALTEN, ARRAYS, ANDOBjekte.1.

TostartaphpSession, useSession_start () atthescript'Sbeginning.1) PlaCEITBEFOREANYOUTPUTTOTHESESSIONSCOOKIE.2) useSsionsforuserDatalikeloginStatusOrShopingCarts

Die Sitzung der Sitzung bezieht sich auf die Generierung einer neuen Sitzungs -ID und die Ungültigmachung der alten ID, wenn der Benutzer sensible Vorgänge bei festgelegten Sitzungsangriffen ausführt. Die Implementierungsschritte umfassen: 1. Erkennen sensibler Vorgänge, 2. Erstellen neuer Sitzungs-ID, 3..


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Dreamweaver Mac
Visuelle Webentwicklungstools

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.
