PostgreSQL: DjangoでのPostgreSQLの使用
このドキュメントははじめにガイドの一部です。完全なガイドはこちらからご覧いただけます:PostgreSQLの始め方。
👋 Stackheroのドキュメントへようこそ!
Stackheroは、数多くの利点を提供するPostgreSQLクラウドソリューションを提供しています。主な利点は以下の通りです:
- 無制限の接続とデータ転送。
- PgAdminウェブUIが含まれています。
PostGIS、TimescaleDB、PgVectorなどの多くのモジュールが含まれています。- ワンクリックで簡単にアップデート。
- プライベートで専用のVMによる最適なパフォーマンスと強力なセキュリティ。
時間を節約し、生活を簡素化しましょう:StackheroのPostgreSQLクラウドホスティングソリューションを試すのにわずか5分しかかかりません!
まだインストールされていない場合は、PostgreSQLに接続するために使用されるpsycopgモジュールをインストールします:
pip install psycopg
この初期ステップでは、パスワードを直接settings.pyファイルに保存します。この方法はテスト用であり、安全ではありません。このドキュメントの後半で、ベストプラクティスの例を見つけることができます。
settings.pyファイルを開き、次の設定を追加します:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'HOST': '<XXXXXX>.stackhero-network.com',
'PORT': <PORT>,
'OPTIONS': {
'sslmode': 'require',
},
'NAME': 'admin',
'USER': 'admin',
'PASSWORD': '<ADMIN_PASSWORD>'
}
}
注意:この例は本番環境には推奨されておらず、テスト目的のみです!
接続が機能したら、資格情報を保存するためのより安全な方法を採用できます。次の例では、django-environを使用し、資格情報を.envファイルに保存します。
-
django-environをインストールします:pip install django-environ -
settings.pyファイルを開き、次のように変更します:import environ env = environ.Env() environ.Env.read_env() DATABASES = { 'default': { 'ENGINE': 'django.db.backends.postgresql', 'HOST': env('STACKHERO_POSTGRESQL_HOST'), 'PORT': <PORT>, 'OPTIONS': { 'sslmode': 'require', }, 'NAME': 'admin', 'USER': 'admin', 'PASSWORD': env('STACKHERO_POSTGRESQL_ADMIN_PASSWORD') } } -
settings.pyと同じディレクトリに.envファイルを開くか作成し、次を追加します:STACKHERO_POSTGRESQL_HOST=<XXXXXX>.stackhero-network.com STACKHERO_POSTGRESQL_ADMIN_PASSWORD=<ADMIN_PASSWORD> -
最後に、
.envを.gitignoreファイルに追加して、資格情報がGitリポジトリに保存されないようにします:
echo ".env" >> .gitignore