-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[exporter/clickhouse] Default async_insert
to true. Added related config option.
#33614
[exporter/clickhouse] Default async_insert
to true. Added related config option.
#33614
Conversation
Note for future reference, this is a continuation of #32340 |
Looks like the README got merged incorrectly, I've removed the duplicate 👍 |
@dmitryax did some git surgery to hopefully extract all these changes into separate PRs. The PRs do build on one another, so I've ordered them so that they can be merged without breaking main. |
902da38
to
ed997a9
Compare
8b9ee99
to
8102c6e
Compare
@hanjm @Frapschen PTAL |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Thanks for reviewing! I don't have permission to merge, but after this is merged we can do #33615 |
8102c6e
to
1b04615
Compare
Latest suggestions applied + rebased, hopefully we can get this merged asap since it's been open for a while. Thanks! |
…33615) **Description:** *NOTE: Depends on merging of #33611, #33614, and #33648* Logs configuration is unlikely to change further with the new recommendation of [manual schema config](https://github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/exporter/clickhouseexporter#schema-management). The logs component of the exporter has proven stability, as seen in deployments such as [ClickHouse's Loghouse](https://clickhouse.com/blog/building-a-logging-platform-with-clickhouse-and-saving-millions-over-datadog). With these points in mind, I suggest we upgrade the status to `beta` for logs. Traces and metrics can remain `alpha` for now. **Documentation:** - Updated metadata.yaml - Updated README - Small unrelated change: added/refactored a section that covers tool visualization
DEPENDS ON #33693, #33694
Description:
Sets
async_insert
to true by default to enable asynchronous inserts.Because this value is being given a default, I have added a config option under the same name.
Keep in mind that if
async_insert
is provided inendpoint
orconnection_params
it will take precedence and ignore this new config option.This is similar to how the
database
config option behaves.The goal is to provide better insert performance by default, since not all users will know to set it in their DSN URL.
This also opens the discussion to whether or not this is a breaking change. Depending on the deployment's telemetry throughput, this could be an unexpected change that leads to
TOO_MANY_PARTS
errors. I don't expect this to be the case however, but I welcome any discussion about this concern.This PR is being resubmitted with suggestions from @crobert-1 and @dmitryax applied.
Here are the extra changes with these suggestions applied:
async_insert
to avoid using abool
pointerTesting:
Ran integration tests. Also added an abundance of tests to check the behavior of
async_insert
when present inendpoint
,connection_params
, and exporter config.Documentation:
Unrelated change, also updated README's SQL samples to use
sql
instead ofclickhouse
for the code samples to enable proper syntax highlighting. ClickHouse SQL is compatible with plain SQL.