Routes fail when making simultaneous requests and with setAutoReload(true)

Description

If setAutoReload(true) is set in the configuration, and a client makes two or more requests in a short period of time (for example, an AJAX query when a page loads), the second request occasionally returns the site home page contents rather than the requested page (i.e. the topmost domain page; 'www.example.com' as opposed to 'www.example.com/my/event').

I think this is happening because interceptors/SES.cfc doesn't do any synchronization, so the second request hits the page while the configuration is reloading. The routes would be empty, so the interceptor would think the request was to the homepage (ex. 'www.myexample.com') and interpret the directory info as extra arguments (ex. 'my=event').

Activity

Show:
Alex Parrill
December 5, 2013, 9:37 PM

Why? Autoreloading of configuration files during development is a useful thing to have.

Luis Majano
December 5, 2013, 9:40 PM

We are considering, not decided. However, it should just be used for dev. The problem we get, is so many times people leave it for production.

Alex Parrill
December 5, 2013, 9:43 PM

Okay, but what does that have to do with the issue? I understand that it should only be on during development, but it should still function correctly.

Luis Majano
December 5, 2013, 11:17 PM

The problem is that auto reload wipes and does not lock. I am not sure adding lock overhead to the logic makes sense for a development features. That is where I am divided and we usually mention that this setting is meant for development and it can cause some side-effects that a simple fwreinit resolves. Thus, the added overhead of locking strategies to the CFC is something I don't know if it is worth it.

Alex Parrill
December 6, 2013, 2:24 AM
Edited

Is a single named lock per request really that much of an overhead? In a production server, they would all be read locks anyway, thus they wouldn't block each other.

Won't Fix

Assignee

Luis Majano

Reporter

Alex Parrill

Labels

None

Components

Affects versions

Priority

Major
Configure