PHP を使用してソケット接続を作成する
コレクションでコンテンツを整理
必要に応じて、コンテンツの保存と分類を行います。
PHP を使用して、Cloud SQL for MySQL への Unix ソケット接続を開きます。
もっと見る
このコードサンプルを含む詳細なドキュメントについては、以下をご覧ください。
コードサンプル
PHP
Cloud SQL for MySQL に対する認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証の設定をご覧ください。
特に記載のない限り、このページのコンテンツはクリエイティブ・コモンズの表示 4.0 ライセンスにより使用許諾されます。コードサンプルは Apache 2.0 ライセンスにより使用許諾されます。詳しくは、Google Developers サイトのポリシーをご覧ください。Java は Oracle および関連会社の登録商標です。
[[["わかりやすい","easyToUnderstand","thumb-up"],["問題の解決に役立った","solvedMyProblem","thumb-up"],["その他","otherUp","thumb-up"]],[["わかりにくい","hardToUnderstand","thumb-down"],["情報またはサンプルコードが不正確","incorrectInformationOrSampleCode","thumb-down"],["必要な情報 / サンプルがない","missingTheInformationSamplesINeed","thumb-down"],["翻訳に関する問題","translationIssue","thumb-down"],["その他","otherDown","thumb-down"]],[],[],[],null,["# Create a socket connection by using PHP\n\nOpen a Unix socket connection to Cloud SQL for MySQL by using PHP.\n\nExplore further\n---------------\n\n\nFor detailed documentation that includes this code sample, see the following:\n\n- [Connect from App Engine flexible environment](/sql/docs/mysql/connect-app-engine-flexible)\n- [Connect from App Engine standard environment](/sql/docs/mysql/connect-app-engine-standard)\n- [Connect from Cloud Build](/sql/docs/mysql/connect-build)\n- [Connect from Cloud Run](/sql/docs/mysql/connect-run)\n- [Connect from Cloud Run functions](/sql/docs/mysql/connect-functions)\n- [Connect using the Cloud SQL Auth Proxy](/sql/docs/mysql/connect-auth-proxy)\n- [Manage database connections](/sql/docs/mysql/manage-connections)\n\nCode sample\n-----------\n\n### PHP\n\n\nTo authenticate to Cloud SQL for MySQL, set up Application Default Credentials.\nFor more information, see\n\n[Set up authentication for a local development environment](/docs/authentication/set-up-adc-local-dev-environment).\n\n namespace Google\\Cloud\\Samples\\CloudSQL\\MySQL;\n\n use PDO;\n use PDOException;\n use RuntimeException;\n use TypeError;\n\n class DatabaseUnix\n {\n public static function initUnixDatabaseConnection(): PDO\n {\n try {\n // Note: Saving credentials in environment variables is convenient, but not\n // secure - consider a more secure solution such as\n // Cloud Secret Manager (https://cloud.google.com/secret-manager) to help\n // keep secrets safe.\n $username = getenv('DB_USER'); // e.g. 'your_db_user'\n $password = getenv('DB_PASS'); // e.g. 'your_db_password'\n $dbName = getenv('DB_NAME'); // e.g. 'your_db_name'\n $instanceUnixSocket = getenv('INSTANCE_UNIX_SOCKET'); // e.g. '/cloudsql/project:region:instance'\n\n // Connect using UNIX sockets\n $dsn = sprintf(\n 'mysql:dbname=%s;unix_socket=%s',\n $dbName,\n $instanceUnixSocket\n );\n\n // Connect to the database.\n $conn = new PDO(\n $dsn,\n $username,\n $password,\n # ...\n );\n } catch (TypeError $e) {\n throw new RuntimeException(\n sprintf(\n 'Invalid or missing configuration! Make sure you have set ' .\n '$username, $password, $dbName, ' .\n 'and $instanceUnixSocket (for UNIX socket mode). ' .\n 'The PHP error was %s',\n $e-\u003egetMessage()\n ),\n (int) $e-\u003egetCode(),\n $e\n );\n } catch (PDOException $e) {\n throw new RuntimeException(\n sprintf(\n 'Could not connect to the Cloud SQL Database. Check that ' .\n 'your username and password are correct, that the Cloud SQL ' .\n 'proxy is running, and that the database exists and is ready ' .\n 'for use. For more assistance, refer to %s. The PDO error was %s',\n 'https://cloud.google.com/sql/docs/mysql/connect-external-app',\n $e-\u003egetMessage()\n ),\n (int) $e-\u003egetCode(),\n $e\n );\n }\n\n return $conn;\n }\n }\n\nWhat's next\n-----------\n\n\nTo search and filter code samples for other Google Cloud products, see the\n[Google Cloud sample browser](/docs/samples?product=cloud_sql_mysql)."]]