Instalación¶
Tabla de Contenido
Instructions for downloading and installing binaries for different operating systems, additional notes and corrections not included in this documentation can be found in 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.6.2.tar.gz
cd pgrouting-3.6.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
Wget
Para descargar esta versión:
wget -O pgrouting-3.6.2.tar.gz https://github.com/pgRouting/pgrouting/archive/v3.6.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.6.2
Go to Versión corta for more instructions on compiling pgRouting (there is no tar ball involved while downloading pgRouting repository from GitHub).
Habilitación y actualización en la base de datos¶
Habilitación de la base de datos
pgRouting is a PostgreSQL extension and depends on PostGIS to provide functionalities to end user. Below given code demonstrates enabling PostGIS and pgRouting in the database.
CREATE EXTENSION postgis;
CREATE EXTENSION pgrouting;
Checking PostGIS and pgRouting version after enabling them in the database.
SELECT PostGIS_full_version();
SELECT * FROM pgr_version();
Actualización de la base de datos
To upgrade pgRouting in the database to version 3.6.2 use the following command:
ALTER EXTENSION pgrouting UPDATE TO "3.6.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:
C and C++0x compilers
Compilar con Boost 1.56 hasta Boost 1.74 requiere un compilador C++ con soporte estandard para C++03 o C++11
Compiling with Boost 1.75 requires C++ Compiler with C++14 standard support
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
Entering psql console
sudo systemctl start postgresql.service
sudo -i -u postgres
psql
To exit psql console
q
Entering psql console directly without switching roles can be done by the following commands
sudo -u postgres psql
Then use the above given method to exit out of the psql console
Checking PostgreSQL version
psql --version
or
Enter the psql console using above given method and then enter
SELECT VERSION();
Creating PostgreSQL role
sudo -i -u postgres
createuser --interactive
or
sudo -u postgres createuser --interactive
Default role provided by PostgreSQL is postgres. To create new roles you can use the above provided commands. The prompt will ask the user to type name of the role and then provide affirmation. Proceed with the steps and you will succeed in creating PostgreSQL role successfully.
To add password to the role or change previously created password of the role use the following commands
ALTER USER <role name> PASSWORD <password>
To get additional details on the flags associated with createuser
below
given command can be used
man createuser
Creating Database in PostgreSQL
sudo -i -u postgres
createdb <database name>
or
sudo -u postgres createdb <database name>
Connecting to a PostgreSQL Database
Enter the psql console and type the following commands
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 |
Configuring cmake to create documentation before building 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
To remove the build when the configuration changes, use the following code:
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