The GeoServer Monitor PostgreSQL Plugin is an extension to the official Monitor Plugin of GeoServer. It fetches the metrics from the Monitor Plugin and persists them in a PostgreSQL database.
Authors: based on CRediT (Contributor Roles Taxonomy)
Name, ORCID and affiliation | Contributor Role(s) | |
---|---|---|
Sangeetha Shankar, DLR Institute of Transportation Systems | Conceptualization, Data curation, Formal Analysis, Investigation, Methodology, Resources, Software, Validation, Visualisation, Writing - original draft, Writing - review and editing | Sangeetha.Shankar@dlr.de |
Lucas Andreas Schubert, DLR Institute of Transportation Systems | Funding acquisition, Project administration, Resources, Supervision | Lucas.Schubert@dlr.de |
Version: 1.0.2 (05 January 2024)
The official Monitor Plugin of the GeoServer allows only one method of storing the metrics on the requests received by the GeoServer - memory storage. This storage is volatile and information is lost when the GeoServer is restarted. Furthermore, it stores metrics only for the latest 100 requests. This is insufficient for GeoServers in productive environments receiving hundreds of requests everyday.
The GeoServer Monitor PostgreSQL plugin aims to overcome this limitation by persisting the metrics in a PostgreSQL database. The persistent storage of metrics enables the administrators of the GeoServer to analyze the performance of their GeoServer layers and optimize their services.
The GeoServer also contains a community module called monitor-hibernate
(link) which has been unmaintained for more than 5 years and is not available for the latest releases of the GeoServer. When compared with this module, the Monitor PostgreSQL module offers a simpler approach to write records to the database through the use of built-in Java functionalities and PostgreSQL JDBC Driver library. Lesser dependency on external modules makes this extension easy to maintain and update.
Note: The plugin has been tested with the following versions of GeoServer - 2.19.0, 2.21.2, 2.23.4 and in Ubuntu Server operating system.
- Clone the repository
- In
pom.xml
present inmonitor-psql folder
, change the GeoServer and GeoTools version to match those of your GeoServer instance. - Build the JAR file using a software of your choice. (Eclipse IDE was used during development and testing)
- Stop your GeoServer instance, if it is running.
- Add the JAR file
monitor-psql-x.x.x_y.y.y.jar
toWEB-INF/lib
directory of GeoServer. - In the file
monitor.properties
present in$GEOSERVER_DATA_DIR/monitoring
directory, add the lines present inpsql_monitor_config.conf
and adjust the values according to your database configuration. - Create a new table in your PostgreSQL database to store the request information. DDL statements are present in
create_tables.sql
. - Restart the GeoServer.
Figure 1 shows the working of GeoServer Monitor PostgreSQL Plugin. Whenever GeoServer receives a request, the Monitor plugin generates the metrics related to that request. These are forwared to the GeoServer Monitor PostgreSQL plugin, which in turn stores these metrics to a database. The metrics are stored after the request is post-processed.
Figure 1: Working of GeoServer Monitor PostgreSQL Plugin
The metrics written to the database are listed in the table 1.
Table 1: List of persisted metrics
Variable | Description | Unit of Measurement |
---|---|---|
id | Request ID | - |
service | Type of service, e.g., WMS, WFS | - |
operation | Type of operation, e.g., GetMap, GetFeature | - |
resources | The requested resource in format : | - |
httpMethod | HTTP method, e.g., GET, POST | - |
startTime | Start time of request | yyyy-MM-dd HH:mm:ss.fff (local time) |
endTime | End time of request | yyyy-MM-dd HH:mm:ss.fff (local time) |
totalTime | endTime - startTime | milliseconds |
remoteUser | Name of GeoServer user who requested the resource | - |
remoteUserAgent | Application used to send the request | - |
responseStatus | Status code | - |
responseLength | Length of the response | - |
responseContentType | Type of response content, for e.g., application/json, image/png | - |
- The plugin was installed in a GeoServer managed by the DLR Institute of Transportation Systems and tested for one year. During the testing period, when the frequency of requests was high, it was observed that I/O errors occasionally occured (
org.postgresql.util.PSQLException: An I/O error occurred while sending to the backend
). This error showed up once for every 40-50 requests. Its occurrence is unpredictable and not fixed yet. It is suspected that the error is occurring due to a bug injava.sql
library. It could also be due to the fact that the plugin establishes a new database connection for every request received by the GeoServer, which could be causing problems when the frequency of requests is high. This issue is being investigated. - If the configuration file
monitor.properties
is changed when the GeoServer is still running, it might cause unexpected errors. The safest way is to always stop the GeoServer before making changes in the configuration file.
- Bug reports and suggestions on improvements are welcome in the form of GitHub issues.
The extension is simple and straight-forward. It contains three classes:
PsqlMonitorInitializer
- This class implements the interfaceGeoServerInitializer
and contains code to initialize and enable the extension.PsqlMonitorDAO.java
- This class implements the interfaceMonitorDAO
and acts as a helper in managing the list of metrics generated for the requests received by the GeoServer.PsqlLogger.java
- This class stores the metrics to the defined PostgreSQL database. The logger opens a new connection to the database for every request received by the GeoServer.
The Monitor plugin records several more metrics in addition to those persisted by this plugin. To see the entire list, please into the RequestData class of the Monitor plugin. In the GeoServer Monitor PostgreSQL Plugin, the list of metrics to be persisted are hard-coded. If you would like to add/remove metrics, please adapt the source code and build the plugin. The database table will also have to be adapted accordingly.
GNU General Public License v3.0. See LICENSE.
The development of this plugin is being funded by the DLR-funded cross-domain project, "Digitaler Atlas 2.0" (2022-2025). After the end of this project, the plugin is intended to be improved and maintained over other DLR-funded projects.
- Sangeetha Shankar, German Aerospace Center (DLR). Email: Sangeetha.Shankar@dlr.de