-
-
Notifications
You must be signed in to change notification settings - Fork 881
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
nginx::locations puts locations in wrong order #971
Comments
When did you clone master? There was a recent PR that just reworked the logic of locations. Can you provide an example of the expected vs. actual ordering? FWIW, this is where most of the location logic happens: called from |
Cloned it today, a few hours back, approx. 5. I'm not using
but rather
So I think rather than https://github.com/voxpupuli/puppet-nginx/blob/master/manifests/resource/vhost.pp#L750 this line applies: https://github.com/voxpupuli/puppet-nginx/blob/master/manifests/init.pp#L276? The expected ordering would be as I have it in hiera: 'dev':
ensure: present
vhost: "%{hiera('vhost')}"
www_root: "/var/www/%{hiera('vhost')}/current/web"
fastcgi: phpfcgi
location: '~ ^/(app_dev|config)\.php(/|$)'
location_cfg_append:
fastcgi_split_path_info: '^(.+\.php)(.*)$'
fastcgi_param SCRIPT_FILENAME: $realpath_root$fastcgi_script_name
fastcgi_param DOCUMENT_ROOT: $realpath_root
'prod':
ensure: present
vhost: "%{hiera('vhost')}"
www_root: "/var/www/%{hiera('vhost')}/current/web"
fastcgi: phpfcgi
location: '~ ^/app\.php(/|$)'
location_cfg_append:
fastcgi_split_path_info: '^(.+\.php)(.*)$'
fastcgi_param SCRIPT_FILENAME: $realpath_root$fastcgi_script_name
fastcgi_param DOCUMENT_ROOT: $realpath_root
internal: true
'404':
ensure: absent
www_root: "/var/www/%{hiera('vhost')}/current/web"
vhost: "%{hiera('vhost')}"
location: '~ \.php'
location_cfg_append:
return: '404' And when applying it, we can actually see that it is the 404 location, which previously (0.5.0) was at the bottom, is now moved above the other regex locations:
|
OK, I'd say case closed. I didn't realize there was a priority parameter. When setting this to e.g. 899 on the 404 location, it is left at the end, as expected. |
To follow up, even though I marked it as closed: The change doesn't seem to have happened in this module, but rather in the concat module.
And now both environments disregard the order. The version of concat I had in one environment, installed without explicitly specifying a version, was 1.2.5. When I specify 2.2.0 explicitly, it only installs with a --force. With a priority of 899 and concat 2.2.0, it actually puts that location outside the server definition:
With a priority of 599, it's fine:
Maybe someone would like to open this ticket back up ;) |
Interesting, thanks for checking into this, and glad it doesn't seem to be directly related to the recent changes, but if concat's behavior is now different, we may need to make some adjustments or add some more tests of the ordering. I haven't used the priority feature much myself. I checked, and with a similar type of config (and a version of the module before the most recent changes), I do get some variance in the order compared to how I'm specifying things in hiera. I do note that the docs suggest a range between 401 and 599 for location. It's possible that using a value outside of this range is what's causing your problems with the placement within the generated file, though the module, perhaps, should throw an error if the user does this. If you keep your priority values within the stated ranges, does that help?
|
Hrm, it does validate it, however, it sets the range higher (899) than the docs suggest. https://github.com/voxpupuli/puppet-nginx/blob/master/manifests/resource/location.pp#L361-L366
If this is just a typo (rather than a feature), we could adjust the upper end of the range to 599. |
It does, as I mentioned in my edit. I had seen that mention of 599 as a maximum value, but then the code itself checks for values between 401 and 899, as you just mentioned here above, an I wanted to make sure my location block was as much at the bottom as possible, but not that much though. ;) |
@kwisatz: I created #972 for this tiny fix People may not know how to submit this. I'm not sure if there's anything we can do to influence the sorting order. From a quick look seems like |
Preserving the user's ordering would certainly be best I suppose. I tried alphanumeric, renaming my '404' location to 'z404' but that didn't change anything, so I don't think it's anything like that. |
It looks like ssl priority adds 300, which might be why it's 899, not 599? https://github.com/voxpupuli/puppet-nginx/blob/master/manifests/resource/location.pp#L436 |
I was thinking that for this reason, there might be a case for $locations to be an array of hashes, rather than a hash. This way, users who aren't being clever (with exported resources or some such), could just list the locations in hiera and since arrays are ordered, have an expectation of order in the config, as seen here. I've not looked too close at the code to know what change would be required to support this, but conceptually, I think it makes sense. This would avoid having to name resources something special to get them in the proper order, etc. |
@xaque208 I think post Ruby 1.9 (the supported version), hashes are ordered anyway, no? |
Oh @wyardley, I'd no idea about ordered hashes post 1.9. Neat. I'd have to look at the code more closely to know where we might apply a clean ordering. |
I realize this might not necessarily belong here, but it is specifically creating problems with nginx and I have the feeling that it actually changed with my upgrade from 0.5.0 to the git-master branch.
Also, I haven't found any information in the documentation on create_resources that would point to it being responsible for this behavior.
Our problem is, that nginx locations are put in the wrong order. With regex locations, order matters and in our case it puts a return 404 in front of the location it should actually match first, which makes my site 404 on all requests that should go to the main controller.
It does not seem to order by order of definition, nor alphabetically by the hash key/name. But I can't find the place where the locations are sorted.
The text was updated successfully, but these errors were encountered: