Hosting di WordPress nell'ambiente flessibile di App Engine


Questo tutorial mostra come eseguire il deployment di un piccolo sito WordPress nell'ambiente flessibile di App Engine.

Obiettivi

  • Creare un'istanza Cloud SQL di seconda generazione.
  • Configurare un sito WordPress di esempio.
  • Esegui il deployment del sito WordPress di esempio nell'ambiente flessibile di App Engine.

Costi

Prima di iniziare

  1. Accedi al tuo account Google Cloud. Se non conosci Google Cloud, crea un account per valutare le prestazioni dei nostri prodotti in scenari reali. I nuovi clienti ricevono anche 300 $di crediti gratuiti per l'esecuzione, il test e il deployment dei carichi di lavoro.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  3. Assicurati che la fatturazione sia attivata per il tuo progetto Google Cloud.

  4. Abilita le API richieste.

    Abilita le API

  5. Installa Google Cloud CLI.
  6. Per initialize gcloud CLI, esegui questo comando:

    gcloud init
  7. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  8. Assicurati che la fatturazione sia attivata per il tuo progetto Google Cloud.

  9. Abilita le API richieste.

    Abilita le API

  10. Installa Google Cloud CLI.
  11. Per initialize gcloud CLI, esegui questo comando:

    gcloud init
  12. Per creare le credenziali, segui questi passaggi:
    • Nella console Google Cloud, vai alla pagina Credenziali.

      Apri la pagina Credenziali API

    • Fai clic su Crea credenziali e seleziona Chiave account di servizio.
    • Seleziona Account di servizio > Account di servizio predefinito di App Engine.
    • Fai clic su Crea.
    • Salva la chiave scaricata in un luogo sicuro.
  13. Installa PHP e Composer.
  14. Scarica il proxy Cloud SQL e rendilo eseguibile. Inoltre, aggiungi la posizione del file eseguibile del proxy Cloud SQL alla variabile di ambiente PATH.
  15. Installa un client MySQL e verifica che la posizione del file eseguibile mysql si trovi nella variabile di ambiente PATH.

Creazione e configurazione di un'istanza Cloud SQL di seconda generazione

  1. Crea un'istanza Cloud SQL di seconda generazione:

    gcloud sql instances create tutorial-sql-instance \
        --activation-policy=ALWAYS \
        --tier=db-n1-standard-1 \
        --region=us-central1
    
  2. Imposta una password radice per l'istanza:

    gcloud sql users set-password root --instance tutorial-sql-instance \
        --password [YOUR_SQL_ROOT_PASSWORD] \
        --host %
    

    dove [YOUR_SQL_ROOT_PASSWORD] è una password sicura scelta da te.

  3. Scarica ed esegui il proxy Cloud SQL:

    wget https://dl.google.com/cloudsql/cloud_sql_proxy.linux.amd64 -O cloud_sql_proxy
    cloud_sql_proxy \
        -dir /tmp/cloudsql \
        -instances=[YOUR_PROJECT_ID]:us-central1:tutorial-sql-instance=tcp:3306 \
        -credential_file=[PATH_TO_YOUR_SERVICE_ACCOUNT_JSON]
    

    dove

    • [YOUR_PROJECT_ID] è l'ID del tuo progetto Google Cloud.

    • [PATH_TO_YOUR_SERVICE_ACCOUNT_JSON] è il percorso del file JSON dell'account di servizio scaricato precedentemente.

    Il seguente output indica che il proxy è pronto per nuove connessioni:

    Listening on 127.0.0.1:3306 for [YOUR_PROJECT_ID]:us-central1:tutorial-sql-instance
    Ready for new connections
    
  4. In un'altra finestra del terminale crea un nuovo database e un utente:

    mysql -h 127.0.0.1 -u root --password=[YOUR_SQL_ROOT_PASSWORD]
    mysql> create database tutorialdb;
    mysql> create user 'tutorial-user'@'%' identified by '[YOUR_DATABASE_PASSWORD]';
    mysql> grant all on tutorialdb.* to 'tutorial-user'@'%';
    mysql> exit
    

    dove:

    • [YOUR_SQL_ROOT_PASSWORD] è la password root per l'istanza Cloud SQL.
    • [YOUR_DATABASE_PASSWORD] è una password sicura scelta da te.

Configurazione del progetto WordPress

  1. Clona il repository di esempio:

    git clone https://github.com/GoogleCloudPlatform/php-docs-samples.git
    
  2. Vai alla directory che contiene il codice di esempio:

    cd php-docs-samples/appengine/flexible/wordpress
    
  3. Installa le dipendenze:

    composer install
    
  4. Esegui lo script di supporto:

    php wordpress.php setup -n \
        --dir=./wordpress-project \
        --db_instance=tutorial-sql-instance \
        --db_name=tutorialdb \
        --db_user=tutorial-user \
        --project_id=[YOUR_PROJECT_ID] \
        --db_password=[YOUR_DATABASE_PASSWORD]
    

    dove:

    • [YOUR_PROJECT_ID] è l'ID progetto.
    • [YOUR_DATABASE_PASSWORD] è la password del database.

    Il parametro -dir specifica la posizione del progetto WordPress.

  5. Lo script di supporto scrive informazioni in wordpress-project/wordpress/wp-config.php. Controlla i contenuti di wp-config.php per verificare che i nomi, l'ID progetto e la password del database siano corretti.

    if ($onGae) {
        /** Production environment */
        define('DB_HOST', ':/cloudsql/[YOUR_PROJECT_ID]:us-central1:tutorial-sql-instance');
        /** The name of the database for WordPress */
        define('DB_NAME', 'tutorialdb');
        /** MySQL database username */
        define('DB_USER', 'tutorial-user');
        /** MySQL database password */
        define('DB_PASSWORD', '[YOUR_DATABASE_PASSWORD]');
    } else {
        /** Local environment */
        define('DB_HOST', '127.0.0.1');
        /** The name of the database for WordPress */
        define('DB_NAME', 'tutorialdb');
        /** MySQL database username */
        define('DB_USER', 'tutorial-user');
        /** MySQL database password */
        define('DB_PASSWORD', '[YOUR_DATABASE_PASSWORD]');
    }
    

Distribuzione del progetto WordPress nell'ambiente flessibile di App Engine

  1. Vai alla directory del progetto WordPress:

    cd wordpress-project
    
  2. Distribuisci il progetto WordPress:

    gcloud app deploy \
        --promote --stop-previous-version app.yaml cron.yaml
    
  3. Nel browser, inserisci il seguente URL:

    https://PROJECT_ID.REGION_ID.r.appspot.com

    Sostituisci quanto segue:

Aggiornamento di WordPress, plug-in e temi

È importante tenere aggiornati WordPress, plug-in e temi. Puoi mantenere aggiornati questi elementi utilizzando lo strumento wp. Dopo un aggiornamento, devi eseguire nuovamente il deployment del progetto WordPress.

  1. Aggiorna WordPress:

    vendor/bin/wp core update --path=wordpress
    
  2. Aggiorna i plug-in:

    vendor/bin/wp plugin update --all --path=wordpress
    # Just in case it updates any of the dropins, copy the files:
    cp wordpress/wp-content/plugins/batcache/advanced-cache.php \
        wordpress/wp-content/plugins/memcached/object-cache.php \
        wordpress/wp-content
    
  3. Aggiorna temi:

    vendor/bin/wp theme update --all --path=wordpress
    
  4. Distribuisci nuovamente il progetto:

    gcloud app deploy \
        --promote --stop-previous-version app.yaml cron.yaml
    

Esegui la pulizia

Per evitare che al tuo Account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questo tutorial, elimina il progetto che contiene le risorse oppure mantieni il progetto ed elimina le singole risorse.

Elimina il progetto

Il modo più semplice per eliminare la fatturazione è eliminare il progetto che hai creato per il tutorial.

Per eliminare il progetto:

  1. Nella console Google Cloud, vai alla pagina Gestisci risorse.

    Vai a Gestisci risorse

  2. Nell'elenco dei progetti, seleziona il progetto che vuoi eliminare, quindi fai clic su Elimina.
  3. Nella finestra di dialogo, digita l'ID del progetto e fai clic su Chiudi per eliminare il progetto.

Elimina le versioni non predefinite dell'applicazione

Se non intendi eliminare il progetto, puoi ridurre i costi eliminando le versioni non predefinite dell'applicazione.

Per eliminare una versione dell'applicazione:

  1. Nella console Google Cloud, vai alla pagina Versioni di App Engine.

    Vai a Versioni

  2. Seleziona la casella di controllo relativa alla versione non predefinita dell'app che vuoi eliminare.
  3. Per eliminare la versione dell'app, fai clic su Elimina.

Elimina l'istanza Cloud SQL

Per eliminare un'istanza Cloud SQL:

  1. Nella console Google Cloud, vai alla pagina Istanze.

    Vai a Istanze

  2. Fai clic sul nome l'istanza SQL che vuoi eliminare.
  3. Per eliminare l'istanza, fai clic su Elimina, quindi segui le istruzioni.

Passaggi successivi