spatial-d4science/doc/install.rst

401 lines
16 KiB
ReStructuredText

======================
Installation and Setup
======================
Check the Troubleshooting_ section if you get errors at any stage.
.. _install_postgis:
Install PostGIS and system packages
-----------------------------------
.. warning:: If you are looking for the geospatial preview plugins to render (eg GeoJSON
or WMS services), these are now located in ckanext-geoview_. They have a much simpler
installation, so you can skip all the following steps if you just want the previews.
.. note:: The package names and paths shown are the defaults on Ubuntu installs.
Adjust the package names and the paths if you are using a different platform.
All commands assume an existing CKAN database named ``ckan_default``.
Ubuntu 14.04 (PostgreSQL 9.3 and PostGIS 2.1)
+++++++++++++++++++++++++++++++++++++++++++++
#. Install PostGIS::
sudo apt-get install postgresql-9.3-postgis-2.1
#. Run the following commands. The first one will create the necessary
tables and functions in the database, and the second will populate
the spatial reference table::
sudo -u postgres psql -d ckan_default -f /usr/share/postgresql/9.3/contrib/postgis-2.1/postgis.sql
sudo -u postgres psql -d ckan_default -f /usr/share/postgresql/9.3/contrib/postgis-2.1/spatial_ref_sys.sql
#. Change the owner of spatial tables to the CKAN user to avoid errors later
on::
sudo -u postgres psql -d ckan_default -c 'ALTER VIEW geometry_columns OWNER TO ckan_default;'
sudo -u postgres psql -d ckan_default -c 'ALTER TABLE spatial_ref_sys OWNER TO ckan_default;'
#. Execute the following command to see if PostGIS was properly
installed::
sudo -u postgres psql -d ckan_default -c "SELECT postgis_full_version()"
You should get something like::
postgis_full_version
----------------------------------------------------------------------------------------------------------------------------------------------------------------------
POSTGIS="2.1.2 r12389" GEOS="3.4.2-CAPI-1.8.2 r3921" PROJ="Rel. 4.8.0, 6 March 2012" GDAL="GDAL 1.10.1, released 2013/08/26" LIBXML="2.9.1" LIBJSON="UNKNOWN" RASTER
(1 row)
#. Install some other packages needed by the extension dependencies::
sudo apt-get install python-dev libxml2-dev libxslt1-dev libgeos-c1
Ubuntu 12.04 (PostgreSQL 9.1 and PostGIS 1.5)
+++++++++++++++++++++++++++++++++++++++++++++
.. note:: You can also install PostGIS 2.x on Ubuntu 12.04 using the packages
on the UbuntuGIS_ repository. Check the documentation there for details.
#. Install PostGIS::
sudo apt-get install postgresql-9.1-postgis
#. Run the following commands. The first one will create the necessary
tables and functions in the database, and the second will populate
the spatial reference table::
sudo -u postgres psql -d ckan_default -f /usr/share/postgresql/9.1/contrib/postgis-1.5/postgis.sql
sudo -u postgres psql -d ckan_default -f /usr/share/postgresql/9.1/contrib/postgis-1.5/spatial_ref_sys.sql
.. note:: If using PostgreSQL 8.x, run the following command to enable
the necessary language::
sudo -u postgres createlang plpgsql ckan_default
#. Change the owner to spatial tables to the CKAN user to avoid errors later
on::
sudo -u postgres psql -d ckan_default -c 'ALTER TABLE geometry_columns OWNER TO ckan_default;'
sudo -u postgres psql -d ckan_default -c 'ALTER TABLE spatial_ref_sys OWNER TO ckan_default;'
#. Execute the following command to see if PostGIS was properly
installed::
sudo -u postgres psql -d ckan_default -c "SELECT postgis_full_version()"
You should get something like::
postgis_full_version
------------------------------------------------------------------------------------------------------
POSTGIS="1.5.2" GEOS="3.2.2-CAPI-1.6.2" PROJ="Rel. 4.7.1, 23 September 2009" LIBXML="2.7.7" USE_STATS
(1 row)
#. Install some other packages needed by the extension dependencies::
sudo apt-get install python-dev libxml2-dev libxslt1-dev libgeos-c1
.. _UbuntuGIS: https://wiki.ubuntu.com/UbuntuGIS
Install the extension
---------------------
1. Install this extension into your python environment (where CKAN is also
installed)::
(pyenv) $ pip install -e "git+https://github.com/okfn/ckanext-spatial.git#egg=ckanext-spatial"
2. Install the rest of python modules required by the extension::
(pyenv) $ pip install -r pip-requirements.txt
To use the :doc:`harvesters`, you will need to install and configure the
harvester extension: `ckanext-harvest`_. Follow the install instructions on
its documentation for details on how to set it up.
Configuration
-------------
Once PostGIS is installed and configured in the database, the extension needs
to create a table to store the datasets extent, called ``package_extent``.
This will happen automatically the next CKAN is restarted after adding the
plugins on the configuration ini file (eg when restarting Apache).
If for some reason you need to explicitly create the table beforehand, you can
do it with the following command (with the virtualenv activated)::
(pyenv) $ paster --plugin=ckanext-spatial spatial initdb [srid] --config=mysite.ini
You can define the SRID of the geometry column. Default is 4326. If you are not
familiar with projections, we recommend to use the default value. To know more
about PostGIS tables, see :doc:`postgis-manual`
Each plugin can be enabled by adding its name to the ``ckan.plugins`` in the
CKAN ini file. For example::
ckan.plugins = spatial_metadata spatial_query
When enabling the spatial metadata, you can define the projection in which
extents are stored in the database with the following option. Use the EPSG code
as an integer (e.g 4326, 4258, 27700, etc). It defaults to 4326::
ckan.spatial.srid = 4326
Troubleshooting
---------------
Here are some common problems you may find when installing or using the
extension:
When upgrading the extension to a newer version
+++++++++++++++++++++++++++++++++++++++++++++++
This version of ckanext-spatial requires geoalchemy2
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
File "/home/adria/dev/pyenvs/spatial/src/ckanext-spatial/ckanext/spatial/plugin.py", line 39, in <module>
check_geoalchemy_requirement()
File "/home/adria/dev/pyenvs/spatial/src/ckanext-spatial/ckanext/spatial/plugin.py", line 37, in check_geoalchemy_requirement
raise ImportError(msg.format('geoalchemy'))
ImportError: This version of ckanext-spatial requires geoalchemy2. Please install it by running `pip install geoalchemy2`.
For more details see the "Troubleshooting" section of the install documentation
Starting from CKAN 2.3, the spatial requires GeoAlchemy2_ instead of GeoAlchemy, as this
is incompatible with the SQLAlchemy version that CKAN core uses. GeoAlchemy2 will get
installed on a new deployment, but if you are upgrading an existing ckanext-spatial
install you'll need to install it manually. With the virtualenv CKAN is installed on
activated, run::
pip install GeoAlchemy2
Restart the server for the changes to take effect.
AttributeError: type object 'UserDefinedType' has no attribute 'Comparator'
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
File "/home/adria/dev/pyenvs/spatial/src/ckanext-spatial/ckanext/spatial/plugin.py", line 30, in check_geoalchemy_requirement
import geoalchemy2
File "/home/adria/dev/pyenvs/spatial/local/lib/python2.7/site-packages/geoalchemy2/__init__.py", line 1, in <module>
from .types import ( # NOQA
File "/home/adria/dev/pyenvs/spatial/local/lib/python2.7/site-packages/geoalchemy2/types.py", line 15, in <module>
from .comparator import BaseComparator, Comparator
File "/home/adria/dev/pyenvs/spatial/local/lib/python2.7/site-packages/geoalchemy2/comparator.py", line 52, in <module>
class BaseComparator(UserDefinedType.Comparator):
AttributeError: type object 'UserDefinedType' has no attribute 'Comparator'
You are trying to run the extension against CKAN 2.3, but the requirements for CKAN haven't been updated
(GeoAlchemy2 is crashing against SQLAlchemy 0.7.x). Upgrade the CKAN requirements as described in the
`upgrade documentation`_.
.. _GeoAlchemy2: http://geoalchemy-2.readthedocs.org/en/0.2.4/
.. _upgrade documentation: http://docs.ckan.org/en/latest/maintaining/upgrading/upgrade-source.html
ckan.plugins.core.PluginNotFoundException: geojson_view
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
File "/home/pyenvs/spatial/src/ckan/ckan/plugins/core.py", line 149, in load
service = _get_service(plugin)
File "/home/pyenvs/spatial/src/ckan/ckan/plugins/core.py", line 256, in _get_service
raise PluginNotFoundException(plugin_name)
ckan.plugins.core.PluginNotFoundException: geojson_view
Your CKAN instance is using the ``geojson_view`` (or ``geojson_preview``) plugin. This plugin has been
moved from ckanext-spatial to ckanext-geoview_. Please install ckanext-geoview following the instructions on the
README.
TemplateNotFound: Template dataviewer/geojson.html cannot be found
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
File '/home/pyenvs/spatial/src/ckan/ckan/lib/base.py', line 129 in render_template
template_path, template_type = render_.template_info(template_name)
File '/home/pyenvs/spatial/src/ckan/ckan/lib/render.py', line 51 in template_info
raise TemplateNotFound('Template %s cannot be found' % template_name)
TemplateNotFound: Template dataviewer/geojson.html cannot be found
See the issue above for details. Install ckanext-geoview_ and additionally run the following on the
ckanext-spatial directory with your virtualenv activated::
python setup.py develop
ImportError: No module named nongeos_plugin
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
File "/home/pyenvs/spatial/src/ckan/ckan/plugins/core.py", line 255, in _get_service
return plugin.load()(name=plugin_name)
File "/home/pyenvs/spatial/local/lib/python2.7/site-packages/pkg_resources.py", line 2147, in load
['__name__'])
ImportError: No module named nongeos_plugin
See the issue above for details. Install ckanext-geoview_ and additionally run the following on the
ckanext-spatial directory with your virtualenv activated::
python setup.py develop
Plugin class 'GeoJSONPreview' does not implement an interface
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
File "/home/pyenvs/spatial/src/ckanext-spatial/ckanext/spatial/nongeos_plugin.py", line 175, in <module>
class GeoJSONPreview(GeoJSONView):
File "/home/pyenvs/spatial/local/lib/python2.7/site-packages/pyutilib/component/core/core.py", line 732, in __new__
return PluginMeta.__new__(cls, name, bases, d)
File "/home/pyenvs/spatial/local/lib/python2.7/site-packages/pyutilib/component/core/core.py", line 659, in __new__
raise PluginError("Plugin class %r does not implement an interface, and it has already been defined in environment '%r'." % (str(name), PluginGlobals.env().name))
pyutilib.component.core.core.PluginError: Plugin class 'GeoJSONPreview' does not implement an interface, and it has already been defined in environment ''pca''
You have correctly installed ckanext-geoview_ but the ckanext-spatial source code is outdated, with references
to the view plugins previously part of this extension. Pull the latest version of the code and re-register the
extension. With the virtualenv CKAN is installed on activated, run::
git pull
python setup.py develop
When initializing the spatial tables
++++++++++++++++++++++++++++++++++++
No function matches the given name and argument types
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
LINE 1: SELECT AddGeometryColumn('package_extent','the_geom', E'4326...
^
HINT: No function matches the given name and argument types. You might need to add explicit type casts.
"SELECT AddGeometryColumn('package_extent','the_geom', %s, 'GEOMETRY', 2)" ('4326',)
PostGIS was not installed correctly. Please check the "Setting up PostGIS"
section.
permission denied for relation spatial_ref_sys
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
sqlalchemy.exc.ProgrammingError: (ProgrammingError) permission denied for relation spatial_ref_sys
The user accessing the ckan database needs to be owner (or have permissions)
of the geometry_columns and spatial_ref_sys tables.
When migrating to an existing PostGIS database
++++++++++++++++++++++++++++++++++++++++++++++
If you are loading a database dump to an existing PostGIS database, you may
find errors like ::
ERROR: type "spheroid" already exists
This means that the PostGIS functions are installed, but you may need to
create the necessary tables anyway. You can force psql to ignore these
errors and continue the transaction with the ON_ERROR_ROLLBACK=on::
sudo -u postgres psql -d ckan_default -f /usr/share/postgresql/8.4/contrib/postgis-1.5/postgis.sql -v ON_ERROR_ROLLBACK=on
You will still need to populate the spatial_ref_sys table and change the
tables permissions. Refer to the previous section for details on how to do
it.
When performing a spatial query
+++++++++++++++++++++++++++++++
SQL expression, column, or mapped entity expected - got '<class 'ckanext.spatial.model.PackageExtent'>
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
InvalidRequestError: SQL expression, column, or mapped entity expected - got '<class 'ckanext.spatial.model.PackageExtent'>'
The spatial model has not been loaded. You probably forgot to add the
``spatial_metadata`` plugin to your ini configuration file.
Operation on two geometries with different SRIDs
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
::
InternalError: (InternalError) Operation on two geometries with different SRIDs
The spatial reference system of the database geometry column and the one
used by CKAN differ. Remember, if you are using a different spatial
reference system from the default one (WGS 84 lat/lon, EPSG:4326), you must
define it in the configuration file as follows::
ckan.spatial.srid = 4258
When running the spatial harvesters
+++++++++++++++++++++++++++++++++++
::
File "xmlschema.pxi", line 102, in lxml.etree.XMLSchema.__init__ (src/lxml/lxml.etree.c:154475)
lxml.etree.XMLSchemaParseError: local list type: A type, derived by list or union, must have the simple ur-type definition as base type, not '{http://www.opengis.net/gml}doubleList'., line 1
The XSD validation used by the spatial harvesters requires libxml2 ersion 2.9.
With CKAN you would probably have installed an older version from your
distribution. (e.g. with ``sudo apt-get install libxml2-dev``). You need to
find the SO files for the old version::
$ find /usr -name "libxml2.so"
For example, it may show it here: ``/usr/lib/x86_64-linux-gnu/libxml2.so``.
The directory of the SO file is used as a parameter to the ``configure`` next
on.
Download the libxml2 source::
$ cd ~
$ wget ftp://xmlsoft.org/libxml2/libxml2-2.9.0.tar.gz
Unzip it::
$ tar zxvf libxml2-2.9.0.tar.gz
$ cd libxml2-2.9.0/
Configure with the SO directory you found before::
$ ./configure --libdir=/usr/lib/x86_64-linux-gnu
Now make it and install it::
$ make
$ sudo make install
Now check the install by running xmllint::
$ xmllint --version
xmllint: using libxml version 20900
compiled with: Threads Tree Output Push Reader Patterns Writer SAXv1 FTP HTTP DTDValid HTML Legacy C14N Catalog XPath XPointer XInclude Iconv ISO8859X Unicode Regexps Automata Expr Schemas Schematron Modules Debug Zlib
.. _PostGIS: http://postgis.org
.. _ckanext-harvest: https://github.com/okfn/ckanext-harvest
.. _ckanext-geoview: https://github.com/ckan/ckanext-geoview