Skip to content
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

PoC: keep log_comment metadata in ClickHouse queries #3702

Draft
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

aerosol
Copy link
Member

@aerosol aerosol commented Jan 18, 2024

Iteration on #3699

@macobo feel free to take it from here, if this is what you were looking for. There's certainly docs and tests missing 😜
Mind you, neither IngestRepo, ImportDeletionRepo nor AsyncInsertRepo are instrumented but I guess it's reads that you're interested in.

SELECT
    event_time,
    current_database,
    log_comment
FROM system.query_log
WHERE (type = 1) AND (length(log_comment) > 2) AND (current_database = 'plausible_events_db')
ORDER BY event_time DESC
LIMIT 20

Query id: f960341e-e871-4f1b-bef7-ee5ddce8f089

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€event_time─┬─current_database────┬─log_comment────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
β”‚ 2024-01-18 06:43:03 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/entry-pages","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"goal\":\"Visit /register\",\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}} β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€event_time─┬─current_database────┬─log_comment────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
β”‚ 2024-01-18 06:42:56 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/operating-systems","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"goal\":\"Visit /register\",\"source\":\"Twitter\",\"page\":\"~a\"}","period":"year","with_imported":"true"}} β”‚
β”‚ 2024-01-18 06:42:56 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/referrers/Twitter","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"goal\":\"Visit /register\",\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","referrer":"Twitter","with_imported":"true"}} β”‚
β”‚ 2024-01-18 06:42:56 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/exit-pages","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"goal\":\"Visit /register\",\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}} β”‚
β”‚ 2024-01-18 06:42:56 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/cities","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"goal\":\"Visit /register\",\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}} β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€event_time─┬─current_database────┬─log_comment────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
β”‚ 2024-01-18 06:42:51 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/current-visitors","query_type":"current_visitors"}}                                                                                                                                                  β”‚
β”‚ 2024-01-18 06:42:48 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/referrers/Twitter","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","referrer":"Twitter","with_imported":"true"}} β”‚
β”‚ 2024-01-18 06:42:48 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/operating-systems","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"source\":\"Twitter\",\"page\":\"~a\"}","period":"year","with_imported":"true"}}                  β”‚
β”‚ 2024-01-18 06:42:48 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/cities","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}}                 β”‚
β”‚ 2024-01-18 06:42:48 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/exit-pages","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"source\":\"Twitter\",\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}}             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€event_time─┬─current_database────┬─log_comment────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┐
β”‚ 2024-01-18 06:42:45 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/suggestions/source","query_type":"filter_suggestions","date":"2024-01-18","domain":"dummy.site","filter_name":"source","filters":"{\"page\":\"~a\"}","period":"year","q":"","with_imported":"true"}} β”‚
β”‚ 2024-01-18 06:42:30 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/exit-pages","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}}                                    β”‚
β”‚ 2024-01-18 06:42:30 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/cities","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}}                                        β”‚
β”‚ 2024-01-18 06:42:30 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/operating-systems","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"page\":\"~a\"}","period":"year","with_imported":"true"}}                                         β”‚
β”‚ 2024-01-18 06:42:30 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/sources","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{\"page\":\"~a\"}","limit":"9","period":"year","with_imported":"true"}}                                       β”‚
β”‚ 2024-01-18 06:42:21 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/operating-systems","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{}","period":"year","with_imported":"true"}}                                                        β”‚
β”‚ 2024-01-18 06:42:21 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/cities","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{}","limit":"9","period":"year","with_imported":"true"}}                                                       β”‚
β”‚ 2024-01-18 06:42:21 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/exit-pages","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{}","limit":"9","period":"year","with_imported":"true"}}                                                   β”‚
β”‚ 2024-01-18 06:42:21 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/exit-pages","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{}","limit":"9","period":"year","with_imported":"true"}}                                                   β”‚
β”‚ 2024-01-18 06:42:21 β”‚ plausible_events_db β”‚ {"log_comment":{"request_path":"/api/stats/dummy.site/sources","query_type":"breakdown","date":"2024-01-18","domain":"dummy.site","filters":"{}","limit":"9","period":"year","with_imported":"true"}}                                                      β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

def init(_opts), do: nil

def call(conn, _) do
ClickhouseRepo.set_context(%{request_path: conn.request_path})
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Depending on what's more suitable, we can either go with route with placeholders, or full request path

@@ -15,6 +15,8 @@ defmodule Plausible.Stats.Query do
@type t :: %__MODULE__{}

def from(site, params) do
Plausible.ClickhouseRepo.set_context(params)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not a great idea perhaps, since params is external and at this point, untrusted, input.

We could probably sanitize it a bit, or serialize the result of Map.from_struct(query) but there's a bit more work required, depending on what is really useful to keep - just flagging it.

Similarly, there's more places when the %Query{} is updated - some changes are made via this module, but others operate on the struct directly, so there's probably a good chunk of sensible info missing unless we keep track of it too. Maybe a good opportunity to make sure the struct is opaque and is never changed outside of its API.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

1 participant