Region ID
The REGION_ID is an abbreviated code that Google assigns
based on the region you select when you create your app. The code does not
correspond to a country or province, even though some region IDs may appear
similar to commonly used country and province codes. For apps created after
  February 2020, REGION_ID.r is included in
  App Engine URLs. For existing apps created before this date, the
  region ID is optional in the URL.
Learn more about region IDs.
Learn how to build an app in App Engine using either PHP version 7.4 or 8.1. The sample app allows users to post the titles, authors, descriptions, publication date, and images of their favorite books to a webpage. The app stores the textual data in a Cloud SQL database and the images in a Cloud Storage bucket.
Guide structure
Before you begin
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Cloud Build API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
      Install the Google Cloud CLI. 
- 
          If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. 
- 
        To initialize the gcloud CLI, run the following command: gcloud init
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Cloud Build API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
      Install the Google Cloud CLI. 
- 
          If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. 
- 
        To initialize the gcloud CLI, run the following command: gcloud init
- Install Composer, the PHP dependency management tool. You must install Composer globally on Linux and Mac OS X systems.
- Due to changes in the default behavior for how Cloud Build uses service accounts in new projects, and secure-by-default organization policy changes, you might need to grant additional roles to your deploying service account. For more information on granting specific roles, see the troubleshooting guide.
Download the sample app
- Explore the code on GitHub 
- Download or clone the app. - git clone https://github.com/GoogleCloudPlatform/php-docs-samples.git - Or download the sample as a zip file and extract it. 
- Navigate to the - getting-starteddirectory.- cd php-docs-samples/appengine/standard/getting-started 
Specify dependencies with composer.json
The app uses a front controller to route requests. The sample code in this guide uses the Slim Framework, but you are free to use a web framework of your choice.
- Open the - composer.jsonfile to review all direct dependencies:
- To install your dependencies and produce a - composer.lockfile, run the following command:- composer install- The - composer.lockfile helps your app to retrieve the same versions of the packages you use across multiple builds and environments.
Initialize the app and defining front controllers
The index.php file initializes the app and forwards all requests to controllers
defined in the ./src/controllers.php file.
For more on request handling, read about application startup and handling requests.
Integrating with Google Cloud services
App Engine requires apps to integrate with external systems for data storage. The sample app stores textual data on Cloud SQL and images on Cloud Storage.
See the Choosing a Storage Option page for all Google Cloud storage options.
Using Cloud SQL
In the sample app, users post books to a webpage. The app uses a Cloud SQL database to store the titles, authors, publication date, and descriptions of the books.
You will need to create a Cloud SQL instance before adding content to the app's database.
Creating a Cloud SQL instance
Use the gcloud CLI to create a Cloud SQL instance:
gcloud sql instances create INSTANCE_NAME --tier=MACHINE_TYPE --region=REGION
For example, if you want to name your instance bookshelf and use the machine
type of db-n1-standard-2 in the United States central region:
gcloud sql instances create bookshelf --tier=db-n1-standard-2 --region=us-central1
Setting up the MySQL root user
You can use the gcloud CLI to set the root user's password of your Cloud SQL instance:
gcloud sql users set-password USER --host=HOST --instance=INSTANCE_NAME --password=PASSWORD
For example, if you want to set the root user's password for the Cloud SQL
instance bookshelf to passw0rd!:
gcloud sql users set-password root --host=% --instance=bookshelf --password=passw0rd!
Setting up a database on the Cloud SQL instance
To store the authors, titles, publication date, and descriptions of the books, create a MySQL database:
gcloud sql databases create DATABASE_NAME --instance=INSTANCE_NAME
For example, if you want to create a database called book-data on the Cloud SQL instance bookshelf:
gcloud sql databases create book-data --instance=bookshelf
Connecting to Cloud SQL database
The sample app uses PHP's PDO to interact with the MySQL database.
For this tutorial, these parameters are specified as environment variables below in Configuring the app.
Querying a single row
When the user clicks on a book, the app queries the database and returns a single row that includes the title, author, publication date, and description of the book.
Using Cloud Storage
The sample app uses Cloud Storage to store the images, which are binary files, uploaded by users.
Creating a Cloud Storage bucket
Cloud Storage uses buckets to organize and control access to your data.
Use gcloud CLI to create a Cloud Storage bucket:
gcloud storage buckets create gs://BUCKET_NAME/ --location=BUCKET_REGION
For example, if you want to create a bucket called picture-storage in the
us-central1 region:
gcloud storage buckets create gs://picture-storage/ --location=us-central1
- If successful, you see the following output: - Creating gs://BUCKET_NAME/ 
- If not successful, you might see the following output: - ServiceException: 409 Bucket BUCKET_NAME already exists - Try again with a different bucket name. 
Connecting a project to a Cloud Storage bucket
To use Cloud Storage, you need to specify the Cloud Storage library.
Storing images
Now that you have created a Cloud Storage bucket and set up a connection, you can store images. Images can be uploaded with predefined access controls lists (ACL) to control access to the images.
In this sample app, uploaded images will have the predefined ACL
public-read. The public URL can be accessed via the
mediaLink property of your Cloud Storage object. You can use
this URL in an HTML image tag.
For instructions on how to read a private Cloud Storage object, see Downloading Objects page.
Deleting images
When a user deletes a book from the app, this code removes the image from the Cloud Storage bucket.
Configuring the app
You configure applications to run on App Engine using an app.yaml file, which specifies the application's runtime, environment variables, and other settings.
For an app with minimal configuration requirements, the app.yaml file can be a
single line:
PHP 8.1
runtime: php81
PHP 7.4
runtime: php74
You can add further configuration options and application-specific environment
variables into the app.yaml configuration file.
Adding environment variables
The app.yaml file is where environment configuration is provided to the app.
The bookshelf example used in this guide needs configuration provided
as environment variables to know how to connect to the correct Cloud SQL
instance and Cloud Storage bucket.
To deploy your app, you need to edit the app.yaml configuration file:
- Set the - GOOGLE_STORAGE_BUCKETvariable to the name of your Cloud Storage bucket.
- Set the - CLOUDSQL_CONNECTION_NAMEvariable to app-name:region:instance-name You can retrieve the necessary details by using the following- gcloudcommand:- gcloud sql instances describe INSTANCE - For a Cloud SQL Second Generation instance, the - CLOUDSQL_CONNECTION_NAMEwill be in the following format:- your_project_name:your_region:your_instance
- Uncomment and set the - CLOUD_SQL_DATABASE_NAMEvariable if the database you have created has a name other than- bookshelf. In this example, te database was created with the name- book-data.
- Review your - app.yamlfile, which should look something like:
PHP 8.1
runtime: php81
env_variables:
  GOOGLE_STORAGE_BUCKET: picture-storage
  CLOUDSQL_CONNECTION_NAME: sample-application:us-central1:bookshelf
  CLOUDSQL_USER: root
  CLOUDSQL_PASSWORD: passw0rd!
  CLOUDSQL_DATABASE_NAME: book-data
PHP 7.4
runtime: php74
env_variables:
  GOOGLE_STORAGE_BUCKET: picture-storage
  CLOUDSQL_CONNECTION_NAME: sample-application:us-central1:bookshelf
  CLOUDSQL_USER: root
  CLOUDSQL_PASSWORD: passw0rd!
  CLOUDSQL_DATABASE_NAME: book-data
Deploying the application
- To deploy the application, navigate to the - getting-starteddirectory and run the following command:- gcloud app deploy 
- When the location prompt appears, choose a location near your app users. App Engine is regional, which means the infrastructure that runs your app is located in a specific geographic area. For example, this tutorial has used the - us-central1region to deploy its storage resources. Deploy the app in the same region to decrease latency and improve performance.- In general, choosing a location near your users is a good idea, but there are cases when deploying your application near where its resources are located is recommended. Read about the available App Engine locations and resource locations. 
- View the application: - gcloud app browse 
Cleaning up
Delete your Google Cloud project to stop the billing for the resources used within the project.
To deleted your project using the following command:
gcloud projects delete PROJECT_ID
To verify the project was deleted, list your projects:
gcloud projects list
What's next
- Learn how to authenticate users.
- Learn more about writing application logs and interpreting system logs in Reading and writing application logs.
- Learn how to do work in the background asynchronously after your request using Cloud Tasks.
- Read about request handling and request routing.
- For a deeper dive into how App Engine works, see the PHP runtime environment.