Changeset 35dacc


Ignore:
Timestamp:
02/03/08 15:02:44 (4 years ago)
Author:
Tomash Brechko <tomash.brechko@…>
Branches:
master-v0.7, master-v0.6, upstream_count_limit
Children:
2a12f7
Parents:
0cce45 (diff), 2a28c1 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
git-author:
Tomash Brechko <tomash.brechko@…> (02/03/08 15:02:44)
git-committer:
Tomash Brechko <tomash.brechko@…> (02/03/08 15:02:44)
Message:

Merge branch 'memcached_gzip'

Files:
8 added
9 edited

Legend:

Unmodified
Added
Removed
  • server/src/core/nginx.c

    r0019fc r6a5335  
    274274    } 
    275275 
    276     /* ngx_crc32_init() requires ngx_cacheline_size set in ngx_os_init() */ 
    277  
    278     if (ngx_crc32_init() != NGX_OK) { 
     276    /* 
     277     * ngx_crc32_table_init() requires ngx_cacheline_size set in ngx_os_init() 
     278     */ 
     279 
     280    if (ngx_crc32_table_init() != NGX_OK) { 
    279281        return 1; 
    280282    } 
  • server/src/core/ngx_crc32.c

    r0019fc r6a5335  
    103103 
    104104ngx_int_t 
    105 ngx_crc32_init(void) 
     105ngx_crc32_table_init(void) 
    106106{ 
    107107    void  *p; 
  • server/src/core/ngx_crc32.h

    r0019fc r6a5335  
    5050 
    5151 
    52 ngx_int_t ngx_crc32_init(void); 
     52#define ngx_crc32_init(crc)                                                   \ 
     53    crc = 0xffffffff 
     54 
     55 
     56static ngx_inline void 
     57ngx_crc32_update(uint32_t *crc, u_char *p, size_t len) 
     58{ 
     59    uint32_t  c; 
     60 
     61    c = *crc; 
     62 
     63    while (len--) { 
     64        c = ngx_crc32_table256[(c ^ *p++) & 0xff] ^ (c >> 8); 
     65    } 
     66 
     67    *crc = c; 
     68} 
     69 
     70 
     71#define ngx_crc32_final(crc)                                                  \ 
     72    crc ^= 0xffffffff 
     73 
     74 
     75ngx_int_t ngx_crc32_table_init(void); 
    5376 
    5477 
  • server/src/core/ngx_string.h

    r0019fc r8760a9  
    6464#define ngx_memset(buf, c, n)     (void) memset(buf, c, n) 
    6565 
     66#define ngx_memmove(dst, src, n)  (void) memmove(dst, src, n) 
    6667 
    6768#if (NGX_MEMCPY_LIMIT) 
  • server/src/http/modules/ngx_http_fastcgi_module.c

    r0019fc r66a597  
    180180    { ngx_string("invalid_header"), NGX_HTTP_UPSTREAM_FT_INVALID_HEADER }, 
    181181    { ngx_string("http_500"), NGX_HTTP_UPSTREAM_FT_HTTP_500 }, 
     182    { ngx_string("http_502"), NGX_HTTP_UPSTREAM_FT_HTTP_502 }, 
    182183    { ngx_string("http_503"), NGX_HTTP_UPSTREAM_FT_HTTP_503 }, 
     184    { ngx_string("http_504"), NGX_HTTP_UPSTREAM_FT_HTTP_504 }, 
     185    { ngx_string("http_507"), NGX_HTTP_UPSTREAM_FT_HTTP_507 }, 
    183186    { ngx_string("http_404"), NGX_HTTP_UPSTREAM_FT_HTTP_404 }, 
    184187    { ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF }, 
  • server/src/http/modules/ngx_http_gzip_filter_module.c

    r233310 r2bbdb3  
    319319 
    320320    if (ctx->preallocated == NULL) { 
    321         wbits = conf->wbits; 
     321        wbits = (!r->gunzip ? conf->wbits : 15); 
    322322        memlevel = conf->memlevel; 
    323323 
    324         if (ctx->length > 0) { 
     324        if (!r->gunzip && ctx->length > 0) { 
    325325 
    326326            /* the actual zlib window size is smaller by 262 bytes */ 
     
    543543            ctx->out_buf->last = ctx->zstream.next_out; 
    544544 
    545             if (ctx->zstream.avail_out == 0) { 
    546  
    547                 /* zlib wants to output some more gzipped data */ 
    548  
    549                 cl = ngx_alloc_chain_link(r->pool); 
    550                 if (cl == NULL) { 
    551                     ngx_http_gzip_error(ctx); 
    552                     return NGX_ERROR; 
    553                 } 
    554  
    555                 cl->buf = ctx->out_buf; 
    556                 cl->next = NULL; 
    557                 *ctx->last_out = cl; 
    558                 ctx->last_out = &cl->next; 
    559  
    560                 ctx->redo = 1; 
    561  
    562                 continue; 
    563             } 
    564  
    565545            ctx->redo = 0; 
    566546 
    567             if (ctx->flush == Z_SYNC_FLUSH 
    568                 && ctx->out_buf->last > ctx->out_buf->pos) { 
    569  
    570                 ctx->zstream.avail_out = 0; 
     547            if (ctx->flush == Z_SYNC_FLUSH) { 
     548 
    571549                ctx->out_buf->flush = 1; 
    572550                ctx->flush = Z_NO_FLUSH; 
    573551 
    574                 cl = ngx_alloc_chain_link(r->pool); 
    575                 if (cl == NULL) { 
    576                     ngx_http_gzip_error(ctx); 
    577                     return NGX_ERROR; 
    578                 } 
    579  
    580                 cl->buf = ctx->out_buf; 
    581                 cl->next = NULL; 
    582                 *ctx->last_out = cl; 
    583                 ctx->last_out = &cl->next; 
    584  
    585                 break; 
     552                /* 
     553                 * On decompression there might be not enough input 
     554                 * data to produce any output data. 
     555                 */ 
     556                if (ctx->out_buf->last > ctx->out_buf->pos) { 
     557 
     558                    ctx->zstream.avail_out = 0; 
     559 
     560                    cl = ngx_alloc_chain_link(r->pool); 
     561                    if (cl == NULL) { 
     562                        ngx_http_gzip_error(ctx); 
     563                        return NGX_ERROR; 
     564                    } 
     565 
     566                    cl->buf = ctx->out_buf; 
     567                    cl->next = NULL; 
     568                    *ctx->last_out = cl; 
     569                    ctx->last_out = &cl->next; 
     570 
     571                    break; 
     572                } 
    586573            } 
    587574 
     
    596583                    ctx->zout = ctx->zstream.total_out; 
    597584 
    598                     r->gunzip = 0; 
    599585                    rc = inflateEnd(&ctx->zstream); 
    600586                } 
     
    667653                } else { 
    668654                    ctx->out_buf->last_buf = 1; 
     655                    r->gunzip = 0; 
    669656                } 
    670657 
     
    677664 
    678665                break; 
     666            } 
     667 
     668            if (ctx->zstream.avail_out == 0) { 
     669 
     670                /* zlib wants to output some more gzipped data */ 
     671 
     672                cl = ngx_alloc_chain_link(r->pool); 
     673                if (cl == NULL) { 
     674                    ngx_http_gzip_error(ctx); 
     675                    return NGX_ERROR; 
     676                } 
     677 
     678                cl->buf = ctx->out_buf; 
     679                cl->next = NULL; 
     680                *ctx->last_out = cl; 
     681                ctx->last_out = &cl->next; 
     682 
     683                ctx->redo = 1; 
     684 
     685                continue; 
    679686            } 
    680687 
  • server/src/http/modules/ngx_http_proxy_module.c

    ra64318 r66a597  
    134134    { ngx_string("invalid_header"), NGX_HTTP_UPSTREAM_FT_INVALID_HEADER }, 
    135135    { ngx_string("http_500"), NGX_HTTP_UPSTREAM_FT_HTTP_500 }, 
     136    { ngx_string("http_502"), NGX_HTTP_UPSTREAM_FT_HTTP_502 }, 
    136137    { ngx_string("http_503"), NGX_HTTP_UPSTREAM_FT_HTTP_503 }, 
     138    { ngx_string("http_504"), NGX_HTTP_UPSTREAM_FT_HTTP_504 }, 
     139    { ngx_string("http_507"), NGX_HTTP_UPSTREAM_FT_HTTP_507 }, 
    137140    { ngx_string("http_404"), NGX_HTTP_UPSTREAM_FT_HTTP_404 }, 
    138141    { ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF }, 
  • server/src/http/ngx_http_upstream.c

    r0019fc r445d49  
    10941094    } 
    10951095 
     1096    if (u->headers_in.status_n == NGX_HTTP_BAD_GATEWAY) { 
     1097 
     1098        if (u->peer.tries > 1 
     1099            && u->conf->next_upstream & NGX_HTTP_UPSTREAM_FT_HTTP_502) 
     1100        { 
     1101            ngx_http_upstream_next(r, u, NGX_HTTP_UPSTREAM_FT_HTTP_502); 
     1102            return; 
     1103        } 
     1104    } 
     1105 
     1106    if (u->headers_in.status_n == NGX_HTTP_SERVICE_UNAVAILABLE) { 
     1107 
     1108        if (u->peer.tries > 1 
     1109            && u->conf->next_upstream & NGX_HTTP_UPSTREAM_FT_HTTP_503) 
     1110        { 
     1111            ngx_http_upstream_next(r, u, NGX_HTTP_UPSTREAM_FT_HTTP_503); 
     1112            return; 
     1113        } 
     1114    } 
     1115 
     1116    if (u->headers_in.status_n == NGX_HTTP_GATEWAY_TIME_OUT) { 
     1117 
     1118        if (u->peer.tries > 1 
     1119            && u->conf->next_upstream & NGX_HTTP_UPSTREAM_FT_HTTP_504) 
     1120        { 
     1121            ngx_http_upstream_next(r, u, NGX_HTTP_UPSTREAM_FT_HTTP_504); 
     1122            return; 
     1123        } 
     1124    } 
     1125 
     1126    if (u->headers_in.status_n == NGX_HTTP_INSUFFICIENT_STORAGE) { 
     1127 
     1128        if (u->peer.tries > 1 
     1129            && u->conf->next_upstream & NGX_HTTP_UPSTREAM_FT_HTTP_507) 
     1130        { 
     1131            ngx_http_upstream_next(r, u, NGX_HTTP_UPSTREAM_FT_HTTP_507); 
     1132            return; 
     1133        } 
     1134    } 
    10961135 
    10971136    if (u->headers_in.status_n >= NGX_HTTP_BAD_REQUEST 
     
    21732212        switch(ft_type) { 
    21742213 
     2214        case NGX_HTTP_UPSTREAM_FT_HTTP_504: 
    21752215        case NGX_HTTP_UPSTREAM_FT_TIMEOUT: 
    21762216            status = NGX_HTTP_GATEWAY_TIME_OUT; 
     
    21832223        case NGX_HTTP_UPSTREAM_FT_HTTP_404: 
    21842224            status = NGX_HTTP_NOT_FOUND; 
     2225            break; 
     2226 
     2227        case NGX_HTTP_UPSTREAM_FT_HTTP_502: 
     2228            status = NGX_HTTP_BAD_GATEWAY; 
     2229            break; 
     2230 
     2231        case NGX_HTTP_UPSTREAM_FT_HTTP_503: 
     2232            status = NGX_HTTP_SERVICE_UNAVAILABLE; 
     2233            break; 
     2234 
     2235        case NGX_HTTP_UPSTREAM_FT_HTTP_507: 
     2236            status = NGX_HTTP_INSUFFICIENT_STORAGE; 
    21852237            break; 
    21862238 
     
    31393191    } 
    31403192 
     3193    us->name = u.url; 
    31413194    us->addrs = u.addrs; 
    31423195    us->naddrs = u.naddrs; 
  • server/src/http/ngx_http_upstream.h

    r0019fc r445d49  
    2525#define NGX_HTTP_UPSTREAM_FT_BUSY_LOCK       0x00000080 
    2626#define NGX_HTTP_UPSTREAM_FT_MAX_WAITING     0x00000100 
     27#define NGX_HTTP_UPSTREAM_FT_HTTP_502        0x00000200 
     28#define NGX_HTTP_UPSTREAM_FT_HTTP_504        0x00000400 
     29#define NGX_HTTP_UPSTREAM_FT_HTTP_507        0x00000800 
    2730#define NGX_HTTP_UPSTREAM_FT_OFF             0x80000000 
    2831 
     
    6568 
    6669typedef struct { 
     70    ngx_str_t                       name; 
    6771    ngx_peer_addr_t                *addrs; 
    6872    ngx_uint_t                      naddrs; 
Note: See TracChangeset for help on using the changeset viewer.