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

Varnisncsa: Change matching rules to reflect reality #4213

Merged
merged 5 commits into from
Jan 22, 2025

Conversation

walid-git
Copy link
Member

This PR introduces the changes discussed in #3528

The relevant parts of [BE]requests/responses are now shown as they were received/sent from/to the peer, without taking irrelevant VCL changes into account. This PR also introduces the handling of Unset headers in varnishncsa.

Note: this breaks the default behavior of varnishncsa.

Fixes #3528.

Copy link
Member

@dridi dridi left a comment

Choose a reason for hiding this comment

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

I think this could be better organized.

bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
@walid-git walid-git force-pushed the varnisncsa_match_rules branch from b6c21ef to cbc5843 Compare October 30, 2024 19:16
Copy link
Member

@dridi dridi left a comment

Choose a reason for hiding this comment

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

I think we can improve this change a bit more if we actually follow the proposal for new matching rules more closely.

bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
@walid-git walid-git force-pushed the varnisncsa_match_rules branch from cbc5843 to 4d66ff0 Compare October 31, 2024 19:53
@walid-git
Copy link
Member Author

Discussed this offline with @dridi. Force pushed a (hopefully) much cleaner version now. All review items should be addressed/obsolete.

Copy link
Member

@nigoroll nigoroll left a comment

Choose a reason for hiding this comment

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

I pass my vote on to @dridi . If he is happy with it now, I am too.

Copy link
Member

@dridi dridi left a comment

Choose a reason for hiding this comment

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

Something went terribly wrong with this new iteration. I probably didn't express myself correctly so I tried to be a lot more specific in this review.

bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
@walid-git
Copy link
Member Author

Sorry for the mix-up, I have updated the PR now, let me know if it's still missing something.

Copy link
Member

@dridi dridi left a comment

Choose a reason for hiding this comment

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

One polish suggestion.

bin/varnishncsa/varnishncsa.c Outdated Show resolved Hide resolved
@walid-git
Copy link
Member Author

bugwash: ok

I will update the docs and merge

This is needed in order to differentiate between what was sent/received to/from
the client/server and the changes made to [be]req/resp in VCL.
It should be noted that this is the best approximation we can get as of today,
as there is no reliable vsl tag to tell exactly when we have finished receiving
a req/beresp, therefore we have to use vcl_recv and vcl_backend_response for now.
With this change, [Be]resp/[Be]req formats should reflect better what was
received/sent from/to the backend/client without taking irrelevant VCL
changes into account. There is however still an exception for the changes
performed by the core code before vcl_recv for req and before
vcl_backend_response for beresp that cannot be distinguished from the
original headers.

Refs: varnishcache#3528
@walid-git walid-git force-pushed the varnisncsa_match_rules branch from de4b66c to 5f515fb Compare January 22, 2025 10:51
@walid-git walid-git merged commit 30bfe66 into varnishcache:master Jan 22, 2025
9 of 10 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

varnishncsa logs header values even if they have in fact been unset
3 participants