diff --git a/client/djrandom_client/daemonize.py b/client/djrandom_client/daemonize.py
index 8a2fc693dd7bbd08c472be75dbbbf9125608983b..2f1ffb694846e2a1ff8be00a4863b105a1a23ce3 100644
--- a/client/djrandom_client/daemonize.py
+++ b/client/djrandom_client/daemonize.py
@@ -99,6 +99,7 @@ def daemonize(opts, main_function, args, support_gevent=False):
         sys.exit(1)
 
     if opts.username:
+        os.chown(opts.pidfile, user_pw.pw_uid, user_pw.pw_gid)
         try:
             user_pw = pwd.getpwnam(opts.username)
             os.setuid(user_pw.pw_uid)
@@ -106,7 +107,6 @@ def daemonize(opts, main_function, args, support_gevent=False):
             sys.stderr.write(
                 'Error: could not find user "%s"\n' % opts.username)
             sys.exit(1)
-        os.chown(opts.pidfile, user_pw.pw_uid, user_pw.pw_gid)
 
     if support_gevent:
         import gevent
diff --git a/server/djrandom/daemonize.py b/server/djrandom/daemonize.py
index 8a2fc693dd7bbd08c472be75dbbbf9125608983b..2f1ffb694846e2a1ff8be00a4863b105a1a23ce3 100644
--- a/server/djrandom/daemonize.py
+++ b/server/djrandom/daemonize.py
@@ -99,6 +99,7 @@ def daemonize(opts, main_function, args, support_gevent=False):
         sys.exit(1)
 
     if opts.username:
+        os.chown(opts.pidfile, user_pw.pw_uid, user_pw.pw_gid)
         try:
             user_pw = pwd.getpwnam(opts.username)
             os.setuid(user_pw.pw_uid)
@@ -106,7 +107,6 @@ def daemonize(opts, main_function, args, support_gevent=False):
             sys.stderr.write(
                 'Error: could not find user "%s"\n' % opts.username)
             sys.exit(1)
-        os.chown(opts.pidfile, user_pw.pw_uid, user_pw.pw_gid)
 
     if support_gevent:
         import gevent