|  | 
 | /* | 
 |  * Copyright (C) Igor Sysoev | 
 |  * Copyright (C) Nginx, Inc. | 
 |  */ | 
 |  | 
 |  | 
 | #ifndef _NGX_STREAM_UPSTREAM_ROUND_ROBIN_H_INCLUDED_ | 
 | #define _NGX_STREAM_UPSTREAM_ROUND_ROBIN_H_INCLUDED_ | 
 |  | 
 |  | 
 | #include <ngx_config.h> | 
 | #include <ngx_core.h> | 
 | #include <ngx_stream.h> | 
 |  | 
 |  | 
 | typedef struct ngx_stream_upstream_rr_peer_s   ngx_stream_upstream_rr_peer_t; | 
 |  | 
 | struct ngx_stream_upstream_rr_peer_s { | 
 |     struct sockaddr                 *sockaddr; | 
 |     socklen_t                        socklen; | 
 |     ngx_str_t                        name; | 
 |     ngx_str_t                        server; | 
 |  | 
 |     ngx_int_t                        current_weight; | 
 |     ngx_int_t                        effective_weight; | 
 |     ngx_int_t                        weight; | 
 |  | 
 |     ngx_uint_t                       conns; | 
 |  | 
 |     ngx_uint_t                       fails; | 
 |     time_t                           accessed; | 
 |     time_t                           checked; | 
 |  | 
 |     ngx_uint_t                       max_fails; | 
 |     time_t                           fail_timeout; | 
 |  | 
 |     ngx_uint_t                       down;         /* unsigned  down:1; */ | 
 |  | 
 | #if (NGX_STREAM_SSL) | 
 |     void                            *ssl_session; | 
 |     int                              ssl_session_len; | 
 | #endif | 
 |  | 
 |     ngx_stream_upstream_rr_peer_t   *next; | 
 |  | 
 | #if (NGX_STREAM_UPSTREAM_ZONE) | 
 |     ngx_atomic_t                     lock; | 
 | #endif | 
 | }; | 
 |  | 
 |  | 
 | typedef struct ngx_stream_upstream_rr_peers_s  ngx_stream_upstream_rr_peers_t; | 
 |  | 
 | struct ngx_stream_upstream_rr_peers_s { | 
 |     ngx_uint_t                       number; | 
 |  | 
 | #if (NGX_STREAM_UPSTREAM_ZONE) | 
 |     ngx_slab_pool_t                 *shpool; | 
 |     ngx_atomic_t                     rwlock; | 
 |     ngx_stream_upstream_rr_peers_t  *zone_next; | 
 | #endif | 
 |  | 
 |     ngx_uint_t                       total_weight; | 
 |  | 
 |     unsigned                         single:1; | 
 |     unsigned                         weighted:1; | 
 |  | 
 |     ngx_str_t                       *name; | 
 |  | 
 |     ngx_stream_upstream_rr_peers_t  *next; | 
 |  | 
 |     ngx_stream_upstream_rr_peer_t   *peer; | 
 | }; | 
 |  | 
 |  | 
 | #if (NGX_STREAM_UPSTREAM_ZONE) | 
 |  | 
 | #define ngx_stream_upstream_rr_peers_rlock(peers)                             \ | 
 |                                                                               \ | 
 |     if (peers->shpool) {                                                      \ | 
 |         ngx_rwlock_rlock(&peers->rwlock);                                     \ | 
 |     } | 
 |  | 
 | #define ngx_stream_upstream_rr_peers_wlock(peers)                             \ | 
 |                                                                               \ | 
 |     if (peers->shpool) {                                                      \ | 
 |         ngx_rwlock_wlock(&peers->rwlock);                                     \ | 
 |     } | 
 |  | 
 | #define ngx_stream_upstream_rr_peers_unlock(peers)                            \ | 
 |                                                                               \ | 
 |     if (peers->shpool) {                                                      \ | 
 |         ngx_rwlock_unlock(&peers->rwlock);                                    \ | 
 |     } | 
 |  | 
 |  | 
 | #define ngx_stream_upstream_rr_peer_lock(peers, peer)                         \ | 
 |                                                                               \ | 
 |     if (peers->shpool) {                                                      \ | 
 |         ngx_rwlock_wlock(&peer->lock);                                        \ | 
 |     } | 
 |  | 
 | #define ngx_stream_upstream_rr_peer_unlock(peers, peer)                       \ | 
 |                                                                               \ | 
 |     if (peers->shpool) {                                                      \ | 
 |         ngx_rwlock_unlock(&peer->lock);                                       \ | 
 |     } | 
 |  | 
 | #else | 
 |  | 
 | #define ngx_stream_upstream_rr_peers_rlock(peers) | 
 | #define ngx_stream_upstream_rr_peers_wlock(peers) | 
 | #define ngx_stream_upstream_rr_peers_unlock(peers) | 
 | #define ngx_stream_upstream_rr_peer_lock(peers, peer) | 
 | #define ngx_stream_upstream_rr_peer_unlock(peers, peer) | 
 |  | 
 | #endif | 
 |  | 
 |  | 
 | typedef struct { | 
 |     ngx_stream_upstream_rr_peers_t  *peers; | 
 |     ngx_stream_upstream_rr_peer_t   *current; | 
 |     uintptr_t                       *tried; | 
 |     uintptr_t                        data; | 
 | } ngx_stream_upstream_rr_peer_data_t; | 
 |  | 
 |  | 
 | ngx_int_t ngx_stream_upstream_init_round_robin(ngx_conf_t *cf, | 
 |     ngx_stream_upstream_srv_conf_t *us); | 
 | ngx_int_t ngx_stream_upstream_init_round_robin_peer(ngx_stream_session_t *s, | 
 |     ngx_stream_upstream_srv_conf_t *us); | 
 | ngx_int_t ngx_stream_upstream_get_round_robin_peer(ngx_peer_connection_t *pc, | 
 |     void *data); | 
 | void ngx_stream_upstream_free_round_robin_peer(ngx_peer_connection_t *pc, | 
 |     void *data, ngx_uint_t state); | 
 |  | 
 |  | 
 | #endif /* _NGX_STREAM_UPSTREAM_ROUND_ROBIN_H_INCLUDED_ */ |