On 03/16/09 13:39, Simon Riggs wrote:
On Wed, 2009-03-11 at 22:20 -0400, Jignesh K. Shah wrote:

A tunable does not impact existing behavior

Why not put the tunable parameter into the patch and then show the test
results with it in? If there is no overhead, we should then be able to
see that.



I did a patch where I define lock_wakeup_algorithm with default value of 0, and range is 0 to 32 It basically handles three types of algorithms and 32 different permutations, such that:
When lock_wakeup_algorithm is set to
0 => default logic of wakeup (only 1 exclusive or all sequential shared) 1 => wake up all sequential exclusives or all sequential shared 32>= n >=2 => wake up first n waiters irrespective of exclusive or sequential



I did a quick test with patch. Unfortunately it improves my number even with default setting 0 (not sure whether I should be pleased or sad - Definitely no overhead infact seems to help performance a bit. NOTE: Logic is same, implementation is slightly different for default set)

my Prepatch numbers typically peaked around 136,000 tpm
With the patch and settings:

lock_wakeup_algorithm=0
PEAK: 962: 512: Medium Throughput: 161121.000 Avg Medium Resp: 0.051


When lock_wakeup_algorithm=1
Then my PEAK increases to
PEAK 1560: 832: Medium Throughput: 176577.000 Avg Medium Resp: 0.086
(Couldn't recreate the 184K+ result.. need to check that)

I still havent tested for the rest 2-32 values but you get the point, the patch is quite flexible with various types of permutations and no overhead.

Do give it a try on your own setup and play with values and compare it with your original builds.

Regards,
Jignesh

*** lwlock.c    Tue Mar 17 12:27:49 2009
--- lwlock.c.orig       Wed Mar 11 12:48:27 2009
***************
*** 87,93 ****
  
  static int    lock_addin_request = 0;
  static bool lock_addin_request_allowed = true;
- int LWLockWakeupAlgorithm;
  
  #ifdef LWLOCK_STATS
  static int    counts_for_pid = 0;
--- 87,92 ----
***************
*** 564,570 ****
        PGPROC     *head;
        PGPROC     *proc;
        int                     i;
-         int         runq;
  
        PRINT_LWDEBUG("LWLockRelease", lockid, lock);
  
--- 563,568 ----
***************
*** 612,631 ****
                         * as many waiters as want shared access.
                         */
                        proc = head;
!                        if (LWLockWakeupAlgorithm || !proc->lwExclusive)
!                        {
!                               if (LWLockWakeupAlgorithm <= 1)
!                               {
                                while (proc->lwWaitLink != NULL &&
!                                   (proc->lwExclusive == 
proc->lwWaitLink->lwExclusive))
                                        proc = proc->lwWaitLink;
-                               }
-                                else 
-                               {  
-                                 runq= LWLockWakeupAlgorithm;
-                               while (proc->lwWaitLink != NULL && --runq)
-                                       proc = proc->lwWaitLink;
-                             }
                        }
                        /* proc is now the last PGPROC to be released */
                        lock->head = proc->lwWaitLink;
--- 610,620 ----
                         * as many waiters as want shared access.
                         */
                        proc = head;
!                       if (!proc->lwExclusive)
!                       {
                                while (proc->lwWaitLink != NULL &&
!                                          !proc->lwWaitLink->lwExclusive)
                                        proc = proc->lwWaitLink;
                        }
                        /* proc is now the last PGPROC to be released */
                        lock->head = proc->lwWaitLink;
*** lwlock.h.orig       Tue Mar 17 14:27:10 2009
--- lwlock.h    Tue Mar 17 08:24:40 2009
***************
*** 103,106 ****
--- 103,107 ----
  
  extern void RequestAddinLWLocks(int n);
  
+ extern int LWLockWakeupAlgorithm; 
  #endif   /* LWLOCK_H */
*** guc.c.orig  Tue Mar 17 07:30:26 2009
--- guc.c       Tue Mar 17 07:47:10 2009
***************
*** 57,62 ****
--- 57,63 ----
  #include "postmaster/walwriter.h"
  #include "regex/regex.h"
  #include "storage/bufmgr.h"
+ #include "storage/lwlock.h"
  #include "storage/fd.h"
  #include "tcop/tcopprot.h"
  #include "tsearch/ts_cache.h"
***************
*** 167,172 ****
--- 168,174 ----
  static bool assign_maxconnections(int newval, bool doit, GucSource source);
  static bool assign_autovacuum_max_workers(int newval, bool doit, GucSource 
source);
  static bool assign_effective_io_concurrency(int newval, bool doit, GucSource 
source);
+ static bool assign_lock_wakeup_algorithm(int newval, bool doit, GucSource 
source);
  static const char *assign_pgstat_temp_directory(const char *newval, bool 
doit, GucSource source);
  
  static char *config_enum_get_options(struct config_enum *record, 
***************
*** 416,421 ****
--- 418,424 ----
  static int    wal_segment_size;
  static bool integer_datetimes;
  static int    effective_io_concurrency;
+ static int    lock_wakeup_algorithm;
  
  /* should be static, but commands/variable.c needs to get at these */
  char     *role_string;
***************
*** 1727,1732 ****
--- 1730,1745 ----
        },
  
        {
+               {"lock_wakeup_algorithm", PGC_USERSET, RESOURCES,
+                       gettext_noop("Select algorithm for lock waiters wakeup. 
0 is default"),
+                       gettext_noop("Select 1 for SMP systems, and higher for 
manual conrol of number of waiters to wake up.")
+               },
+               &lock_wakeup_algorithm,
+               0, 0, 32,
+               assign_lock_wakeup_algorithm, NULL
+       },
+ 
+       {
                {"log_rotation_age", PGC_SIGHUP, LOGGING_WHERE,
                        gettext_noop("Automatic log file rotation will occur 
after N minutes."),
                        NULL,
***************
*** 7668,7673 ****
--- 7681,7698 ----
  #endif /* USE_PREFETCH */
  }
  
+ static bool
+ assign_lock_wakeup_algorithm(int newval, bool doit, GucSource source)
+ {
+       if ( newval < 0 && newval > 32)
+               return false;
+ 
+       if (doit)
+               LWLockWakeupAlgorithm= newval ;
+ 
+       return true;
+ }
+ 
  static const char *
  assign_pgstat_temp_directory(const char *newval, bool doit, GucSource source)
  {
-- 
Sent via pgsql-performance mailing list (pgsql-performance@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-performance

Reply via email to