WordPress in der flexiblen App Engine-Umgebung hosten

In dieser Anleitung erfahren Sie, wie eine kleine WordPress-Website in der flexiblen App Engine-Umgebung bereitgestellt wird.

Ziele

  • Eine Cloud SQL-Instanz der zweiten Generation erstellen
  • Eine WordPress-Beispielwebsite konfigurieren
  • WordPress-Beispielwebsite in der flexiblen App Engine-Umgebung bereitstellen

Kosten

Hinweis

  1. Melden Sie sich in Ihrem Google Cloud Konto an. Wenn Sie noch kein Konto bei Google Cloudhaben, erstellen Sie ein Konto, um die Leistungsfähigkeit unserer Produkte in der Praxis sehen und bewerten zu können. Neukunden erhalten außerdem ein Guthaben von 300 $, um Arbeitslasten auszuführen, zu testen und bereitzustellen.
  2. 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 role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  3. Verify that billing is enabled for your Google Cloud project.

  4. Enable the required APIs.

    Roles required to enable APIs

    To enable APIs, you need the Service Usage Admin IAM role (roles/serviceusage.serviceUsageAdmin), which contains the serviceusage.services.enable permission. Learn how to grant roles.

    Enable the APIs

  5. Installieren Sie die Google Cloud CLI.

  6. Wenn Sie einen externen Identitätsanbieter (IdP) verwenden, müssen Sie sich zuerst mit Ihrer föderierten Identität in der gcloud CLI anmelden.

  7. Führen Sie den folgenden Befehl aus, um die gcloud CLI zu initialisieren:

    gcloud init
  8. 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 role (roles/resourcemanager.projectCreator), which contains the resourcemanager.projects.create permission. Learn how to grant roles.

    Go to project selector

  9. Verify that billing is enabled for your Google Cloud project.

  10. Enable the required APIs.

    Roles required to enable APIs

    To enable APIs, you need the Service Usage Admin IAM role (roles/serviceusage.serviceUsageAdmin), which contains the serviceusage.services.enable permission. Learn how to grant roles.

    Enable the APIs

  11. Installieren Sie die Google Cloud CLI.

  12. Wenn Sie einen externen Identitätsanbieter (IdP) verwenden, müssen Sie sich zuerst mit Ihrer föderierten Identität in der gcloud CLI anmelden.

  13. Führen Sie den folgenden Befehl aus, um die gcloud CLI zu initialisieren:

    gcloud init
  14. Führen Sie die folgenden Schritte aus, um Anmeldedaten zu erstellen:
    • Rufen Sie in der Google Cloud Console die Seite Anmeldedaten auf.

      Zur Seite "API-Anmeldedaten"

    • Klicken Sie auf Anmeldedaten erstellen und wählen Sie Dienstkontoschlüssel aus.
    • Wählen Sie Dienstkonto > App Engine-Standarddienstkonto aus.
    • Klicken Sie auf Erstellen.
    • Speichern Sie den heruntergeladenen Schlüssel an einem sicheren Ort.
  15. Installieren Sie PHP und Composer.
  16. Laden Sie den Cloud SQL-Proxy herunter und machen Sie ihn ausführbar. Fügen Sie außerdem der Umgebungsvariable PATH den Speicherort der ausführbaren Datei des Cloud SQL-Proxys hinzu.
  17. Installieren Sie einen MySQL-Client und prüfen Sie, ob sich der Speicherort der ausführbaren mysql-Datei in der Umgebungsvariable PATH befindet.

Cloud SQL-Instanz der zweiten Generation erstellen und konfigurieren

  1. Erstellen Sie eine Cloud SQL-Instanz der zweiten Generation.

    gcloud sql instances create tutorial-sql-instance \
        --activation-policy=ALWAYS \
        --tier=db-n1-standard-1 \
        --region=us-central1
    
  2. Legen Sie das Root-Passwort für die Instanz fest:

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

    Dabei ist [YOUR_SQL_ROOT_PASSWORD] ein sicheres Passwort Ihrer Wahl.

  3. Laden Sie den Cloud SQL-Proxy herunter und führen Sie ihn aus:

    ./cloud-sql-proxy \
        -dir /tmp/cloudsql \
        -instances=[YOUR_PROJECT_ID]:us-central1:tutorial-sql-instance \
        -credential_file=[PATH_TO_YOUR_SERVICE_ACCOUNT_JSON]

    wobei

    • [YOUR_PROJECT_ID] Ihre Google Cloud Projekt-ID ist.

    • [PATH_TO_YOUR_SERVICE_ACCOUNT_JSON] der Pfad zu der JSON-Dienstkontodatei ist, die Sie zuvor heruntergeladen haben.

    Die folgende Ausgabe zeigt an, dass der Proxy für neue Verbindungen bereit ist:

    Listening on 127.0.0.1:3306 for [YOUR_PROJECT_ID]:us-central1:tutorial-sql-instance
    Ready for new connections
    
  4. Erstellen Sie in einem anderen Terminalfenster eine neue Datenbank und einen neuen Nutzer:

    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

    wobei

    • [YOUR_SQL_ROOT_PASSWORD] ist das Root-Passwort für die Cloud SQL-Instanz.
    • [YOUR_DATABASE_PASSWORD] ist ein sicheres Passwort Ihrer Wahl.

WordPress-Projekt einrichten

  1. Klonen Sie das Beispiel-Repository:

    git clone https://github.com/GoogleCloudPlatform/php-docs-samples.git
    
  2. Navigieren Sie zu dem Verzeichnis mit dem Beispielcode:

    cd php-docs-samples/appengine/flexible/wordpress
    
  3. Installieren Sie die Abhängigkeiten:

    composer install
    
  4. Führen Sie das Hilfsskript aus:

    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]

    Dabei gilt:

    • [YOUR_PROJECT_ID] ist die Projekt-ID.
    • [YOUR_DATABASE_PASSWORD] ist Ihr Datenbankpasswort.

    Der Parameter -dir gibt den Speicherort des WordPress-Projekts an.

  5. Das Hilfsskript schreibt Informationen in wordpress-project/wordpress/wp-config.php. Prüfen Sie, ob in wp-config.php die Namen, die Projekt-ID und das Datenbankpasswort korrekt sind.

    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]');
    }

WordPress-Projekt in der flexiblen App Engine-Umgebung bereitstellen

  1. Navigieren Sie zum Verzeichnis des WordPress-Projekts:

    cd wordpress-project
    
  2. Stellen Sie das WordPress-Projekt bereit:

    gcloud app deploy \
        --promote --stop-previous-version app.yaml cron.yaml
    
  3. Geben Sie im Webbrowser die folgende URL ein:

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

    Ersetzen Sie Folgendes:

WordPress, Plug-ins und Themen aktualisieren

WordPress, Plug-ins und Designs sollten immer auf dem neuesten Stand sein. Sie können diese Elemente mit dem wp-Tool laufend aktualisieren. Nach einer Aktualisierung müssen Sie das WordPress-Projekt noch einmal bereitstellen.

  1. Aktualisieren Sie WordPress:

    vendor/bin/wp core update --path=wordpress
    
  2. Aktualisieren Sie die Plug-ins:

    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. Aktualisieren Sie die Designs:

    vendor/bin/wp theme update --all --path=wordpress
    
  4. Stellen Sie das Projekt wieder bereit:

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

Bereinigen

Damit Ihrem Google Cloud-Konto die in dieser Anleitung verwendeten Ressourcen nicht in Rechnung gestellt werden, löschen Sie entweder das Projekt, das die Ressourcen enthält, oder Sie behalten das Projekt und löschen die einzelnen Ressourcen.

Projekt löschen

Am einfachsten vermeiden Sie weitere Kosten durch Löschen des für die Anleitung erstellten Projekts.

So löschen Sie das Projekt:

  1. Wechseln Sie in der Google Cloud Console zur Seite Ressourcen verwalten.

    Zur Seite „Ressourcen verwalten“

  2. Wählen Sie in der Projektliste das Projekt aus, das Sie löschen möchten, und klicken Sie dann auf Löschen.
  3. Geben Sie im Dialogfeld die Projekt-ID ein und klicken Sie auf Shut down (Beenden), um das Projekt zu löschen.

Nicht standardmäßige Versionen der Anwendung löschen

Wenn Sie das Projekt nicht löschen möchten, können Sie trotzdem die Kosten senken. Löschen Sie dazu die nicht standardmäßigen Versionen der Anwendung.

So löschen Sie eine Anwendungsversion:

  1. Rufen Sie in der Google Cloud Console die Seite Versionen für App Engine auf.

    Zur Seite "Versionen"

  2. Klicken Sie auf das Kästchen für die nicht standardmäßige Anwendungsversion, die Sie löschen möchten.
  3. Klicken Sie zum Löschen der Anwendungsversion auf Löschen.

Cloud SQL-Instanz löschen

So löschen Sie eine Cloud SQL-Instanz:

  1. Rufen Sie in der Google Cloud Console die Instanzen Seite auf.

    Zur Seite „VM-Instanzen“

  2. Klicken Sie auf den Namen der SQL-Instanz, die Sie löschen möchten.
  3. Klicken Sie zum Löschen der Instanz auf Löschen und folgen Sie der Anleitung.

Nächste Schritte