This doesn't avoid the race.

You just added a huge race in the in-memory scoreboards.  I'll be
re-instating the second chunk of this patch. 

Dean

On 10 Dec 1998 [EMAIL PROTECTED] wrote:

> jim         98/12/10 07:14:10
> 
>   Modified:    src/main http_main.c
>   Log:
>   Add 'reset slot vhost' logic to the
>   ap_update_child_status function and avoid the race as well.
>   
>   Revision  Changes    Path
>   1.409     +11 -9     apache-1.3/src/main/http_main.c
>   
>   Index: http_main.c
>   ===================================================================
>   RCS file: /export/home/cvs/apache-1.3/src/main/http_main.c,v
>   retrieving revision 1.408
>   retrieving revision 1.409
>   diff -u -r1.408 -r1.409
>   --- http_main.c     1998/12/04 19:12:16     1.408
>   +++ http_main.c     1998/12/10 15:14:08     1.409
>   @@ -2069,6 +2069,17 @@
>                                      sizeof(ss->request));
>           }
>           ss->vhostrec =  r->server;
>   +   } else if (status == SERVER_STARTING) {
>   +       /* clean up the slot's vhostrec pointer (maybe re-used)
>   +        * and mark the slot as belonging to a new generation.
>   +        */
>   +       ss->vhostrec = NULL;
>   +       ap_scoreboard_image->parent[child_num].generation = 
> ap_my_generation;
>   +#ifdef SCOREBOARD_FILE
>   +       lseek(scoreboard_fd, XtOffsetOf(scoreboard, parent[child_num]), 0);
>   +       force_write(scoreboard_fd, &ap_scoreboard_image->parent[child_num],
>   +           sizeof(parent_score));
>   +#endif
>       }
>        }
>        put_scoreboard_info(child_num, ss);
>   @@ -3917,15 +3928,6 @@
>        Explain1("Starting new child in slot %d", slot);
>        (void) ap_update_child_status(slot, SERVER_STARTING, (request_rec *) 
> NULL);
>    
>   -    /* clean up the slot's vhostrec pointer now that it is being re-used,
>   -     * and mark the slot as beloging to a new generation.
>   -     */
>   -    /* XXX: there's still a race condition here for file-based 
> scoreboards...
>   -     * but... like, do we really care to spend yet another write() 
> operation
>   -     * here? -djg
>   -     */
>   -    ap_scoreboard_image->servers[slot].vhostrec = NULL;
>   -    ap_scoreboard_image->parent[slot].generation = ap_my_generation;
>    
>    #ifndef _OSD_POSIX
>        if ((pid = fork()) == -1) {
>   
>   
>   
> 

Reply via email to