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

Fix for wildcard routes taking precedence over other routes #19076

Merged
merged 1 commit into from
Mar 29, 2018

Conversation

jmprusi
Copy link
Contributor

@jmprusi jmprusi commented Mar 23, 2018

To avoid wildcard routes (type: Subdomain) overriding other routes that start with a number,
we first sort the non-wildcard routes and then we append the wildcard routes at the end of the file.

Related: #16724

@openshift-ci-robot openshift-ci-robot added the size/XS Denotes a PR that changes 0-9 lines, ignoring generated files. label Mar 23, 2018
@jmprusi jmprusi changed the title Fix for wildcard routes taking precedence over other routes https://github.com/openshift/origin/issues/16724 Fix for wildcard routes taking precedence over other routes Mar 23, 2018
@jmprusi
Copy link
Contributor Author

jmprusi commented Mar 23, 2018

/retest

@knobunc knobunc self-assigned this Mar 28, 2018
@knobunc knobunc requested review from ramr and rajatchopra March 28, 2018 19:05
@knobunc
Copy link
Contributor

knobunc commented Mar 28, 2018

@openshift/networking PTAL

Copy link
Contributor

@ramr ramr left a comment

Choose a reason for hiding this comment

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

Changes look good - just a couple of comments.

for mapfile in "$haproxy_conf_dir"/*.map; do
sort -r "$mapfile" -o "$mapfile"
grep -v -F '^[^\.]*\' "$mapfile" | sort -r -o /tmp/"$mapfile"
grep -F '^[^\.]*\' "$mapfile" >> /tmp/"$mapfile"
Copy link
Contributor

Choose a reason for hiding this comment

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

Sort it as well ala:
grep -F '^[^\.]*\' "$mapfile" | sort -r >> "/tmp/$mapfile"

grep -v -F '^[^\.]*\' "$mapfile" | sort -r -o /tmp/"$mapfile"
grep -F '^[^\.]*\' "$mapfile" >> /tmp/"$mapfile"
cp /tmp/"$mapfile" "$haproxy_conf_dir"/"$mapfile"
rm /tmp/"$mapfile"
Copy link
Contributor

@ramr ramr Mar 28, 2018

Choose a reason for hiding this comment

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

Could use: mv -f "/tmp/$mapfile" "$haproxy_conf_dir/$mapfile" to collapse the 2 commands.

To avoid having wildcard routes (type: Subdomain) override other routes,
we first sort the non-wildcard routes and then we append the wildcard routes
at the end of the file.
@jmprusi
Copy link
Contributor Author

jmprusi commented Mar 29, 2018

@knobunc @ramr thanks! Added your feedback!

Copy link
Contributor

@knobunc knobunc left a comment

Choose a reason for hiding this comment

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

LGTM. Thanks!

/lgtm

@openshift-ci-robot openshift-ci-robot added lgtm Indicates that a PR is ready to be merged. approved Indicates a PR has been approved by an approver from all required OWNERS files. labels Mar 29, 2018
@knobunc
Copy link
Contributor

knobunc commented Mar 29, 2018

/approve

@knobunc
Copy link
Contributor

knobunc commented Mar 29, 2018

/retest

@openshift-ci-robot
Copy link

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: jmprusi, knobunc

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@openshift-bot
Copy link
Contributor

/retest

Please review the full test history for this PR and help us cut down flakes.

Copy link
Contributor

@ramr ramr left a comment

Choose a reason for hiding this comment

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

Thx LGTM

@openshift-merge-robot openshift-merge-robot merged commit bb8bbbe into openshift:master Mar 29, 2018
@smarterclayton
Copy link
Contributor

This is reporting errors when I look at the logs:

I0330 02:15:04.127575       1 router.go:447] Router reloaded:
sort: open failed: /tmp//var/lib/haproxy/conf/cert_config.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/cert_config.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/cert_config.map': No such file or directory
sort: open failed: /tmp//var/lib/haproxy/conf/os_edge_reencrypt_be.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/os_edge_reencrypt_be.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/os_edge_reencrypt_be.map': No such file or directory
sort: open failed: /tmp//var/lib/haproxy/conf/os_http_be.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/os_http_be.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/os_http_be.map': No such file or directory
sort: open failed: /tmp//var/lib/haproxy/conf/os_route_http_redirect.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/os_route_http_redirect.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/os_route_http_redirect.map': No such file or directory
sort: open failed: /tmp//var/lib/haproxy/conf/os_sni_passthrough.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/os_sni_passthrough.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/os_sni_passthrough.map': No such file or directory
sort: open failed: /tmp//var/lib/haproxy/conf/os_tcp_be.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/os_tcp_be.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/os_tcp_be.map': No such file or directory
sort: open failed: /tmp//var/lib/haproxy/conf/os_wildcard_domain.map: No such file or directory
/var/lib/haproxy/reload-haproxy: line 80: /tmp//var/lib/haproxy/conf/os_wildcard_domain.map: No such file or directory
mv: cannot stat '/tmp//var/lib/haproxy/conf/os_wildcard_domain.map': No such file or directory
 - Checking http://localhost:80 ...
 - Health check ok : 0 retry attempt(s).

It looks like this has a break in it, I'm going to revert until we know for sure what is wrong.

@smarterclayton
Copy link
Contributor

Why is this sorting being done in the reload function and not in where we generate the map files in the first place?

@ramr
Copy link
Contributor

ramr commented Mar 30, 2018

So its failing because the file name is fully qualified -- needs a basename $mapfile for the name in the temp directory (the temp file created for this). Doh, I completed missed that.
So changes needed ala:

fname=$(basename "$mapfile")   
grep -v -F '^[^\.]*\' "$mapfile" | sort -r -o "/tmp/$fname"`

and do the same for all the other references.
@jmprusi fyi ↑

As re: the sorting @smarterclayton think that was just done from the start as we needed to reverse sort it for the longest path match on routes. This is so we match on the longest path first.
We could well sort in the template but it would still need like a two step process to do and would be further complicated with this case of doing like a regular route and then a wildcard sort.

@smarterclayton
Copy link
Contributor

smarterclayton commented Mar 30, 2018 via email

@ramr
Copy link
Contributor

ramr commented Mar 30, 2018

@smarterclayton well the template router is "sorta" (qualified) agnostic to the type of proxy underneath it. Could well do it in go code via something like a pre-processor run before the reload script is called (in the router/template code) but it would still have to be haproxy specific.
We also don't pass the router type to the infra command which we'd need since we now would have to set up the pre-processor for a haproxy specific router type, so it means some migration for existing router deployments.

@smarterclayton
Copy link
Contributor

smarterclayton commented Mar 30, 2018 via email

@jmprusi
Copy link
Contributor Author

jmprusi commented Mar 31, 2018

@smarterclayton @ramr should I open a new PR with the proper fixes (sorry) ?
edit:

Created a new PR with the required fixes:
#19187

@ramr
Copy link
Contributor

ramr commented Apr 2, 2018

@jmprusi Sorry for the delayed response - was traveling. So what @smarterclayton mentioned was using a new helper to do the sort. I'll work on this later this week.

@smarterclayton
Copy link
Contributor

smarterclayton commented Apr 2, 2018 via email

ramr added a commit to ramr/origin that referenced this pull request Apr 4, 2018
…ldcard

routes don't take precedence over routes that start with a number.
Based on discussions in PR openshift#19076 to fix issue openshift#16724
ramr added a commit to ramr/origin that referenced this pull request Apr 4, 2018
…ldcard

routes don't take precedence over routes that start with a number.
Based on discussions in PR openshift#19076 to fix issue openshift#16724
ramr added a commit to ramr/origin that referenced this pull request Apr 11, 2018
…ldcard

routes don't take precedence over routes that start with a number.
Make the template processing follow a particular order (based on file name),
so that we can use temporary files to write map data and subsequently sort
into the actual config map file.
Fixup helper to also sort cert_config but non-grouped to keep existing
behavior (backward compatibility).
Based on discussions in PR openshift#19076 to fix issue openshift#16724
ramr added a commit to ramr/origin that referenced this pull request Apr 11, 2018
…ldcard

routes don't take precedence over routes that start with a number.
Make the template processing follow a particular order (based on file name),
so that we can use temporary files to write map data and subsequently sort
into the actual config map file.
Fixup helper to also sort cert_config but non-grouped to keep existing
behavior (backward compatibility).
Based on discussions in PR openshift#19076 to fix issue openshift#16724
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. lgtm Indicates that a PR is ready to be merged. size/XS Denotes a PR that changes 0-9 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants