⚠️ Forge CLI is under development - use at your own risk.
Laravel Forge is a server management and site deployment service. After connecting to your preferred server provider, Forge will provision a new server, installing and configuring: PHP, Nginx, MySQL, and more.
In addition, Forge can assist you in managing scheduled jobs, queue workers, SSL certificates, and more. After a server has provisioned, you can then deploy your PHP / Laravel applications or WordPress applications using the Forge UI dashboard or the Forge CLI.
This repository contains the CLI client for interacting with Laravel Forge. To learn more about Forge and how to use this client, please consult the official documentation.
Requires PHP 7.3+
You may install the Forge CLI as a global Composer dependency:
composer global require laravel/forge-cli
To view a list of all available Forge CLI commands, also view the current version of your installation, you may run forge
from the command-line:
forge
You will need to generate an API token to interact with the Forge CLI. Tokens are used to authenticate your account without providing personal details. API tokens can be created from Forge's API dashboard.
After you have generated an API token, you should authenticate with your Forge account using the login command:
forge login
When managing Forge resources via the CLI, you will need to be aware of your currently active server. You may view your current server using the server:current
command:
forge server:current
To change your active server, you may use the server:switch
command:
forge server:switch
forge server:switch staging
To view the list of all available servers, you may use the server:list
command:
forge server:list
Before performing any tasks using the Forge CLI, you should ensure that you have added an SSH key for the forge
user to your servers so that you can securely connect to them. You may test that SSH is configured correctly by running the ssh:test
command:
forge ssh:test
To configure SSH key authentication, you may use the ssh:configure
command:
forge ssh:configure
forge ssh:configure --key=/path/to/public/key.pub --name=name-in-forge
After you have configured SSH key authentication, you may use the https://forge.laravel.com/docs/1.0/servers/recipes.html`ssh` command to create a secure connection to your server:
forge ssh
forge ssh staging
As you may know, Forge provision servers with a variety of resources. And you may use Forge CLI to perform "common" actions on those resources.
To check the current status of a resource, you may use the {resource}:status
command:
forge daemon:status
forge database:status
forge nginx:status
forge php:status # Visualize PHP logs (default server version)
forge php:status 8.0 # Visualize PHP 8.0 logs
You may also view logs directly from the command-line. To do so, use the {resource}:logs
command:
forge daemon:logs
forge daemon:logs --tail # Visualize logs in realtime
forge database:logs
forge nginx:logs # Visualize error logs
forge nginx:logs access # Visualize access logs
forge php:logs # Visualize PHP logs (default server version)
forge php:logs 8.0 # Visualize PHP 8.0 logs
Resources may be "restarted" using the {resource}:restart
command:
forge daemon:restart
forge database:restart
forge nginx:restart
forge php:restart # Restarts PHP (default server version)
forge php:restart 8.0 # Restarts PHP 8.0
You may use the {resource}:shell
command to quickly access a command line shell that lets you interact with your resource:
forge database:shell
forge database:shell my-database-name
forge database:shell my-database-name --user=my-user
To view the list of all available sites, you may use the site:list
command:
forge site:list
You may also view site logs directly from the command-line. To do so, use the site:logs
command:
forge site:logs
forge site:logs example.com
Of course, one of the primary features of Laravel Forge is deployments, and those may be initiated via the Forge CLI using the deploy
command:
forge deploy
forge deploy example.com
When a deployment fails, you may review the output / logs via the Forge UI's deployment history screen. Of course, you may review the output at any time on the command-line using the deploy:logs
command:
forge deploy:logs
forge deploy:logs 12345
Sometimes, you may wish to run a "command" on a site. The command command
will prompt you for the "command" you would like to run:
forge command
forge command example.com
forge command example.com --command="php artisan inspire"
As you may know, all Laravel applications include "Tinker" by default. To enter the Tinker environment, run the tinker
command:
forge tinker
forge tinker example.com
Thank you for considering contributing to Forge CLI! You can read the contribution guide here.
In order to ensure that the Laravel community is welcoming to all, please review and abide by the Code of Conduct.
Please review our security policy on how to report security vulnerabilities.
Forge CLI is open-sourced software licensed under the MIT license.