aboutsummaryrefslogtreecommitdiff
path: root/src/exchange
diff options
context:
space:
mode:
authorChristian Grothoff <christian@grothoff.org>2019-12-01 13:31:45 +0100
committerChristian Grothoff <christian@grothoff.org>2019-12-01 13:31:45 +0100
commitf1639c09a22ab5d1453153946bde7f3df62ffb36 (patch)
tree337fc378774338e4f01afe91049b48a792db62b0 /src/exchange
parent97afbf1ea594748eafcda0f0cbd0f170d2d05015 (diff)
implement #5740
Diffstat (limited to 'src/exchange')
-rw-r--r--src/exchange/exchange.conf5
-rw-r--r--src/exchange/taler-exchange-httpd.c33
2 files changed, 36 insertions, 2 deletions
diff --git a/src/exchange/exchange.conf b/src/exchange/exchange.conf
index 7fe737b7..79b1877d 100644
--- a/src/exchange/exchange.conf
+++ b/src/exchange/exchange.conf
@@ -21,6 +21,11 @@ REVOCATION_DIR = ${TALER_DATA_HOME}/exchange/revocations/
# Used to artifically reduce caching (addresses #5747).
MAX_KEYS_CACHING = forever
+# After how many requests should the exchange auto-restart
+# (to address potential issues with memory fragmentation)?
+# If this option is not specified, auto-restarting is disabled.
+# MAX_REQUESTS = 10000000
+
# How to access our database
DB = postgres
diff --git a/src/exchange/taler-exchange-httpd.c b/src/exchange/taler-exchange-httpd.c
index 30efb8bc..bcac62ce 100644
--- a/src/exchange/taler-exchange-httpd.c
+++ b/src/exchange/taler-exchange-httpd.c
@@ -1,6 +1,6 @@
/*
This file is part of TALER
- Copyright (C) 2014, 2015, 2016, 2019 Inria and GNUnet e.V.
+ Copyright (C) 2014, 2015, 2016, 2019 Taler Systems SA
TALER is free software; you can redistribute it and/or modify it under the
terms of the GNU Affero General Public License as published by the Free Software
@@ -13,7 +13,6 @@
You should have received a copy of the GNU Affero General Public License along with
TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
*/
-
/**
* @file taler-exchange-httpd.c
* @brief Serve the HTTP interface of the exchange
@@ -144,6 +143,16 @@ static char *serve_unixpath;
*/
static mode_t unixpath_mode;
+/**
+ * Counter for the number of requests this HTTP has processed so far.
+ */
+static unsigned long long req_count;
+
+/**
+ * Limit for the number of requests this HTTP may process before restarting.
+ */
+static unsigned long long req_max;
+
/**
* Function called whenever MHD is done with a request. If the
@@ -422,7 +431,19 @@ handle_mhd_request (void *cls,
(void) version;
if (NULL == ecls)
{
+ unsigned long long cnt;
+
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "Handling new request\n");
+ cnt = __sync_add_and_fetch (&req_count, 1LLU);
+ if (req_max == cnt)
+ {
+ GNUNET_log (GNUNET_ERROR_TYPE_INFO,
+ "Restarting exchange service after %llu requests\n",
+ cnt);
+ (void) kill (getpid (),
+ SIGHUP);
+ }
+
/* We're in a new async scope! */
ecls = *con_cls = GNUNET_new (struct ExchangeHttpRequestClosure);
GNUNET_async_scope_fresh (&ecls->async_scope_id);
@@ -498,6 +519,14 @@ exchange_serve_process_config ()
char *TEH_master_public_key_str;
if (GNUNET_OK !=
+ GNUNET_CONFIGURATION_get_value_number (cfg,
+ "exchange",
+ "MAX_REQUESTS",
+ &req_max))
+ {
+ req_max = ULONG_LONG_MAX;
+ }
+ if (GNUNET_OK !=
GNUNET_CONFIGURATION_get_value_time (cfg,
"exchange",
"MAX_KEYS_CACHING",