🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Google Cloud Platform

Google Cloud Platformは、Google社がクラウド上で提供しているサービス郡の総称です。エンドユーザー向けサービスと同様のインフラストラクチャーで運営されており、Webサイト開発から複雑なアプリ開発まで対応可能です。

docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

解決済

1回答

976閲覧

Docker環境にてCloudSQLのWordpress接続について

sika

総合スコア52

Google Cloud Platform

Google Cloud Platformは、Google社がクラウド上で提供しているサービス郡の総称です。エンドユーザー向けサービスと同様のインフラストラクチャーで運営されており、Webサイト開発から複雑なアプリ開発まで対応可能です。

docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2021/03/12 09:07

現在、ローカルMacからDockerにてwordpress環境を構築し
Google App Engineにデププロイを目的としデータベースをCloud SQLからの接続を試みています

  1. GCPから新規プロジェクトとCloudSQLイスタンスとデータベースは作成済み
  2. CloudSQLのサービスアカウント(認証キー)作成とプロキシ実行からローカルMacからのCloudSQLの操作は可能

Dockerを以下のdocker-composeで立ち上げてlocalhost:8000にアクセスすると
データベース接続エラーページとなり
php_network_getaddresses: getaddrinfo failed: Name or service not known
のメッセージが表示されます

docker-compose.yml

docker

1version: '3' 2 3 wordpress: 4 image: wordpress:latest 5 container_name: wordpress 6 volumes: 7 - ./wordpress/:/var/www/html/ 8 ports: 9 - "8000:80" 10 restart: always 11 env_file: .env 12 environment: 13 - WORDPRESS_DB_HOST 14 - WORDPRESS_DB_USER 15 - WORDPRESS_DB_PASSWORD 16 depends_on: 17 - cloud-sql-proxy 18 19 20 cloud-sql-proxy: 21 container_name: cloudsql-proxy 22 image: gcr.io/cloudsql-docker/gce-proxy:1.19.1 23 volumes: 24 - ./key.json:/config 25 ports: 26 - 3306:3306 27 restart: always 28 command: 29 - "/cloud_sql_proxy" 30 - "-instances=<PROJECT_NAME>:asia-northeast1:<DB_INSTANCE>=tcp:0.0.0.0:3306" 31 - "-credential_file=/config" 32 33volumes: 34 wordpress:

ローカル上でのCloudSQLとの接続は問題ないと思うのですが、Dockerコンテナ上でどう接続状態を確認すれば良いのかわかりません。
ご教授お願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

68user

2021/03/14 14:02

docker-compose よくわかってませんが、WordPress に localhost:3306 に接続せよというのはどうやって指定しているのですか? .env に書いてあるのでしょうか? 最終的に wordpress コンテナに狙いの環境変数が渡っていることは確認済みでしょうか?
sika

2021/03/15 04:36

回答ありがとうございます。 MySQLやWPの接続情報はenvファイルに指定しいていた接続先が原因でした。
guest

回答1

0

自己解決

envファイルに記していたwordpressの接続先が原因でした。

envファイル

1# つながらない指定 2WORDPRESS_DB_HOST: 127.0.0.1 3 4# 繋がった指定 5WORDPRESS_DB_HOST: cloud-sql-proxy

投稿2021/03/15 04:36

sika

総合スコア52

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問