Bas*_*deh 5 django postgresql postgis gdal geodjango
Django 的官方文档列出了开始开发 PostGIS 应用程序所需的 3 个依赖项。他们根据数据库列出一个表。
我使用 docker 进行本地开发,但我很困惑哪些包应该安装在 Django 容器中,哪些包应该安装在 PostgreSQL 容器中。我猜其中一些应该同时存在。
我将非常感谢您对此的帮助。
您只需在 Django 容器中安装地理空间库,因为它们用于与支持空间的数据库(例如带有 PostGIS 的 PostgreSQL)进行交互。您可以使用现成的映像作为基础来部署此类数据库,例如kartoza/postgis。
这是一个很好的Dockerfile 示例,它使用 python:3.6-slim 作为基础并将 GDAL 依赖项构建到容器中。您需要的 Dockerfile 部分如下:
FROM python:3.6-slim
ENV PYTHONUNBUFFERED=1
# Add unstable repo to allow us to access latest GDAL builds
# Existing binutils causes a dependency conflict, correct version will be installed when GDAL gets intalled
RUN echo deb http://deb.debian.org/debian testing main contrib non-free >> /etc/apt/sources.list && \
apt-get update && \
apt-get remove -y binutils && \
apt-get autoremove -y
# Install GDAL dependencies
RUN apt-get install -y libgdal-dev g++ --no-install-recommends && \
pip install pipenv && \
pip install whitenoise && \
pip install gunicorn && \
apt-get clean -y
# Update C env vars so compiler can find gdal
ENV CPLUS_INCLUDE_PATH=/usr/include/gdal
ENV C_INCLUDE_PATH=/usr/include/gdal
ENV LC_ALL="C.UTF-8"
ENV LC_CTYPE="C.UTF-8"
Run Code Online (Sandbox Code Playgroud)
您可以使用 docker-compose 部署 Django 应用程序和数据库,使用以下命令docker-compose.yaml(来自与 Dockerfile 相同的存储库):
# Sample compose file for a django app and postgis
version: '3'
services:
postgis:
image: kartoza/postgis:9.6-2.4
volumes:
- postgis_data:/var/lib/postgresql
environment:
ALLOW_IP_RANGE: 0.0.0.0/0
POSTGRES_PASS: ${POSTGRES_PASSWORD}
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_DB: postgis
web:
image: intelligems/geodjango:latest
command: python manage.py runserver 0.0.0.0:8000
environment:
DEBUG: "True"
SECRET_KEY: ${SECRET_KEY}
DATABASE_URL: postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@postgis:5432/postgis
SENTRY_DSN: ${SENTRY_DSN}
ports:
- 8000:8000
depends_on:
- postgis
volumes:
postgis_data: {}
Run Code Online (Sandbox Code Playgroud)
在此存储库中,您可以找到有关您的问题的更多信息和有趣的配置:https://github.com/intelligems/docker-library/tree/master/geodjango(上面的 Dockerfile 片段来自该存储库)。
创建卷:
$ docker volume create postgresql_data
Run Code Online (Sandbox Code Playgroud)部署容器:
$ docker run \
--name=postgresql-with-postgis -d \
-e POSTGRES_USER=user_name \
-e POSTGRES_PASS=user_pass \
-e ALLOW_IP_RANGE=0.0.0.0/0 -p 5433:5432 \
-v postgresql_data:/var/lib/postgresql \
--restart=always \
kartoza/postgis:9.6-2.4
Run Code Online (Sandbox Code Playgroud)postgres连接到容器的默认数据库 ( ) 并创建您的数据库:
$ psql -h localhost -U user_name -d postgres
$ CREATE DATABASE database_name;
Run Code Online (Sandbox Code Playgroud)启用数据库的 PostGIS 扩展:
$ \connect database_name
$ CREATE EXTENSION postgis;
Run Code Online (Sandbox Code Playgroud)这将导致一个名称为database_name监听本地主机端口 5432 的数据库,您可以从本地 Django 应用程序连接到该数据库。
| 归档时间: |
|
| 查看次数: |
1614 次 |
| 最近记录: |