Before diving in, we recommend reading through the getting started guide below to help you prepare everything you will need to deploy your first application as well as allow you to familarize yourself with the capabilities of Laravel Cloud!

This is the early access phase of Laravel Cloud. We’re continually making improvements and acting on feedback so you should prepare to see things change frequently.

We’ll do out utmost to ensure things remain stable during this time, but you should refrain from running any mission critical or commercially significant workloads at this time whilst we continue to refine the platform.

Registration

The Cloud team will send you an email containing your unique invite link and access code. Simply follow the link and populate the registration form to gain access to the Cloud dashboard.

Once logged in, you will have the ability to invite additional team members from your organization settings page.

Key Concepts

Organizations

Upon registering with Laravel Cloud, you will be assigned to an organization. For new registrations, this will be a brand new organization; however, if you are invited by another user, you will join an existing organization.

On Laravel Cloud, the organization is the top-level entity that owns all applications, environments, and resources such as databases and custom domains.

Applications

The application entity encompasses everything required to run your application on Laravel Cloud. It is coupled directly to your chosen source control repository.

When creating a new application, a default environment will be created using the default branch of the associated repository. In most cases, this is a sensible starting point, but you are free to change this to suit your requirements.

Environments

Environments are children of the application entity. You may create as many environments as you require with each environment attached to a branch of the application’s associated source control repository.

A common use case here is to create a production and staging environment, but also affords the ability to create environments for new feature branches like so:

EnvironmentBranch
productionmain
stagingdevelop
new-featurefeat/new-feature

Some environments will be long-lived whilst others short-lived. For example, you may only need the new-feature environment for a few hours during a QA test after which, you may remove it.

Each environment can be configured independently. You may, for instance, wish to test an updated version of our application with a newer version of PHP. Simply create a new environment from a branch containing your updates and set your desired version of PHP without affecting your other environments.

Deployments

You may deploy a new version of your application by initiating a new deployment. Doing so will result in Cloud pulling the latest commit hash of the branch associated with the given environment before building, deploying your application as per your settings configured in Cloud.

Resources

Resources relate to any dependency required by your application in order for it to function. Laravel Cloud affords a number of additional resources, with more to follow soon.

  • Serverless Postgres

  • Custom domains

  • MySQL (coming soon)

  • Redis (coming soon)

  • Object storage (coming soon)

Prerequisites

To get your application running on Laravel Cloud, you should prepare the following:

Laravel application source controlled by either GitHub, GitLab or BitBucket with admin permission to the containing organization

The environment variables required by your application

Any custom frontend and backend build commands

Trust Proxies set to Trust All Proxies

Limitations

Databases

During early access, Laravel Cloud offers first-party serverless Postgres databases.

In the event this doesn’t suit your requirements, you may bring your own database. The database will need to be publicly accessible and the connection to your application should be manually configured by setting the relevant environment variables within the Cloud UI.

Region Support

For early access, Laravel Cloud is available in the US Ohio region only. Support for more regions will follow in the coming weeks.

Runtime

Laravel Cloud is optimized to run Laravel applications effectively and efficiently and the most commonly used PHP extensions are available out of the box. It’s not currently possible to utilize a custom runtime or Docker image nor is it possible to run custom executables.

Supported extensions include: ctype, curl, dom, fileinfo, filter, hash, mysqli, mbstring, opcache, openssl, pcntl, pdo_mysql, pdo_pgsql, pcre, redis, session, tokenizer, xml, zip

Domains

Before a custom domain can be used and SSL certificate issued by Laravel Cloud, ownership of the domain must first be verified.

The simplest and fastest way to verify ownership is to use real-time validation where the domain A record is immediately pointed at Cloud’s IP address.

However, doing so will result in a small amount of downtime. Additionally, real-time verification is not possible when attempting to add wildcard subdomain support.

If you cannot afford downtime when migrating your application or if you need to provide wildcard subdomain support, you will need to pre-verify your domain before pointing your DNS at Cloud. This involves adding some additional DNS records which you can find in the Cloud UI.

Was this page helpful?