mirror of
https://github.com/nginx/nginx.git
synced 2025-01-21 13:53:08 -06:00
embed session_rbtree and sentinel inside ngx_ssl_session_cache_t
This commit is contained in:
parent
0a0024bdb5
commit
181abe549f
@ -1217,7 +1217,6 @@ static ngx_int_t
|
|||||||
ngx_ssl_session_cache_init(ngx_shm_zone_t *shm_zone, void *data)
|
ngx_ssl_session_cache_init(ngx_shm_zone_t *shm_zone, void *data)
|
||||||
{
|
{
|
||||||
ngx_slab_pool_t *shpool;
|
ngx_slab_pool_t *shpool;
|
||||||
ngx_rbtree_node_t *sentinel;
|
|
||||||
ngx_ssl_session_cache_t *cache;
|
ngx_ssl_session_cache_t *cache;
|
||||||
|
|
||||||
if (data) {
|
if (data) {
|
||||||
@ -1232,25 +1231,15 @@ ngx_ssl_session_cache_init(ngx_shm_zone_t *shm_zone, void *data)
|
|||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ngx_rbtree_init(&cache->session_rbtree, &cache->sentinel,
|
||||||
|
ngx_ssl_session_rbtree_insert_value);
|
||||||
|
|
||||||
cache->session_cache_head.prev = NULL;
|
cache->session_cache_head.prev = NULL;
|
||||||
cache->session_cache_head.next = &cache->session_cache_tail;
|
cache->session_cache_head.next = &cache->session_cache_tail;
|
||||||
|
|
||||||
cache->session_cache_tail.prev = &cache->session_cache_head;
|
cache->session_cache_tail.prev = &cache->session_cache_head;
|
||||||
cache->session_cache_tail.next = NULL;
|
cache->session_cache_tail.next = NULL;
|
||||||
|
|
||||||
cache->session_rbtree = ngx_slab_alloc(shpool, sizeof(ngx_rbtree_t));
|
|
||||||
if (cache->session_rbtree == NULL) {
|
|
||||||
return NGX_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
sentinel = ngx_slab_alloc(shpool, sizeof(ngx_rbtree_node_t));
|
|
||||||
if (sentinel == NULL) {
|
|
||||||
return NGX_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
ngx_rbtree_init(cache->session_rbtree, sentinel,
|
|
||||||
ngx_ssl_session_rbtree_insert_value);
|
|
||||||
|
|
||||||
shm_zone->data = cache;
|
shm_zone->data = cache;
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -1369,7 +1358,7 @@ ngx_ssl_new_session(ngx_ssl_conn_t *ssl_conn, ngx_ssl_session_t *sess)
|
|||||||
sess_id->prev = &cache->session_cache_head;
|
sess_id->prev = &cache->session_cache_head;
|
||||||
cache->session_cache_head.next = sess_id;
|
cache->session_cache_head.next = sess_id;
|
||||||
|
|
||||||
ngx_rbtree_insert(cache->session_rbtree, &sess_id->node);
|
ngx_rbtree_insert(&cache->session_rbtree, &sess_id->node);
|
||||||
|
|
||||||
ngx_shmtx_unlock(&shpool->mutex);
|
ngx_shmtx_unlock(&shpool->mutex);
|
||||||
|
|
||||||
@ -1432,8 +1421,8 @@ ngx_ssl_get_cached_session(ngx_ssl_conn_t *ssl_conn, u_char *id, int len,
|
|||||||
|
|
||||||
ngx_shmtx_lock(&shpool->mutex);
|
ngx_shmtx_lock(&shpool->mutex);
|
||||||
|
|
||||||
node = cache->session_rbtree->root;
|
node = cache->session_rbtree.root;
|
||||||
sentinel = cache->session_rbtree->sentinel;
|
sentinel = cache->session_rbtree.sentinel;
|
||||||
|
|
||||||
while (node != sentinel) {
|
while (node != sentinel) {
|
||||||
|
|
||||||
@ -1470,7 +1459,7 @@ ngx_ssl_get_cached_session(ngx_ssl_conn_t *ssl_conn, u_char *id, int len,
|
|||||||
sess_id->next->prev = sess_id->prev;
|
sess_id->next->prev = sess_id->prev;
|
||||||
sess_id->prev->next = sess_id->next;
|
sess_id->prev->next = sess_id->next;
|
||||||
|
|
||||||
ngx_rbtree_delete(cache->session_rbtree, node);
|
ngx_rbtree_delete(&cache->session_rbtree, node);
|
||||||
|
|
||||||
ngx_slab_free_locked(shpool, sess_id->session);
|
ngx_slab_free_locked(shpool, sess_id->session);
|
||||||
#if (NGX_PTR_SIZE == 4)
|
#if (NGX_PTR_SIZE == 4)
|
||||||
@ -1527,8 +1516,8 @@ ngx_ssl_remove_session(SSL_CTX *ssl, ngx_ssl_session_t *sess)
|
|||||||
|
|
||||||
ngx_shmtx_lock(&shpool->mutex);
|
ngx_shmtx_lock(&shpool->mutex);
|
||||||
|
|
||||||
node = cache->session_rbtree->root;
|
node = cache->session_rbtree.root;
|
||||||
sentinel = cache->session_rbtree->sentinel;
|
sentinel = cache->session_rbtree.sentinel;
|
||||||
|
|
||||||
while (node != sentinel) {
|
while (node != sentinel) {
|
||||||
|
|
||||||
@ -1553,7 +1542,7 @@ ngx_ssl_remove_session(SSL_CTX *ssl, ngx_ssl_session_t *sess)
|
|||||||
sess_id->next->prev = sess_id->prev;
|
sess_id->next->prev = sess_id->prev;
|
||||||
sess_id->prev->next = sess_id->next;
|
sess_id->prev->next = sess_id->next;
|
||||||
|
|
||||||
ngx_rbtree_delete(cache->session_rbtree, node);
|
ngx_rbtree_delete(&cache->session_rbtree, node);
|
||||||
|
|
||||||
ngx_slab_free_locked(shpool, sess_id->session);
|
ngx_slab_free_locked(shpool, sess_id->session);
|
||||||
#if (NGX_PTR_SIZE == 4)
|
#if (NGX_PTR_SIZE == 4)
|
||||||
@ -1601,7 +1590,7 @@ ngx_ssl_expire_sessions(ngx_ssl_session_cache_t *cache,
|
|||||||
sess_id->next->prev = sess_id->prev;
|
sess_id->next->prev = sess_id->prev;
|
||||||
sess_id->prev->next = sess_id->next;
|
sess_id->prev->next = sess_id->next;
|
||||||
|
|
||||||
ngx_rbtree_delete(cache->session_rbtree, &sess_id->node);
|
ngx_rbtree_delete(&cache->session_rbtree, &sess_id->node);
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, ngx_cycle->log, 0,
|
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, ngx_cycle->log, 0,
|
||||||
"expire session: %08Xi", sess_id->node.key);
|
"expire session: %08Xi", sess_id->node.key);
|
||||||
|
@ -75,7 +75,8 @@ struct ngx_ssl_sess_id_s {
|
|||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
ngx_rbtree_t *session_rbtree;
|
ngx_rbtree_t session_rbtree;
|
||||||
|
ngx_rbtree_node_t sentinel;
|
||||||
ngx_ssl_sess_id_t session_cache_head;
|
ngx_ssl_sess_id_t session_cache_head;
|
||||||
ngx_ssl_sess_id_t session_cache_tail;
|
ngx_ssl_sess_id_t session_cache_tail;
|
||||||
} ngx_ssl_session_cache_t;
|
} ngx_ssl_session_cache_t;
|
||||||
|
Loading…
Reference in New Issue
Block a user