On Fri, Mar 11, 2016 at 12:00 AM, Amit Kapila <amit.kapil...@gmail.com> wrote: > On Wed, Mar 9, 2016 at 5:46 PM, Haribabu Kommi <kommi.harib...@gmail.com> > wrote: >> On Wed, Mar 9, 2016 at 10:06 PM, Amit Kapila <amit.kapil...@gmail.com> >> wrote: >> > On Wed, Mar 9, 2016 at 11:46 AM, Haribabu Kommi >> > <kommi.harib...@gmail.com> >> > wrote: >> >> >> >> >> >> I tried replacing the random() with PostmaterRandom() for a test and it >> >> worked. >> >> This is generating different random values, so the issue is not >> >> occurring. >> >> >> >> "Global/PostgreSQL.2115609797" >> >> >> >> I feel, we should add the the data directory path + the random number >> >> to >> >> generate the name for dynamic shared memory, this can fix problem. >> >> >> > >> > As mentioned above, I think if we can investigate why this error is >> > generated, that will be helpful. Currently the code ensures that if the >> > segment already exists, it should retry to create a segment with other >> > name >> > (refer dsm_impl_windows()), so the point of investigation is, why it is >> > not >> > going via that path? I am guessing due to some reason >> > CreateFileMapping() >> > is returning NULL in this case whereas ideally it should return the >> > existing >> > handle with an error ERROR_ALREADY_EXISTS. >> >> DEBUG: mapped win32 error code 5 to 13 >> >> Yes, the CreateFileMapping() is returning NULL with an error of >> ERROR_ACCESS_DENIED. >> > > Okay, so one probable theory for such an error could be that when there is > already an object with same name exists, this API requests access to the > that existing object and found that it can't access it due to some reason. > On googling, I found some people suggesting to try by disabling UAC  on > your m/c, can you once try that to see what is the result (this experiment > is just to find out the actual reason of failure, rather than a permanent > change suggestion).
Thanks for the details. Currently I am unable to change the UAC settings in my laptop. I will try to do it in a different system and let you know the result later. >> I am not able to find the reason for this error. This error is occurring >> only >> when the PostgreSQL is started as a service only. >> > > Did you use pg_ctl register/unregister to register different services. Can > you share the detail steps and OS version on which you saw this behaviour? Operating system - windows 7 Binary - PostgreSQL 9.5 (This doesn't matter, 9.4+ can produce the problem) 1. Create two standard users in the system (test_user1 and test_user2) 2. Create two databases belongs each user listed above. 3. Now using pg_ctl register the services for the two users. 4. Provide logon permissions to these users to run the services by changing service properties. 5. Now try to start the services, the second service fails with the error message. 6. Error details can be found out in Event log viewer. Regards, Hari Babu Fujitsu Australia -- Sent via pgsql-hackers mailing list (email@example.com) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers