|  |  | 
|  | /* | 
|  | * 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_ */ |