| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644 | [#es-connectors-postgresql]=== Elastic PostgreSQL connector reference++++<titleabbrev>PostgreSQL</titleabbrev>++++// Attributes used in this file:service-name: PostgreSQL:service-name-stub: postgresqlThe _Elastic PostgreSQL connector_ is a connector for https://www.postgresql.org[PostgreSQL^].This connector is written in Python using the {connectors-python}[Elastic connector framework^].This connector uses the https://github.com/elastic/connectors/blob/{branch}/connectors/sources/generic_database.py[generic database connector source code^] (branch _{connectors-branch}_, compatible with Elastic _{minor-version}_).View the specific {connectors-python}/connectors/sources/{service-name-stub}.py[*source code* for this connector^] (branch _{connectors-branch}_, compatible with Elastic _{minor-version}_)..Choose your connector reference*******************************Are you using an Elastic managed connector on Elastic Cloud or a self-managed connector? Expand the documentation based on your deployment method.*******************************// //////// //// //// //// //// //// //// ////////// ////////   NATIVE CONNECTOR REFERENCE   ///////// //////// //// //// //// //// //// //// ////////[discrete#connectors-postgresql-native-connector-reference]=== *Elastic managed connector (Elastic Cloud)*.View *Elastic managed connector* reference[%collapsible]===============[discrete#connectors-postgresql-availability-prerequisites]==== Availability and prerequisitesThis connector is available as an *Elastic managed connector* in Elastic versions *8.8.0 and later*.To use this connector natively in Elastic Cloud, satisfy all <<es-native-connectors,Elastic managed connector requirements>>.[discrete#connectors-postgresql-create-native-connector]==== Create a {service-name} connectorinclude::_connectors-create-native.asciidoc[][discrete#connectors-postgresql-usage]==== UsageTo use this connector as an *Elastic managed connector*, use the *Connector* workflow.See <<es-native-connectors>>.[TIP]====Users must set `track_commit_timestamp` to `on`.To do this, run `ALTER SYSTEM SET track_commit_timestamp = on;` in PostgreSQL server.====For additional operations, see <<-esconnectors-usage>>.[NOTE]====For an end-to-end example of the connector client workflow, see <<es-postgresql-connector-client-tutorial>>.====[discrete#connectors-postgresql-compatibility]==== CompatibilityPostgreSQL versions 11 to 15 are compatible with the Elastic connector.[discrete#connectors-postgresql-configuration]==== ConfigurationSet the following configuration fields:Host::The server host address where the PostgreSQL instance is hosted.Examples:+* `192.158.1.38`* `demo.instance.demo-region.demo.service.com`Port::The port where the PostgreSQL instance is hosted.Examples:+* `5432` (default)Username::The username of the PostgreSQL account.Password::The password of the PostgreSQL account.Database::Name of the PostgreSQL database.Examples:+* `employee_database`* `customer_database`Schema::The schema of the PostgreSQL database.Comma-separated List of Tables::A list of tables separated by commas.The PostgreSQL connector will fetch data from all tables present in the configured database, if the value is `*` .Default value is `*`.Examples:+* `table_1, table_2`* `*`+[WARNING]====This field can be bypassed when using advanced sync rules.====Enable SSL::Toggle to enable SSL verification.Disabled by default.SSL Certificate::Content of SSL certificate.If SSL is disabled, the `ssl_ca` value will be ignored.+.*Expand* to see an example certificate[%collapsible]====```-----BEGIN CERTIFICATE-----MIID+jCCAuKgAwIBAgIGAJJMzlxLMA0GCSqGSIb3DQEBCwUAMHoxCzAJBgNVBAYTAlVTMQwwCgYDVQQKEwNJQk0xFjAUBgNVBAsTDURlZmF1bHROb2RlMDExFjAUBgNVBAsTDURlZmF1bHRDZWxsMDExGTAXBgNVBAsTEFJvb3QgQ2VydGlmaWNhdGUxEjAQBgNVBAMTCWxvY2FsaG9zdDAeFw0yMTEyMTQyMjA3MTZaFw0yMjEyMTQyMjA3MTZaMF8xCzAJBgNVBAYTAlVTMQwwCgYDVQQKEwNJQk0xFjAUBgNVBAsTDURlZmF1bHROb2RlMDExFjAUBgNVBAsTDURlZmF1bHRDZWxsMDExEjAQBgNVBAMTCWxvY2FsaG9zdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMv5HCsJZIpI5zCy+jXVz6lmzNc9UcVSEEHn86h6zT6pxuY90TYeAhlZ9hZ+SCKn4OQ4GoDRZhLPTkYDt+wWCV3NTIy9uCGUSJ6xjCKoxClJmgSQdg5m4HzwfY4ofoEZ5iZQ0Zmt62jGRWc0zuxjhegnM+eO2reBJYu6Ypa9RPJdYJsmn1RNnC74IDY8Y95qn+WZj//UALCpYfX41hkoi7TWD9GKQO8SBmAxhjCDifOxVBokoxYrNdzESl0LXvnzEadeZTd9BfUtTaBHhx6tnjqqCPrbTY+3jAbZFd4RiERPnhLVKMytw5ot506BhPrUtpr2lusbN5svNXjuLeeaMMUCAwEAAaOBoDCBnTATBgNVHSMEDDAKgAhOatpLwvJFqjAdBgNVHSUEFjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwVAYDVR0RBE0wS4E+UHJvZmlsZVVVSUQ6QXBwU3J2MDEtQkFTRS05MDkzMzJjMC1iNmFiLTQ2OTMtYWI5NC01Mjc1ZDI1MmFmNDiCCWxvY2FsaG9zdDARBgNVHQ4ECgQITzqhA5sO8O4wDQYJKoZIhvcNAQELBQADggEBAKR0gY/BM69S6BDyWp5dxcpmZ9FS783FBbdUXjVtTkQno+oYURDrhCdsfTLYtqUlP4J4CHoskP+MwJjRIoKhPVQMv14Q4VC2J9coYXnePhFjE+6MaZbTjq9WaekGrpKkMaQAiQt5b67jo7y63CZKIo9yBvs7sxODQzDn3wZwyux2vPegXSaTHR/rop/s/mPk3YTShQprs/IVtPoWU4/TsDN3gIlrAYGbcs29CAt5q9MfzkMmKsuDkTZD0ry42VjxjAmkxw23l/k8RoD1wRWaDVbgpjwSzt+kl+vJE/ip2w3h69eEZ9wbo6scRO5lCO2JM4Pr7RhLQyWn2u00L7/9Omw=-----END CERTIFICATE-----```====[discrete#connectors-postgresql-documents-syncs]==== Documents and syncs* Tables must be owned by a PostgreSQL user.* Tables with no primary key defined are skipped.* To fetch the last updated time in PostgreSQL, `track_commit_timestamp` must be set to `on`.Otherwise, all data will be indexed in every sync.[NOTE]====* Files bigger than 10 MB won't be extracted.* Permissions are not synced.**All documents** indexed to an Elastic deployment will be visible to **all users with access** to that Elastic Deployment.====[discrete#connectors-postgresql-sync-rules]==== Sync rules<<es-sync-rules-basic,Basic sync rules>> are identical for all connectors and are available by default.[discrete#connectors-postgresql-sync-rules-advanced]===== Advanced sync rules[NOTE]====A <<es-connectors-sync-types-full, full sync>> is required for advanced sync rules to take effect.====Advanced sync rules are defined through a source-specific DSL JSON snippet.[discrete#connectors-postgresql-sync-rules-advanced-example-data]====== Example dataHere is some example data that will be used in the following examples.[discrete#connectors-postgresql-sync-rules-advanced-example-data-1]======= `employee` table[cols="3*", options="header"]|===| emp_id | name  | age| 3      | John  | 28| 10     | Jane  | 35| 14     | Alex  | 22|===[discrete#connectors-postgresql-sync-rules-advanced-example-2]======= `customer` table[cols="3*", options="header"]|===| c_id | name | age| 2    | Elm  | 24| 6    | Pine | 30| 9    | Oak  | 34|===[discrete#connectors-postgresql-sync-rules-advanced-examples]====== Advanced sync rules examples[discrete#connectors-postgresql-sync-rules-advanced-examples-1]======= Multiple table queries[source,js]----[  {    "tables": [      "employee"    ],    "query": "SELECT * FROM employee"  },  {    "tables": [      "customer"    ],    "query": "SELECT * FROM customer"  }]----// NOTCONSOLE[discrete#connectors-postgresql-sync-rules-advanced-examples-1-id-columns]======= Multiple table queries with `id_columns`In 8.15.0, we added a new optional `id_columns` field in our advanced sync rules for the PostgreSQL connector.Use the `id_columns` field to ingest tables which do not have a primary key. Include the names of unique fields so that the connector can use them to generate unique IDs for documents.[source,js]----[  {    "tables": [      "employee"    ],    "query": "SELECT * FROM employee",    "id_columns": ["emp_id"]  },  {    "tables": [      "customer"    ],    "query": "SELECT * FROM customer",    "id_columns": ["c_id"]  }]----// NOTCONSOLEThis example uses the `id_columns` field to specify the unique fields `emp_id` and `c_id` for the `employee` and `customer` tables, respectively.[discrete#connectors-postgresql-sync-rules-advanced-examples-2]======= Filtering data with `WHERE` clause[source,js]----[  {    "tables": ["employee"],    "query": "SELECT * FROM employee WHERE emp_id > 5"  }]----// NOTCONSOLE[discrete#connectors-postgresql-sync-rules-advanced-examples-3]======= `JOIN` operations[source,js]----[  {    "tables": ["employee", "customer"],    "query": "SELECT * FROM employee INNER JOIN customer ON employee.emp_id = customer.c_id"  }]----// NOTCONSOLE[WARNING]====When using advanced rules, a query can bypass the configuration field `tables`.This will happen if the query specifies a table that doesn't appear in the configuration.This can also happen if the configuration specifies `*` to fetch all tables while the advanced sync rule requests for only a subset of tables.====[discrete#connectors-postgresql-known-issues]==== Known issuesThere are no known issues for this connector.Refer to <<es-connectors-known-issues>> for a list of known issues for all connectors.[discrete#connectors-postgresql-troubleshooting]==== TroubleshootingSee <<es-connectors-troubleshooting>>.[discrete#connectors-postgresql-security]==== SecuritySee <<es-connectors-security>>.// Closing the collapsible section===============[discrete#es-connectors-postgresql-connector-client-reference]=== *Self-managed connector*.View *self-managed connector* reference[%collapsible]===============[discrete#es-connectors-postgresql-client-availability-prerequisites]==== Availability and prerequisitesThis connector is available as a self-managed *self-managed connector*.To use this connector, satisfy all <<es-build-connector,self-managed connector requirements>>.[discrete#es-connectors-postgresql-create-connector-client]==== Create a {service-name} connectorinclude::_connectors-create-client.asciidoc[][discrete#es-connectors-postgresql-client-usage]==== UsageTo use this connector as a *self-managed connector*, see <<es-build-connector>>.[TIP]====Users must set `track_commit_timestamp` to `on`.To do this, run `ALTER SYSTEM SET track_commit_timestamp = on;` in PostgreSQL server.====For additional operations, see.[NOTE]====For an end-to-end example of the self-managed connector workflow, see <<es-postgresql-connector-client-tutorial>>.====[discrete#es-connectors-postgresql-client-compatibility]==== CompatibilityPostgreSQL versions 11 to 15 are compatible with Elastic connector frameworks.[discrete#es-connectors-postgresql-client-configuration]==== Configuration[TIP]====When using the <<es-build-connector, self-managed connector workflow>>, initially these fields will use the default configuration set in the https://github.com/elastic/connectors-python/blob/{branch}/connectors/sources/postgresql.py[connector source code^].These configurable fields will be rendered with their respective *labels* in the Kibana UI.Once connected, users will be able to update these values in Kibana.====Set the following configuration fields:`host`::The server host address where the PostgreSQL instance is hosted.Examples:+* `192.158.1.38`* `demo.instance.demo-region.demo.service.com``port`::The port where the PostgreSQL instance is hosted.Examples:+* `5432`* `9090``username`::The username of the PostgreSQL account.`password`::The password of the PostgreSQL account.`database`::Name of the PostgreSQL database.Examples:+* `employee_database`* `customer_database``schema`::The schema of the PostgreSQL database.`tables`::A list of tables separated by commas.The PostgreSQL connector will fetch data from all tables present in the configured database, if the value is `*` .Default value is `*`.Examples:+* `table_1, table_2`* `*`+[WARNING]====This field can be bypassed when using advanced sync rules.====`ssl_enabled`::Whether SSL verification will be enabled.Default value is `True`.`ssl_ca`::Content of SSL certificate (if SSL is enabled).If SSL is disabled, the `ssl_ca` value will be ignored.+.*Expand* to see an example certificate[%collapsible]====```-----BEGIN CERTIFICATE-----MIID+jCCAuKgAwIBAgIGAJJMzlxLMA0GCSqGSIb3DQEBCwUAMHoxCzAJBgNVBAYTAlVTMQwwCgYDVQQKEwNJQk0xFjAUBgNVBAsTDURlZmF1bHROb2RlMDExFjAUBgNVBAsTDURlZmF1bHRDZWxsMDExGTAXBgNVBAsTEFJvb3QgQ2VydGlmaWNhdGUxEjAQBgNVBAMTCWxvY2FsaG9zdDAeFw0yMTEyMTQyMjA3MTZaFw0yMjEyMTQyMjA3MTZaMF8xCzAJBgNVBAYTAlVTMQwwCgYDVQQKEwNJQk0xFjAUBgNVBAsTDURlZmF1bHROb2RlMDExFjAUBgNVBAsTDURlZmF1bHRDZWxsMDExEjAQBgNVBAMTCWxvY2FsaG9zdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMv5HCsJZIpI5zCy+jXVz6lmzNc9UcVSEEHn86h6zT6pxuY90TYeAhlZ9hZ+SCKn4OQ4GoDRZhLPTkYDt+wWCV3NTIy9uCGUSJ6xjCKoxClJmgSQdg5m4HzwfY4ofoEZ5iZQ0Zmt62jGRWc0zuxjhegnM+eO2reBJYu6Ypa9RPJdYJsmn1RNnC74IDY8Y95qn+WZj//UALCpYfX41hkoi7TWD9GKQO8SBmAxhjCDifOxVBokoxYrNdzESl0LXvnzEadeZTd9BfUtTaBHhx6tnjqqCPrbTY+3jAbZFd4RiERPnhLVKMytw5ot506BhPrUtpr2lusbN5svNXjuLeeaMMUCAwEAAaOBoDCBnTATBgNVHSMEDDAKgAhOatpLwvJFqjAdBgNVHSUEFjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwVAYDVR0RBE0wS4E+UHJvZmlsZVVVSUQ6QXBwU3J2MDEtQkFTRS05MDkzMzJjMC1iNmFiLTQ2OTMtYWI5NC01Mjc1ZDI1MmFmNDiCCWxvY2FsaG9zdDARBgNVHQ4ECgQITzqhA5sO8O4wDQYJKoZIhvcNAQELBQADggEBAKR0gY/BM69S6BDyWp5dxcpmZ9FS783FBbdUXjVtTkQno+oYURDrhCdsfTLYtqUlP4J4CHoskP+MwJjRIoKhPVQMv14Q4VC2J9coYXnePhFjE+6MaZbTjq9WaekGrpKkMaQAiQt5b67jo7y63CZKIo9yBvs7sxODQzDn3wZwyux2vPegXSaTHR/rop/s/mPk3YTShQprs/IVtPoWU4/TsDN3gIlrAYGbcs29CAt5q9MfzkMmKsuDkTZD0ry42VjxjAmkxw23l/k8RoD1wRWaDVbgpjwSzt+kl+vJE/ip2w3h69eEZ9wbo6scRO5lCO2JM4Pr7RhLQyWn2u00L7/9Omw=-----END CERTIFICATE-----```====[discrete#es-connectors-postgresql-client-docker]==== Deployment using Dockerinclude::_connectors-docker-instructions.asciidoc[][discrete#es-connectors-postgresql-client-documents-syncs]==== Documents and syncs* Tables must be owned by a PostgreSQL user.* Tables with no primary key defined are skipped.* To fetch the last updated time in PostgreSQL, `track_commit_timestamp` must be set to `on`.Otherwise, all data will be indexed in every sync.[NOTE]====* Files bigger than 10 MB won't be extracted.* Permissions are not synced.**All documents** indexed to an Elastic deployment will be visible to **all users with access** to that Elastic Deployment.====[discrete#es-connectors-postgresql-client-sync-rules]==== Sync rules//sync-rules-basic,Basic sync rules are identical for all connectors and are available by default.[discrete#es-connectors-postgresql-client-sync-rules-advanced]===== Advanced sync rules[NOTE]====A //connectors-sync-types-full, full sync is required for advanced sync rules to take effect.====Advanced sync rules are defined through a source-specific DSL JSON snippet.[discrete#es-connectors-postgresql-client-sync-rules-advanced-example-data]====== Example dataHere is some example data that will be used in the following examples.[discrete#es-connectors-postgresql-client-sync-rules-advanced-example-data-1]======= `employee` table[cols="3*", options="header"]|===| emp_id | name  | age| 3      | John  | 28| 10     | Jane  | 35| 14     | Alex  | 22|===[discrete#es-connectors-postgresql-client-sync-rules-advanced-example-2]======= `customer` table[cols="3*", options="header"]|===| c_id | name | age| 2    | Elm  | 24| 6    | Pine | 30| 9    | Oak  | 34|===[discrete#es-connectors-postgresql-client-sync-rules-advanced-examples]====== Advanced sync rules examples[discrete#es-connectors-postgresql-client-sync-rules-advanced-examples-1]======== Multiple table queries[source,js]----[  {    "tables": [      "employee"    ],    "query": "SELECT * FROM employee"  },  {    "tables": [      "customer"    ],    "query": "SELECT * FROM customer"  }]----// NOTCONSOLE[discrete#es-connectors-postgresql-client-sync-rules-advanced-examples-1-id-columns]======== Multiple table queries with `id_columns`In 8.15.0, we added a new optional `id_columns` field in our advanced sync rules for the PostgreSQL connector.Use the `id_columns` field to ingest tables which do not have a primary key. Include the names of unique fields so that the connector can use them to generate unique IDs for documents.[source,js]----[  {    "tables": [      "employee"    ],    "query": "SELECT * FROM employee",    "id_columns": ["emp_id"]  },  {    "tables": [      "customer"    ],    "query": "SELECT * FROM customer",    "id_columns": ["c_id"]  }]----// NOTCONSOLEThis example uses the `id_columns` field to specify the unique fields `emp_id` and `c_id` for the `employee` and `customer` tables, respectively.[discrete#es-connectors-postgresql-client-sync-rules-advanced-examples-2]======== Filtering data with `WHERE` clause[source,js]----[  {    "tables": ["employee"],    "query": "SELECT * FROM employee WHERE emp_id > 5"  }]----// NOTCONSOLE[discrete#es-connectors-postgresql-client-sync-rules-advanced-examples-3]======== `JOIN` operations[source,js]----[  {    "tables": ["employee", "customer"],    "query": "SELECT * FROM employee INNER JOIN customer ON employee.emp_id = customer.c_id"  }]----// NOTCONSOLE[WARNING]====When using advanced rules, a query can bypass the configuration field `tables`.This will happen if the query specifies a table that doesn't appear in the configuration.This can also happen if the configuration specifies `*` to fetch all tables while the advanced sync rule requests for only a subset of tables.====[discrete#es-connectors-postgresql-client-client-operations-testing]==== End-to-end testingThe connector framework enables operators to run functional tests against a real data source.Refer to <<es-build-connector-testing>> for more details.To perform E2E testing for the PostgreSQL connector, run the following command:[source,shell]----$ make ftest NAME=postgresql----For faster tests, add the `DATA_SIZE=small` flag:[source,shell]----make ftest NAME=postgresql DATA_SIZE=small----[discrete#es-connectors-postgresql-client-known-issues]==== Known issuesThere are no known issues for this connector.Refer to <<es-connectors-known-issues>> for a list of known issues for all connectors.[discrete#es-connectors-postgresql-client-troubleshooting]==== TroubleshootingSee <<es-connectors-troubleshooting>>.[discrete#es-connectors-postgresql-client-security]==== SecuritySee <<es-connectors-security>>.// Closing the collapsible section===============
 |