|
Nathan
It is a combination of several things.
Normally the Apache server runs it QZSRCGI jobs under a common userprofile
(serverUserId) in the config file. That is that the QZSRCGI job actually
runs under user QTMHHTTP as job user id and the common user from the server
config as adopted/actual user profile.
The number of possible QZSRCGI jobs under and Apache instant is also a
config setting.
If all QZSRCGI jobs are active processing and a request comes in the
request I queued until a QZSRCGI job is idle.
When you set up the Apache to run persistent this scenario is changed.
QZSRCGI jobs now runs under the real user profile as adopted/actual. A new
request will cause apache to create a new QZSRCGI job for the requesting
user.
When the allowed number of active QZSRCGI jobs is reached and a new user
makes a request the trouble starts. What Apache will do is to find the
first idle QZSRCGI job allocated to another user, close it down and start a
new QZSRCGI job for the new user. This will of course mean that the closed
job will lose persistency.
Now, today we run AJAX and AJAX may fire parallel requests from one client
against the Apache server. The Apache server will not queue this request
for one QZSRCGI job but execute them in different QZSRCGI jobs and that
doesn’t matter if you run stateless or persistent.
So suddenly one user may have a number of in this case persistent QZSRCGI
jobs and nobody knows which of the jobs are used for a single request. This
will of course also add to the overhead of closing and restarting QZSRCGI
jobs when the maximum threshold is reached.
There may be techniques to avoid this behavior, but as standard I will not
call it persistent.
On Thu, Jun 11, 2015 at 3:36 PM, Nathan Andelin <nandelin@xxxxxxxxx>
wrote:
listis
PS. If you run Apache there is no such thing as persistent CGI but that
another rather long story. If you like I could explain it.
Henrik,
Yes, I would be interested in your views about "persistent CGI" under
Apache. My understanding is that Profound UI uses it. And it seems to
maintain a session which may time-out after a period of inactivity. What
makes you say there is "no such thing"?
BTW, I agree with your method of storing "session" variables in an IBM i
DB, keyed by a secure value.
--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing
To post a message email: MIDRANGE-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/midrange-l.
--
Regards,
Henrik Rützou
http://powerEXT.com <http://powerext.com/>
--
This is the Midrange Systems Technical Discussion (MIDRANGE-L) mailing list
To post a message email: MIDRANGE-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/midrange-l
or email: MIDRANGE-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/midrange-l.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.