# GCP - Cloud SQL Enum
{{#include ../../../banners/hacktricks-training.md}}
## 基本情報
Google Cloud SQLは、**MySQL、PostgreSQL、SQL Server**などのリレーショナルデータベースをGoogle Cloud Platform上で設定、維持、管理することを**簡素化する**マネージドサービスであり、ハードウェアのプロビジョニング、データベースのセットアップ、パッチ適用、バックアップなどのタスクを処理する必要がなくなります。
Google Cloud SQLの主な機能は以下の通りです:
1. **完全管理**:Google Cloud SQLは完全管理サービスであり、Googleがパッチ適用、更新、バックアップ、構成などのデータベースメンテナンスタスクを処理します。
2. **スケーラビリティ**:データベースのストレージ容量と計算リソースをスケールアップする能力を提供し、しばしばダウンタイムなしで実現します。
3. **高可用性**:高可用性構成を提供し、データベースサービスが信頼性が高く、ゾーンやインスタンスの障害に耐えられるようにします。
4. **セキュリティ**:データ暗号化、アイデンティティとアクセス管理(IAM)制御、プライベートIPとVPCを使用したネットワーク隔離などの堅牢なセキュリティ機能を提供します。
5. **バックアップと復元**:自動バックアップと時点復元をサポートし、データを保護し復元するのに役立ちます。
6. **統合**:他のGoogle Cloudサービスとシームレスに統合され、アプリケーションの構築、展開、管理のための包括的なソリューションを提供します。
7. **パフォーマンス**:データベースのパフォーマンスを監視、トラブルシューティング、改善するためのパフォーマンスメトリクスと診断を提供します。
### パスワード
ウェブコンソールではCloud SQLがユーザーに**データベースのパスワードを設定**することを許可しており、生成機能もありますが、最も重要なのは、**MySQL**が**空のパスワードを許可し、すべてのデータベースがパスワードとして文字"a"のみを設定することを許可することです:**
**長さ**、**複雑さ**、**再利用の無効化**、および**パスワードにユーザー名を使用しない**ことを要求するパスワードポリシーを構成することも可能です。すべての設定はデフォルトで無効になっています。
**SQL Server**は**Active Directory Authentication**で構成できます。
### ゾーンの可用性
データベースは**1つのゾーンまたは複数のゾーンで利用可能**であり、重要なデータベースは複数のゾーンに配置することが推奨されます。
### 暗号化
デフォルトではGoogle管理の暗号化キーが使用されますが、**顧客管理の暗号化キー(CMEK)を選択することも可能です**。
### 接続
- **プライベートIP**:VPCネットワークを指定すると、データベースはネットワーク内にプライベートIPを取得します。
- **パブリックIP**:データベースはパブリックIPを取得しますが、デフォルトでは誰も接続できません。
- **承認されたネットワーク**:データベースに接続を許可すべきパブリック**IP範囲を指定**します。
- **プライベートパス**:DBがVPCに接続されている場合、このオプションを有効にして**BigQueryなどの他のGCPサービスにアクセスを提供する**ことが可能です。
### データ保護
- **毎日のバックアップ**:自動的に毎日のバックアップを実行し、維持したいバックアップの数を指定します。
- **時点復元**:特定の時点からデータを復元することを可能にし、秒の一部まで対応します。
- **削除保護**:有効にすると、この機能が無効になるまでDBを削除できなくなります。
### 列挙
```bash
# Get SQL instances
gcloud sql instances list
gcloud sql instances describe # get IPs, CACert, settings
# Get database names inside an instance (like information_schema, sys...)
gcloud sql databases list --instance
gcloud sql databases describe --instance
# Get usernames inside the db instance
gcloud sql users list --instance
# Backups
gcloud sql backups list --instance
gcloud sql backups describe --instance
```
### 認証されていない列挙
{{#ref}}
../gcp-unauthenticated-enum-and-access/gcp-cloud-sql-unauthenticated-enum.md
{{#endref}}
### ポストエクスプロイテーション
{{#ref}}
../gcp-post-exploitation/gcp-cloud-sql-post-exploitation.md
{{#endref}}
### 永続性
{{#ref}}
../gcp-persistence/gcp-cloud-sql-persistence.md
{{#endref}}
{{#include ../../../banners/hacktricks-training.md}}