Instrumenting calls to a PostgreSQL database
The application-pgsql.properties
file adds the X-Ray PostgreSQL
tracing interceptor to the data source created in RdsWebConfig.java
Example application-pgsql.properties
– PostgreSQL database
instrumentation
spring.datasource.continue-on-error=true
spring.jpa.show-sql=false
spring.jpa.hibernate.ddl-auto=create-drop
spring.datasource.jdbc-interceptors=com.amazonaws.xray.sql.postgres.TracingInterceptor
spring.jpa.database-platform=org.hibernate.dialect.PostgreSQL94Dialect
Note
See Configuring Databases with Elastic Beanstalk in the AWS Elastic Beanstalk Developer Guide for details on how to add a PostgreSQL database to the application environment.
The X-Ray demo page in the xray
branch includes a demo that uses the
instrumented data source to generate traces that show information about the SQL queries that
it generates. Navigate to the /#/xray
path in the running application or choose
Powered by AWS X-Ray in the navigation bar to see the demo
page.
data:image/s3,"s3://crabby-images/0e314/0e314af2ab50835b15427a2baec95c613c7f5860" alt="AWS X-Ray integration demo page showing game session tracing and SQL query tracing options."
Choose Trace SQL queries to simulate game sessions and store the
results in the attached database. Then, choose View traces in AWS X-Ray
to see a filtered list of traces that hit the API's /api/history
route.
Choose one of the traces from the list to see the timeline, including the SQL query.
data:image/s3,"s3://crabby-images/5b9c4/5b9c4a91719659ec035182068bf9d7bfc10417bb" alt="Timeline view of a trace showing method, response, duration, and age for a GET request."