geolibs.txt 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. ===============================
  2. Installing Geospatial libraries
  3. ===============================
  4. GeoDjango uses and/or provides interfaces for the following open source
  5. geospatial libraries:
  6. ======================== ==================================== ================================ ===================================
  7. Program Description Required Supported Versions
  8. ======================== ==================================== ================================ ===================================
  9. :doc:`GEOS <../geos>` Geometry Engine Open Source Yes 3.4, 3.3
  10. `PROJ.4`_ Cartographic Projections library Yes (PostgreSQL and SQLite only) 4.9, 4.8, 4.7, 4.6, 4.5, 4.4
  11. :doc:`GDAL <../gdal>` Geospatial Data Abstraction Library Yes 2.1, 2.0, 1.11, 1.10, 1.9, 1.8, 1.7
  12. :doc:`GeoIP <../geoip>` IP-based geolocation library No 1.4
  13. `PostGIS`__ Spatial extensions for PostgreSQL Yes (PostgreSQL only) 2.2, 2.1
  14. `SpatiaLite`__ Spatial extensions for SQLite Yes (SQLite only) 4.3, 4.2, 4.1, 4.0
  15. ======================== ==================================== ================================ ===================================
  16. Note that older or more recent versions of these libraries *may* also work
  17. totally fine with GeoDjango. Your mileage may vary.
  18. .. versionchanged:: 1.11
  19. In older versions, GDAL is required only for SQLite. Now it's required for
  20. all databases.
  21. ..
  22. Libs release dates:
  23. GEOS 3.3.0 2011-05-30
  24. GEOS 3.4.0 2013-08-11
  25. GDAL 1.7.1 2010-02-08
  26. GDAL 1.8.0 2011-01-13
  27. GDAL 1.9.0 2012-01-03
  28. GDAL 1.10.0 2013-04-29
  29. GDAL 1.11.0 2014-04-25
  30. GDAL 2.0.0 2015-06
  31. GDAL 2.1.0 2016-04
  32. PostGIS 2.1.0 2013-08-17
  33. PostGIS 2.2.0 2015-10-17
  34. Spatialite 4.0.0 2012-11-25
  35. Spatialite 4.1.0 2013-06-04
  36. Spatialite 4.2.0 2014-07-25
  37. Spatialite 4.3.0 2015-09-07
  38. .. note::
  39. The GeoDjango interfaces to GEOS, GDAL, and GeoIP may be used
  40. independently of Django. In other words, no database or settings file
  41. required -- just import them as normal from :mod:`django.contrib.gis`.
  42. .. _PROJ.4: https://github.com/OSGeo/proj.4/wiki/
  43. __ http://postgis.net/
  44. __ http://www.gaia-gis.it/gaia-sins/
  45. On Debian/Ubuntu, you are advised to install the following packages which will
  46. install, directly or by dependency, the required geospatial libraries:
  47. .. code-block:: console
  48. $ sudo apt-get install binutils libproj-dev gdal-bin
  49. Optional packages to consider:
  50. * ``libgeoip1``: for :doc:`GeoIP <../geoip>` support
  51. * ``gdal-bin``: for GDAL command line programs like ``ogr2ogr``
  52. * ``python-gdal`` for GDAL's own Python bindings -- includes interfaces for raster manipulation
  53. Please also consult platform-specific instructions if you are on :ref:`macosx`
  54. or :ref:`windows`.
  55. .. _build_from_source:
  56. Building from source
  57. ====================
  58. When installing from source on UNIX and GNU/Linux systems, please follow
  59. the installation instructions carefully, and install the libraries in the
  60. given order. If using MySQL or Oracle as the spatial database, only GEOS
  61. is required.
  62. .. note::
  63. On Linux platforms, it may be necessary to run the ``ldconfig`` command
  64. after installing each library. For example::
  65. $ sudo make install
  66. $ sudo ldconfig
  67. .. note::
  68. OS X users are required to install `Apple Developer Tools`_ in order
  69. to compile software from source. This is typically included on your
  70. OS X installation DVDs.
  71. .. _Apple Developer Tools: https://developer.apple.com/technologies/tools/
  72. .. _geosbuild:
  73. GEOS
  74. ----
  75. GEOS is a C++ library for performing geometric operations, and is the default
  76. internal geometry representation used by GeoDjango (it's behind the "lazy"
  77. geometries). Specifically, the C API library is called (e.g., ``libgeos_c.so``)
  78. directly from Python using ctypes.
  79. First, download GEOS 3.4.2 from the GEOS website and untar the source
  80. archive::
  81. $ wget http://download.osgeo.org/geos/geos-3.4.2.tar.bz2
  82. $ tar xjf geos-3.4.2.tar.bz2
  83. Next, change into the directory where GEOS was unpacked, run the configure
  84. script, compile, and install::
  85. $ cd geos-3.4.2
  86. $ ./configure
  87. $ make
  88. $ sudo make install
  89. $ cd ..
  90. Troubleshooting
  91. ~~~~~~~~~~~~~~~
  92. Can't find GEOS library
  93. ^^^^^^^^^^^^^^^^^^^^^^^
  94. When GeoDjango can't find GEOS, this error is raised:
  95. .. code-block:: text
  96. ImportError: Could not find the GEOS library (tried "geos_c"). Try setting GEOS_LIBRARY_PATH in your settings.
  97. The most common solution is to properly configure your :ref:`libsettings` *or* set
  98. :ref:`geoslibrarypath` in your settings.
  99. If using a binary package of GEOS (e.g., on Ubuntu), you may need to :ref:`binutils`.
  100. .. _geoslibrarypath:
  101. ``GEOS_LIBRARY_PATH``
  102. ^^^^^^^^^^^^^^^^^^^^^
  103. If your GEOS library is in a non-standard location, or you don't want to
  104. modify the system's library path then the :setting:`GEOS_LIBRARY_PATH`
  105. setting may be added to your Django settings file with the full path to the
  106. GEOS C library. For example::
  107. GEOS_LIBRARY_PATH = '/home/bob/local/lib/libgeos_c.so'
  108. .. note::
  109. The setting must be the *full* path to the **C** shared library; in
  110. other words you want to use ``libgeos_c.so``, not ``libgeos.so``.
  111. See also :ref:`My logs are filled with GEOS-related errors <geos-exceptions-in-logfile>`.
  112. .. _proj4:
  113. PROJ.4
  114. ------
  115. `PROJ.4`_ is a library for converting geospatial data to different coordinate
  116. reference systems.
  117. First, download the PROJ.4 source code and datum shifting files [#]_::
  118. $ wget http://download.osgeo.org/proj/proj-4.9.1.tar.gz
  119. $ wget http://download.osgeo.org/proj/proj-datumgrid-1.5.tar.gz
  120. Next, untar the source code archive, and extract the datum shifting files in the
  121. ``nad`` subdirectory. This must be done *prior* to configuration::
  122. $ tar xzf proj-4.9.1.tar.gz
  123. $ cd proj-4.9.1/nad
  124. $ tar xzf ../../proj-datumgrid-1.5.tar.gz
  125. $ cd ..
  126. Finally, configure, make and install PROJ.4::
  127. $ ./configure
  128. $ make
  129. $ sudo make install
  130. $ cd ..
  131. .. _gdalbuild:
  132. GDAL
  133. ----
  134. `GDAL`__ is an excellent open source geospatial library that has support for
  135. reading most vector and raster spatial data formats. Currently, GeoDjango only
  136. supports :doc:`GDAL's vector data <../gdal>` capabilities [#]_.
  137. :ref:`geosbuild` and :ref:`proj4` should be installed prior to building GDAL.
  138. First download the latest GDAL release version and untar the archive::
  139. $ wget http://download.osgeo.org/gdal/1.11.2/gdal-1.11.2.tar.gz
  140. $ tar xzf gdal-1.11.2.tar.gz
  141. $ cd gdal-1.11.2
  142. Configure, make and install::
  143. $ ./configure
  144. $ make # Go get some coffee, this takes a while.
  145. $ sudo make install
  146. $ cd ..
  147. .. note::
  148. Because GeoDjango has its own Python interface, the preceding instructions
  149. do not build GDAL's own Python bindings. The bindings may be built by
  150. adding the ``--with-python`` flag when running ``configure``. See
  151. `GDAL/OGR In Python`__ for more information on GDAL's bindings.
  152. If you have any problems, please see the troubleshooting section below for
  153. suggestions and solutions.
  154. __ https://trac.osgeo.org/gdal/
  155. __ https://trac.osgeo.org/gdal/wiki/GdalOgrInPython
  156. .. _gdaltrouble:
  157. Troubleshooting
  158. ~~~~~~~~~~~~~~~
  159. Can't find GDAL library
  160. ^^^^^^^^^^^^^^^^^^^^^^^
  161. When GeoDjango can't find the GDAL library, the ``HAS_GDAL`` flag
  162. will be false:
  163. .. code-block:: pycon
  164. >>> from django.contrib.gis import gdal
  165. >>> gdal.HAS_GDAL
  166. False
  167. The solution is to properly configure your :ref:`libsettings` *or* set
  168. :ref:`gdallibrarypath` in your settings.
  169. .. _gdallibrarypath:
  170. ``GDAL_LIBRARY_PATH``
  171. ^^^^^^^^^^^^^^^^^^^^^
  172. If your GDAL library is in a non-standard location, or you don't want to
  173. modify the system's library path then the :setting:`GDAL_LIBRARY_PATH`
  174. setting may be added to your Django settings file with the full path to
  175. the GDAL library. For example::
  176. GDAL_LIBRARY_PATH = '/home/sue/local/lib/libgdal.so'
  177. .. rubric:: Footnotes
  178. .. [#] The datum shifting files are needed for converting data to and from
  179. certain projections.
  180. For example, the PROJ.4 string for the `Google projection (900913 or 3857)
  181. <http://spatialreference.org/ref/sr-org/6864/prj/>`_ requires the
  182. ``null`` grid file only included in the extra datum shifting files.
  183. It is easier to install the shifting files now, then to have debug a
  184. problem caused by their absence later.
  185. .. [#] Specifically, GeoDjango provides support for the `OGR
  186. <http://gdal.org/ogr_arch.html>`_ library, a component of GDAL.