9ae3f9
From fbda9baaf7231e3237277348cc7e873f3113fd14 Mon Sep 17 00:00:00 2001
9ae3f9
From: l17zhou <cynthia.zhou@nokia-sbell.com.cn>
9ae3f9
Date: Mon, 4 Nov 2019 08:45:52 +0200
9ae3f9
Subject: [PATCH 388/449] rpc: Cleanup SSL specific data at the time of freeing
9ae3f9
 rpc object
9ae3f9
9ae3f9
Problem: At the time of cleanup rpc object ssl specific data
9ae3f9
         is not freeing so it has become a leak.
9ae3f9
9ae3f9
Solution: To avoid the leak cleanup ssl specific data at the
9ae3f9
          time of cleanup rpc object
9ae3f9
9ae3f9
> Credits: l17zhou <cynthia.zhou@nokia-sbell.com.cn>
9ae3f9
> Fixes: bz#1768407
9ae3f9
> Change-Id: I37f598673ae2d7a33c75f39eb8843ccc6dffaaf0
9ae3f9
> (Cherry pick from commit 54ed71dba174385ab0d8fa415e09262f6250430c)
9ae3f9
> (Reviewed on upstream link https://review.gluster.org/#/c/glusterfs/+/23650/)
9ae3f9
9ae3f9
Change-Id: I37f598673ae2d7a33c75f39eb8843ccc6dffaaf0
9ae3f9
BUG: 1786516
9ae3f9
Signed-off-by: Mohit Agrawal <moagrawa@redhat.com>
9ae3f9
Reviewed-on: https://code.engineering.redhat.com/gerrit/202308
9ae3f9
Tested-by: RHGS Build Bot <nigelb@redhat.com>
9ae3f9
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
9ae3f9
---
9ae3f9
 rpc/rpc-transport/socket/src/socket.c | 22 ++++++++++++++++++++--
9ae3f9
 tests/features/ssl-authz.t            | 23 ++++++++++++++++++++---
9ae3f9
 2 files changed, 40 insertions(+), 5 deletions(-)
9ae3f9
9ae3f9
diff --git a/rpc/rpc-transport/socket/src/socket.c b/rpc/rpc-transport/socket/src/socket.c
9ae3f9
index 65845ea..226b2e2 100644
9ae3f9
--- a/rpc/rpc-transport/socket/src/socket.c
9ae3f9
+++ b/rpc/rpc-transport/socket/src/socket.c
9ae3f9
@@ -446,6 +446,7 @@ ssl_setup_connection_postfix(rpc_transport_t *this)
9ae3f9
     gf_log(this->name, GF_LOG_DEBUG,
9ae3f9
            "SSL verification succeeded (client: %s) (server: %s)",
9ae3f9
            this->peerinfo.identifier, this->myinfo.identifier);
9ae3f9
+    X509_free(peer);
9ae3f9
     return gf_strdup(peer_CN);
9ae3f9
 
9ae3f9
     /* Error paths. */
9ae3f9
@@ -1157,7 +1158,15 @@ __socket_reset(rpc_transport_t *this)
9ae3f9
     memset(&priv->incoming, 0, sizeof(priv->incoming));
9ae3f9
 
9ae3f9
     event_unregister_close(this->ctx->event_pool, priv->sock, priv->idx);
9ae3f9
-
9ae3f9
+    if (priv->use_ssl && priv->ssl_ssl) {
9ae3f9
+        SSL_clear(priv->ssl_ssl);
9ae3f9
+        SSL_free(priv->ssl_ssl);
9ae3f9
+        priv->ssl_ssl = NULL;
9ae3f9
+    }
9ae3f9
+    if (priv->use_ssl && priv->ssl_ctx) {
9ae3f9
+        SSL_CTX_free(priv->ssl_ctx);
9ae3f9
+        priv->ssl_ctx = NULL;
9ae3f9
+    }
9ae3f9
     priv->sock = -1;
9ae3f9
     priv->idx = -1;
9ae3f9
     priv->connected = -1;
9ae3f9
@@ -3217,7 +3226,6 @@ socket_server_event_handler(int fd, int idx, int gen, void *data, int poll_in,
9ae3f9
         new_priv->sock = new_sock;
9ae3f9
 
9ae3f9
         new_priv->ssl_enabled = priv->ssl_enabled;
9ae3f9
-        new_priv->ssl_ctx = priv->ssl_ctx;
9ae3f9
         new_priv->connected = 1;
9ae3f9
         new_priv->is_server = _gf_true;
9ae3f9
 
9ae3f9
@@ -4672,6 +4680,16 @@ fini(rpc_transport_t *this)
9ae3f9
         pthread_mutex_destroy(&priv->out_lock);
9ae3f9
         pthread_mutex_destroy(&priv->cond_lock);
9ae3f9
         pthread_cond_destroy(&priv->cond);
9ae3f9
+        if (priv->use_ssl && priv->ssl_ssl) {
9ae3f9
+            SSL_clear(priv->ssl_ssl);
9ae3f9
+            SSL_free(priv->ssl_ssl);
9ae3f9
+            priv->ssl_ssl = NULL;
9ae3f9
+        }
9ae3f9
+        if (priv->use_ssl && priv->ssl_ctx) {
9ae3f9
+            SSL_CTX_free(priv->ssl_ctx);
9ae3f9
+            priv->ssl_ctx = NULL;
9ae3f9
+        }
9ae3f9
+
9ae3f9
         if (priv->ssl_private_key) {
9ae3f9
             GF_FREE(priv->ssl_private_key);
9ae3f9
         }
9ae3f9
diff --git a/tests/features/ssl-authz.t b/tests/features/ssl-authz.t
9ae3f9
index cae010c..132b598 100755
9ae3f9
--- a/tests/features/ssl-authz.t
9ae3f9
+++ b/tests/features/ssl-authz.t
9ae3f9
@@ -25,6 +25,7 @@ TEST glusterd
9ae3f9
 TEST pidof glusterd
9ae3f9
 TEST $CLI volume info;
9ae3f9
 
9ae3f9
+TEST $CLI v set all cluster.brick-multiplex on
9ae3f9
 # Construct a cipher list that excludes CBC because of POODLE.
9ae3f9
 # http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2014-3566
9ae3f9
 #
9ae3f9
@@ -45,12 +46,12 @@ TEST openssl genrsa -out $SSL_KEY 2048
9ae3f9
 TEST openssl req -new -x509 -key $SSL_KEY -subj /CN=Anyone -out $SSL_CERT
9ae3f9
 ln $SSL_CERT $SSL_CA
9ae3f9
 
9ae3f9
-TEST $CLI volume create $V0 $H0:$B0/1
9ae3f9
+TEST $CLI volume create $V0 replica 3 $H0:$B0/{1,2,3} force
9ae3f9
 TEST $CLI volume set $V0 server.ssl on
9ae3f9
 TEST $CLI volume set $V0 client.ssl on
9ae3f9
 TEST $CLI volume set $V0 ssl.cipher-list $(valid_ciphers)
9ae3f9
 TEST $CLI volume start $V0
9ae3f9
-EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" online_brick_count
9ae3f9
+EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" online_brick_count
9ae3f9
 
9ae3f9
 # This mount should SUCCEED because ssl-allow=* by default.  This effectively
9ae3f9
 # disables SSL authorization, though authentication and encryption might still
9ae3f9
@@ -59,11 +60,27 @@ TEST glusterfs --volfile-server=$H0 --volfile-id=$V0 $M0
9ae3f9
 TEST ping_file $M0/before
9ae3f9
 EXPECT_WITHIN $UMOUNT_TIMEOUT "Y" force_umount $M0
9ae3f9
 
9ae3f9
+glusterfsd_pid=`pgrep glusterfsd`
9ae3f9
+TEST [ $glusterfsd_pid != 0 ]
9ae3f9
+start=`pmap -x $glusterfsd_pid | grep total | awk -F " " '{print $4}'`
9ae3f9
+echo "Memory consumption for glusterfsd process"
9ae3f9
+for i in $(seq 1 100); do
9ae3f9
+        gluster v heal $V0 info >/dev/null
9ae3f9
+done
9ae3f9
+
9ae3f9
+end=`pmap -x $glusterfsd_pid | grep total | awk -F " " '{print $4}'`
9ae3f9
+diff=$((end-start))
9ae3f9
+
9ae3f9
+# If memory consumption is more than 5M some leak in SSL code path
9ae3f9
+
9ae3f9
+TEST [ $diff -lt 5000 ]
9ae3f9
+
9ae3f9
+
9ae3f9
 # Set ssl-allow to a wildcard that includes our identity.
9ae3f9
 TEST $CLI volume stop $V0
9ae3f9
 TEST $CLI volume set $V0 auth.ssl-allow Any*
9ae3f9
 TEST $CLI volume start $V0
9ae3f9
-EXPECT_WITHIN $CHILD_UP_TIMEOUT "1" online_brick_count
9ae3f9
+EXPECT_WITHIN $CHILD_UP_TIMEOUT "3" online_brick_count
9ae3f9
 
9ae3f9
 # This mount should SUCCEED because we match the wildcard.
9ae3f9
 TEST glusterfs --volfile-server=$H0 --volfile-id=$V0 $M0
9ae3f9
-- 
9ae3f9
1.8.3.1
9ae3f9