Heim >Backend-Entwicklung >Python-Tutorial >Verbinden Sie Postgres mit Docker und Django

Verbinden Sie Postgres mit Docker und Django

王林
王林Original
2024-08-08 15:36:021409Durchsuche

Connect postgres with docker and django

Um PostgreSQL mit Docker und Django zu verbinden, befolgen Sie diese Schritte:

  1. Docker und Docker Compose einrichten:
    Stellen Sie sicher, dass Docker und Docker Compose auf Ihrem Computer installiert sind.

  2. Erstellen Sie eine Docker Compose-Datei:
    Erstellen Sie eine docker-compose.yml-Datei, um die Dienste für Django und PostgreSQL zu definieren.

version: '3.8'

services:
  db:
    image: postgres:13
    environment:
      POSTGRES_DB: mydatabase
      POSTGRES_USER: myuser
      POSTGRES_PASSWORD: mypassword
    volumes:
      - postgres_data:/var/lib/postgresql/data

  web:
    build: .
    command: python manage.py runserver 0.0.0.0:8000
    volumes:
      - .:/code
    ports:
      - "8000:8000"
    depends_on:
      - db

volumes:
  postgres_data:
  1. Erstellen Sie eine Docker-Datei für Django: Erstellen Sie eine Docker-Datei im Stammverzeichnis Ihres Django-Projekts.
# Use the official Python image from the Docker Hub
FROM python:3.9

# Set the working directory in the container
WORKDIR /code

# Copy the requirements file into the container
COPY requirements.txt /code/

# Install the dependencies
RUN pip install -r requirements.txt

# Copy the rest of the application code into the container
COPY . /code/
  1. Konfigurieren Sie Django für die Verwendung von PostgreSQL: Aktualisieren Sie Ihre Settings.py in Ihrem Django-Projekt, um PostgreSQL zu verwenden.
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql',
        'NAME': 'mydatabase',
        'USER': 'myuser',
        'PASSWORD': 'mypassword',
        'HOST': 'db',
        'PORT': '5432',
    }
}
  1. Abhängigkeiten installieren: Stellen Sie sicher, dass Ihre „requirements.txt“-Datei die erforderlichen Abhängigkeiten enthält.
Django>=3.2,<4.0
psycopg2-binary>=2.8,<3.0
  1. Docker Compose ausführen: Verwenden Sie Docker Compose, um Ihre Container zu erstellen und auszuführen.
docker-compose up --build
  1. Datenbank migrieren: Sobald die Container ausgeführt werden, wenden Sie die Migrationen an, um Ihre PostgreSQL-Datenbank einzurichten.
docker-compose exec web python manage.py migrate
  1. Erstellen Sie einen Superuser (optional): Erstellen Sie einen Django-Superuser, um auf das Admin-Panel zuzugreifen.
docker-compose exec web python manage.py createsuperuser

Jetzt sollten Sie über eine funktionierende Django-Anwendung verfügen, die mit einer PostgreSQL-Datenbank verbunden ist und beide in Docker-Containern ausgeführt werden. Sie können auf Ihre Anwendung unter http://localhost:8000.

zugreifen

Das obige ist der detaillierte Inhalt vonVerbinden Sie Postgres mit Docker und Django. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn