Instalación

Tabla de Contenido

Las instrucciones para descargar e instalar los binarios para diferentes sistemas operativos, notas adicionales y correcciones no incluidas en esta documentación se pueden encontrar en Installation wiki

Para utilizar pgRouting postGIS necesita ser instalado, por favor lea la información sobre la instalación en esta Guía de instalacoón

Versión corta

Extraer la bola de alquitrán

tar xvfz pgrouting-3.7.2.tar.gz
cd pgrouting-3.7.2

Para compilar suponiendo que tiene todas las dependencias en su ruta de búsqueda:

mkdir build
cd build
cmake  ..
make
sudo make install

Una vez que pgRouting está instalado, debe habilitarse en cada base de datos individual en la que desee utilizarlo.

createdb routing
psql routing -c 'CREATE EXTENSION PostGIS'
psql routing -c 'CREATE EXTENSION pgRouting'

Obtener las fuentes

La última versión de pgRouting se puede encontrar en https://github.com/pgRouting/pgrouting/releases/latest

Para descargar esta versión:

wget -O pgrouting-3.7.2.tar.gz    https://github.com/pgRouting/pgrouting/archive/v3.7.2.tar.gz

Ir a Versión corta para más instrucciones sobre la extraccion de la bola tar y la compilación de pgRouting.

git

Para descargar el repositorio

git clone git://github.com/pgRouting/pgrouting.git
cd pgrouting
git checkout v3.7.2

Ir a Versión corta para más instrucciones sobre la compilación de pgRouting (no hay bola tar involucrada al descargar el repositorio pgRouting desde GitHub).

Habilitación y actualización en la base de datos

Habilitación de la base de datos

pgRouting es una extensión de PostgreSQL y depende de PostGIS para proporcionar funcionalidades al usuario final. A continuación se muestra el código demuestra que permite PostGIS y pgRouting en la base de datos.

CREATE EXTENSION postgis;
CREATE EXTENSION pgrouting;

Comprobación de la versión de PostGIS y pgRouting después de habilitarlos en la base de datos.

SELECT PostGIS_full_version();
SELECT * FROM pgr_version();

Actualización de la base de datos

To upgrade pgRouting in the database to version 3.7.2 use the following command:

ALTER EXTENSION pgrouting UPDATE TO "3.7.2";

Puede hallar más información en https://www.postgresql.org/docs/current/sql-createextension.html

Dependencias

Dependencias de Compilación

Para poder compilar pgRouting, asegúrese de que se cumplen las siguientes dependencias:

  • Compiladores C y C++0x

    • Compilar con Boost 1.56 hasta Boost 1.74 requiere un compilador C++ con soporte estandard para C++03 o C++11

    • La compilación con Boost 1.75 requiere un compilador de C++ compatible con el estándar C++14

  • Versión postgresql = Versiones compatibles por PostgreSQL

  • La Biblioteca de Gráficos Boost (BGL). Versión >= 1.56

  • CMake >= 3.2

dependencias opcionales

Para la documentación del usuario

  • Sphinx >= 1.1

  • Latex

Para la documentación del desarrollador

  • Doxygen >= 1.7

Para pruebas

  • pgtap

  • pg_prove

Para uso:

  • PostGIS version >= 2.2

Ejemplo: Instalación de dependencias en linux

Instalación de las dependencias de compilación

Dependencias de bases de datos

sudo apt install postgresql-15
sudo apt install postgresql-server-dev-15
sudo apt install postgresql-15-postgis

Configurar PostgreSQL

Entrar en la consola psql

sudo systemctl start postgresql.service
sudo -i -u postgres
psql

Para salir de la consola psql

q

Se puede entrar directamente en la consola psql sin cambiar de rol mediante los siguientes comandos

sudo -u postgres psql

A continuación, utilizar el método anterior para salir de la consola psql

Comprobación de la versión de PostgreSQL

psql --version

o

Entrar a la consola psql usando el método anterior e introducir

SELECT VERSION();

Creación del rol PostgreSQL

sudo -i -u postgres
createuser --interactive

o

sudo -u postgres createuser --interactive

El rol por defecto proporcionado por PostgreSQL es postgres. Para crear nuevos roles puede utilizar los comandos proporcionados anteriromente. El prompt le pedirá al usuario que escibir el nombre del rol y confirmarlo. Proceder con los pasos y tendrá éxito en la creación de rol PostgreSQL.

Para añadir una contraseña a un rol o cambiar una contraseña previamente creada utilizar los siguientes comandos

ALTER USER <role name> PASSWORD <password>

Para obtener detalles adicionales sobre las banderas asociadas con createuser se puede utilizar el siguiente comando

man createuser

Crear una base de datos en PostgreSQL

sudo -i -u postgres
createdb <database name>

o

sudo -u postgres createdb <database name>

Conexión a una base de datos PostgreSQL

Entrar en la consola psql y escribir los siguientes comandos

connect <database name>

Construir dependencias

sudo apt install cmake
sudo apt install g++
sudo apt install libboost-graph-dev

Dependencias opcionales

Para documentación y pruebas

pip install sphinx
pip install sphinx-bootstrap-theme
sudo apt install texlive
sudo apt install doxygen
sudo apt install libtap-parser-sourcehandler-pgtap-perl
sudo apt install postgresql-15-pgtap

Configuración

pgRouting utiliza el sistema “cmake” para realizar la configuración.

El directorio de compilación es diferente del directorio de origen

Cree el directorio de compilación

$ mkdir build

Variables configurables

Para ver las variables que se pueden configurar

$ cd build
$ cmake -L ..

Configurar la documentación

La mayor parte del esfuerzo de la documentación ha estado en los archivos HTML. Algunas variables para construir la documentación:

Variable

x Defecto

Comentario

WITH_DOC

BOOL=OFF

Activar/desactivar la construcción de la documentación

BUILD_HTML

BOOL=ON

Si está activado, active/desactive la creación de HTML para la documentación del usuario

BUILD_DOXY

BOOL=ON

Si está activado, active o desactive la creación de HTML para la documentación del desarrollador

BUILD_LATEX

BOOL=OFF

Si está activado, active/desactive la creación de PDF

BUILD_MAN

BOOL=OFF

Si está activado, active/desactive las páginas MAN de construcción

DOC_USE_BOOTSTRAP

BOOL=OFF

Si está activado, utilice sphinx-bootstrap para las páginas HTML de la documentación de los usuarios

Configuración de cmake para crear documentación antes de compilar pgRouting

$ cmake -DWITH_DOC=ON -DDOC_USE_BOOTSTRAP=ON ..

Nota

La mayor parte del esfuerzo de la documentación ha estado en los archivos html.

Compilando

Uso de make para compilar el código y la documentación

Las siguientes instrucciones comienzan desde path/to/pgrouting/build

$ make          # build the code but not the documentation
$ make doc      # build only the user's documentation
$ make all doc  # build both the code and the user's documentation
$ make doxy     # build only the developer's documentation

Hemos probado en varias plataformas, Para instalar o reinstalar todos los pasos son necesarios.

Advertencia

Las firmas sql se configuran y se compilan en el comando cmake.

MinGW en Windows

$ mkdir build
$ cd build
$ cmake -G"MSYS Makefiles" ..
$ make
$ make install

Linux

Las siguientes instrucciones comienzan desde path/to/pgrouting

mkdir build
cd build
cmake  ..
make
sudo make install

Para eliminar la compilación cuando se cambie la configuración, utilizar el siguiente código:

rm -rf build

e iniciar el proceso de compilación como se mencionó anteriormente.

Pruebas

Actualmente no hay make test y las pruebas se realizan de la siguiente manera

Las siguientes instrucciones comienzan desde path/to/pgrouting/

tools/testers/doc_queries_generator.pl
createdb -U <user> ___pgr___test___
sh ./tools/testers/pg_prove_tests.sh <user>
dropdb -U <user> ___pgr___test___

Ver también

Índices y tablas