Installation av GeoDjango¶
Översikt¶
I allmänhet kräver installationen av GeoDjango:
spatial_databas
Detaljer för varje krav och installationsanvisningar finns i avsnitten nedan. Dessutom finns plattformsspecifika instruktioner tillgängliga för:
fönster
Använd källan
Eftersom GeoDjango utnyttjar det senaste inom geospatial mjukvaruteknik med öppen källkod, krävs det aktuella versioner av biblioteken. Om binära paket inte är tillgängliga för din plattform kan installation från källkod krävas. När du kompilerar biblioteken från källkod, följ anvisningarna noga, särskilt om du är nybörjare.
Krav¶
Python och Django¶
Eftersom GeoDjango ingår i Django hänvisar vi till Djangos installationsinstruktioner för mer information om hur du installerar.
Spatial databas¶
PostgreSQL (med PostGIS), MySQL, Oracle och SQLite (med SpatiaLite) är de spatiala databaser som för närvarande stöds.
Observera
PostGIS rekommenderas eftersom det är den mest utvecklade och funktionsrika spatiala databasen med öppen källkod.
The geospatial libraries required for a GeoDjango installation depends on the spatial database used. The following lists the library requirements, supported versions, and any notes for each of the supported database backends:
Databas |
Krav på bibliotek |
Versioner som stöds |
Anteckningar |
|---|---|---|---|
PostgreSQL |
GEOS, GDAL, PROJ, PostGIS |
14+ |
Kräver PostGIS. |
MySQL |
GEOS, GDAL |
8.0.11+ |
|
Oracle |
GEOS, GDAL |
19+ |
XE stöds inte. |
SQLite |
GEOS, GDAL, PROJ, SpatiaLite |
3.31.0+ |
Kräver SpatiaLite 4.3+ |
Se även `den här jämförelsematrisen`__ på OSGeo Wiki för PostgreSQL / PostGIS /GEOS / GDAL möjliga kombinationer.
Installation¶
Geospatiala bibliotek¶
Installation av databas¶
DATABASER konfiguration¶
Ange inställningen ENGINE till en av spatial backends.
Lägg till django.contrib.gis i INSTALLED_APPS¶
Precis som andra Django Contrib-applikationer behöver du bara lägga till django.contrib.gis till INSTALLED_APPS i dina inställningar. Detta är så att gis-mallarna kan lokaliseras - om det inte görs kommer funktioner som den geografiska administratören eller KML-webbplatskartor inte att fungera korrekt.
Felsökning¶
Om du inte hittar lösningen på ditt problem här kan du delta i gemenskapen! Detta kan du göra:
Ställ din fråga på forumet `GeoDjango`__.
File a ticket on the `Django trac`__ if you think there’s a bug. Make sure to provide a complete description of the problem, versions used, and specify the component as ”GIS”.
Inställningar för biblioteksmiljö¶
Det överlägset vanligaste problemet vid installation av GeoDjango är att de externa delade biblioteken (t.ex. för GEOS och GDAL) inte kan hittas. [Orsaken till detta problem är vanligtvis att operativsystemet inte känner till den katalog där biblioteken som byggts från källan installerades.
I allmänhet kan bibliotekssökvägen ställas in för varje användare genom att ange en miljövariabel eller genom att konfigurera bibliotekssökvägen för hela systemet.
miljövariabeln LD_LIBRARY_PATH¶
A user may set this environment variable to customize the library paths
they want to use. The typical library directory for software
built from source is /usr/local/lib. Thus, /usr/local/lib needs
to be included in the LD_LIBRARY_PATH variable. For example, the user
could place the following in their bash profile:
export LD_LIBRARY_PATH=/usr/local/lib
Ställa in sökväg för systembibliotek¶
On GNU/Linux systems, there is typically a file in /etc/ld.so.conf, which
may include additional paths from files in another directory, such as
/etc/ld.so.conf.d. As the root user, add the custom library path (like
/usr/local/lib) on a new line in ld.so.conf. This is one example of
how to do so:
$ sudo echo /usr/local/lib >> /etc/ld.so.conf
$ sudo ldconfig
For OpenSolaris users, the system library path may be modified using the
crle utility. Run crle with no options to see the current configuration
and use crle -l to set with the new library path. Be very careful when
modifying the system library path:
# crle -l $OLD_PATH:/usr/local/lib
Installera binutils¶
GeoDjango uses the find_library function (from the ctypes.util Python
module) to discover libraries. The find_library routine uses a program
called objdump (part of the binutils package) to verify a shared
library on GNU/Linux systems. Thus, if binutils is not installed on your
Linux system then Python’s ctypes may not be able to find your library even if
your library path is set correctly and geospatial libraries were built
perfectly.
Paketet binutils kan installeras på Debian- och Ubuntu-system med följande kommando:
$ sudo apt-get install binutils
På samma sätt på Red Hat- och CentOS-system:
$ sudo yum install binutils
Plattformsspecifika instruktioner¶
macOS¶
På grund av de olika paketeringssystemen som finns tillgängliga för macOS har användarna flera olika alternativ för att installera GeoDjango. Dessa alternativ är:
Postgres.app (enklast och rekommenderas)
bygga_från_källa
Detta avsnitt innehåller även instruktioner för att installera en uppgraderad version av Python från paket som tillhandahålls av Python Software Foundation, men detta är inte nödvändigt.
Python¶
Although macOS comes with Python installed, users can use `framework installers`__ provided by the Python Software Foundation. An advantage to using the installer is that macOS’s Python will remain ”pristine” for internal operating system use.
Observera
Du måste ändra miljövariabeln PATH i filen .profile så att den nya versionen av Python används när python skrivs in på kommandoraden:
export PATH=/Library/Frameworks/Python.framework/Versions/Current/bin:$PATH
Postgres.app¶
Postgres.app är en fristående PostgreSQL-server som innehåller PostGIS-tillägget. Du måste också installera gdal och libgeoip med Hemmabryggare.
När du har installerat Postgres.app lägger du till följande i din .bash_profile så att du kan köra paketets program från kommandoraden. Ersätt X.Y med versionen av PostgreSQL i Postgres.app som du installerade:
export PATH=$PATH:/Applications/Postgres.app/Contents/Versions/X.Y/bin
Du kan kontrollera om sökvägen är korrekt inställd genom att skriva which psql i en terminalprompt.
Hemmabryggare¶
`Homebrew`__ tillhandahåller ”recept” för att bygga binära filer och paket från källan. Det ger recept för GeoDjango-förutsättningarna på Macintosh-datorer som kör macOS. Eftersom Homebrew fortfarande bygger programvaran från källan krävs Xcode.
Sammanfattning:
$ brew install postgresql
$ brew install postgis
$ brew install gdal
$ brew install libgeoip
Fink¶
`Kurt Schwehr`__ har varit snäll nog att skapa GeoDjango-paket för användare av `Fink`__-paketsystemet. olika paket finns tillgängliga (börjar med django-gis), beroende på vilken version av Python du vill använda.
MacPorts¶
`MacPorts`__ may be used to install GeoDjango prerequisites on computers running macOS. Because MacPorts still builds the software from source, Xcode is required.
Sammanfattning:
$ sudo port install postgresql14-server
$ sudo port install geos
$ sudo port install proj6
$ sudo port install postgis3
$ sudo port install gdal
$ sudo port install libgeoip
Observera
Du måste också ändra PATH i din .profile så att MacPorts-programmen är tillgängliga från kommandoraden:
export PATH=/opt/local/bin:/opt/local/lib/postgresql14/bin
Dessutom ska du lägga till inställningen DYLD_FALLBACK_LIBRARY_PATH så att biblioteken kan hittas av Python:
export DYLD_FALLBACK_LIBRARY_PATH=/opt/local/lib:/opt/local/lib/postgresql14
Fönster¶
Fortsätt genom följande avsnitt i tur och ordning för att installera GeoDjango på Windows. I denna handledning kommer vi att installera 64-bitarsversioner av varje applikation.
Python¶
Installera en 64-bitarsversion av Python. Se Installera Python för ytterligare information.
PostgreSQL¶
Download the latest `PostgreSQL 15.x installer`__ from the `EnterpriseDB`__ website. After downloading, run the installer, follow the on-screen directions, and keep the default options unless you know the consequences of changing them.
Observera
PostgreSQL-installationsprogrammet skapar en ny postgres databas superanvändare Du kommer att uppmanas en gång att ställa in lösenordet - se till att komma ihåg det!
När installationsprogrammet är klart kommer det att fråga om ”Launch Stack Builder at exit?” – håll detta markerat, eftersom det är nödvändigt att installera PostGIS.
Observera
Om den har installerats framgångsrikt kommer PostgreSQL-servern att köras i bakgrunden varje gång systemet startas som en Windows-tjänst. En :menyval:`PostgreSQL 15` startmenygrupp kommer att skapas och innehåller genvägar för Application Stack Builder (ASB) samt ’SQL Shell’, som startar ett `` psql`` kommandofönster.
PostGIS¶
Från Stack Builder (för att köra utanför installationsprogrammet, ), välj från rullgardinsmenyn och klicka på nästa. Expandera menyträd och välj .
När du har klickat på nästa uppmanas du att bekräfta det valda paketet och ”Download directory”. Klicka på nästa igen, detta kommer att ladda ner PostGIS och du kommer att bli ombedd att klicka på nästa för att starta PostGIS-installationsprogrammet. Välj standardalternativ under installationen. Installationsprocessen innehåller fyra Ja/Nej-dialogrutor, standardalternativet för alla fyra är ”Nej”.
OSGeo4W¶
The OSGeo4W installer helps to install the PROJ, GDAL, and GEOS libraries required by GeoDjango. First, download the OSGeo4W installer, and run it. Select and click next. In the ’Select Packages’ list, ensure that GDAL is selected. If any other packages are enabled by default, they are not required by GeoDjango and may be unchecked safely. After clicking next and accepting the license agreements, the packages will be automatically downloaded and installed, after which you may exit the installer.
Ändra Windows-miljön¶
In order to use GeoDjango, you will need to add your OSGeo4W
directories to your Windows system Path, as well as create GDAL_DATA
and PROJ_LIB environment variables. The following set of commands,
executable with cmd.exe, will set this up. Restart your device
once this is complete for new environment variables to be recognized:
set OSGEO4W_ROOT=C:\OSGeo4W
set GDAL_DATA=%OSGEO4W_ROOT%\apps\gdal\share\gdal
set PROJ_LIB=%OSGEO4W_ROOT%\share\proj
set PATH=%PATH%;%OSGEO4W_ROOT%\bin
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v Path /t REG_EXPAND_SZ /f /d "%PATH%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v GDAL_DATA /t REG_EXPAND_SZ /f /d "%GDAL_DATA%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v PROJ_LIB /t REG_EXPAND_SZ /f /d "%PROJ_LIB%"
Observera
Administratörsbehörighet krävs för att utföra dessa kommandon. För att göra detta kör du kommandotolken som administratör och anger kommandona ovan. Du måste logga ut och logga in igen för att inställningarna ska börja gälla.
Observera
Om du har anpassat OSGeo4W:s installationskataloger måste du ändra variablerna OSGEO4W_ROOT i enlighet med detta.
Installera Django och konfigurera databasen¶
Installera Django på ditt system. Det rekommenderas att du skapar en virtuell miljö för varje projekt du skapar.
psycopg¶
Python-modulen `` psycopg`` tillhandahåller gränssnittet mellan Python och PostgreSQL-databasen. psycopg kan installeras via pip inom din virtuella Python-miljö:
...\> py -m pip install psycopg
Fotnoter