[zorp] Zorp 2.1.5.5 can't handle load

Balazs Scheidler zorp@lists.balabit.hu
Sat, 22 May 2004 00:11:15 +0200


2004-05-21, p keltezéssel 19:53-kor Sheldon Hearn ezt írta:
> On Fri, 2004-05-21 at 10:37, Balazs Scheidler wrote:
> 
> > > chances are that you are using python2.3 and zorp 2.1. there was a
> > > locking issue looking similar what you have, the fix was included in
> > > 2.1.7.1, I'm not in the office right now but I can provide a broken down
> > > patch if you need that. (though upgrading to 2.1.7.1 should help too)
> > 
> > So the above fix should solve your SIGSEGV issue with HTTP, I will
> > explain your possibilities with load in the next mail.
> 
> I see only 2.1.7 available for download at
> http://www.balabit.com/downloads/zorp/2.1/src/, and it does not fix the
> SIGSEGV issue with HTTP.
> 
> # /usr/lib/zorp/zorp --version
> Zorp 2.1.7
> Compile-Date: May 21 2004 08:32:20
> Config-Date: 2004/05/21
> Trace: on
> Debug: on
> IPOptions: off
> IPFilter-Tproxy: off
> Netfilter-Tproxy: on
> Netfilter-Linux22-Fallback: on
> Linux22-Tproxy: off
> Conntrack: on

This is the patch that was incorporated in 2.1.7.1, but the GPL version
has not been released yet.
Index: zorp-core/lib/proxyvars.c
diff -u zorp-core/lib/proxyvars.c:1.10.2.1 zorp-core/lib/proxyvars.c:1.10.2.2
--- zorp-core/lib/proxyvars.c:1.10.2.1	Wed Aug  6 09:46:06 2003
+++ zorp-core/lib/proxyvars.c	Fri Apr 30 13:00:08 2004
@@ -742,19 +742,21 @@
       break;
     case Z_VAR_TYPE_METHOD:
       {
-	ZorpMethod *zm;
 	ZProxy *proxy;
 
 	proxy = va_arg(l, ZProxy *);
-	zm = z_py_zorp_method_new(proxy, va_arg(l, ZProxyMethodFunc));
-	e->value = zm;
+	z_python_lock();
+	e->value = z_py_zorp_method_new(proxy, va_arg(l, ZProxyMethodFunc));
+	z_python_unlock();
 	e->free = z_proxy_vars_method_free;
 	e->getvar = z_proxy_vars_method_get;
 	break;
       }
     case Z_VAR_TYPE_HASH:
 
+      z_python_lock();
       e->value = z_py_zorp_hash_new((GHashTable *) va_arg(l, gpointer));
+      z_python_unlock();
       e->free = z_proxy_vars_hash_free;
       e->getvar = z_proxy_vars_hash_get;
       break;
@@ -766,8 +768,9 @@
       e->free = va_arg(l, gpointer);
       break;
     case Z_VAR_TYPE_DIMHASH:
-
+      z_python_lock();
       e->value = z_py_zorp_dimhash_new((ZDimHashTable *) va_arg(l, gpointer));
+      z_python_unlock();
       e->free = z_proxy_vars_dimhash_free;
       e->getvar = z_proxy_vars_dimhash_get;
       break;


-- 
Bazsi
PGP info: KeyID 9AF8D0A9 Fingerprint CD27 CFB0 802C 0944 9CFD 804E C82C 8EB1