Received: from malur.postgresql.org ([217.196.149.56]) by arkaria.postgresql.org with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1nSgr8-000892-LO for pgsql-hackers@arkaria.postgresql.org; Fri, 11 Mar 2022 15:07:02 +0000 Received: from localhost ([127.0.0.1] helo=malur.postgresql.org) by malur.postgresql.org with esmtp (Exim 4.92) (envelope-from ) id 1nSgr7-0006k8-9W for pgsql-hackers@arkaria.postgresql.org; Fri, 11 Mar 2022 15:07:01 +0000 Received: from magus.postgresql.org ([2a02:c0:301:0:ffff::29]) by malur.postgresql.org with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1nSgr6-0006jy-VA for pgsql-hackers@lists.postgresql.org; Fri, 11 Mar 2022 15:07:01 +0000 Received: from mail-pf1-x430.google.com ([2607:f8b0:4864:20::430]) by magus.postgresql.org with esmtps (TLS1.3:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.92) (envelope-from ) id 1nSgqz-0006Tz-T9 for pgsql-hackers@postgresql.org; Fri, 11 Mar 2022 15:07:00 +0000 Received: by mail-pf1-x430.google.com with SMTP id g19so8051425pfc.9 for ; Fri, 11 Mar 2022 07:06:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=+sgf/131vTyOmtVehtsm165z5OG/JVp/u+ehKr2TjXI=; b=WoI6ZTAmg938xKSgBrtgqom/1P5FU6cHegzjzvBcuEKhbrgUFb0KBPA1aJKWCSK1Rl +9Fr4hZ+hJNswG6cTYcZNhJyKlvTEH86x3ldSf45edJNOLOIcsiPD42rdUCo5Az+qmiD qtZkURGQOxH92PQqssnJfV7gEtC2QkTblAjp5WluFOPBLrWsFcjH5/dQarGyve92JWbr Vm1BCCSKhEWMq/LcyvWVkCqPt2PQQK3tEvzQFlCXmDoBIC5xenDnZABNk5n93gloHmk3 hnL7j7cpdaMf4VTrv+k4hrwJ3Qh+2bmIqgSuy7rqsTBoDunAyekhp6KGqFMD7xv10Od1 WbJg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=+sgf/131vTyOmtVehtsm165z5OG/JVp/u+ehKr2TjXI=; b=OnajW6/fiKLTBjnueL1scPf9sOnWTkfhuOswazYa6NK4H1DOd/4M/lMNdtwY8q+NLJ 6ZsgwOZ/lflh2srrXZymQCD1PFvb9hL/er9GajuraFGMWzd9TTk34zy/ZSQbtKkIDie4 EvC705DrQwiXMPA/rAIo+ScbNWj8E1CDfJ+l0ceh/gR3nrg/kAqk11idBO2b+ryrvllh BLToHZAUIvYjmO7NlIKI0keD2Tg4e4RDADynDPEj7glzHjITcnOeHgmz/tIqpwlkCOag 8rkohYqzDYPHvSepdkaXZLvq1OGbcbTfd4PUZCkkJEEb0qGcxUV1vKgZUxatQsZ8vFq7 tnpg== X-Gm-Message-State: AOAM530Sz3C6ttl4bNA1pqbj+SidGPl2xD1PU7Ja3sxw1yTQokx6ApyN YwmqbSL/Kcfr6YwjbPdpA6rKSPlg6ck/iaIGkDw= X-Google-Smtp-Source: ABdhPJyJl9dGXMkxI66zEb8yk3R6YLQWnw2RzVz/zsaxQX5u30rYlEVjv6QItTjdA2CirMWjhvaG/UDGROmXFMUglk8= X-Received: by 2002:a63:cf09:0:b0:372:d564:8024 with SMTP id j9-20020a63cf09000000b00372d5648024mr8813888pgg.251.1647011211871; Fri, 11 Mar 2022 07:06:51 -0800 (PST) MIME-Version: 1.0 References: In-Reply-To: From: Amit Langote Date: Sat, 12 Mar 2022 00:06:34 +0900 Message-ID: Subject: Re: generic plans and "initial" pruning To: Robert Haas Cc: PostgreSQL-development , "David Rowley *EXTERN*" Content-Type: text/plain; charset="UTF-8" List-Id: List-Help: List-Subscribe: List-Post: List-Owner: List-Archive: Archived-At: Precedence: bulk On Fri, Mar 11, 2022 at 11:35 PM Amit Langote wrote: > Attached is v5, now broken into 3 patches: > > 0001: Some refactoring of runtime pruning code > 0002: Add a plan_tree_walker > 0003: Teach AcquireExecutorLocks to skip locking pruned relations Repeated the performance tests described in the 1st email of this thread: HEAD: (copied from the 1st email) 32 tps = 20561.776403 (without initial connection time) 64 tps = 12553.131423 (without initial connection time) 128 tps = 13330.365696 (without initial connection time) 256 tps = 8605.723120 (without initial connection time) 512 tps = 4435.951139 (without initial connection time) 1024 tps = 2346.902973 (without initial connection time) 2048 tps = 1334.680971 (without initial connection time) Patched v1: (copied from the 1st email) 32 tps = 27554.156077 (without initial connection time) 64 tps = 27531.161310 (without initial connection time) 128 tps = 27138.305677 (without initial connection time) 256 tps = 25825.467724 (without initial connection time) 512 tps = 19864.386305 (without initial connection time) 1024 tps = 18742.668944 (without initial connection time) 2048 tps = 16312.412704 (without initial connection time) Patched v5: 32 tps = 28204.197738 (without initial connection time) 64 tps = 26795.385318 (without initial connection time) 128 tps = 26387.920550 (without initial connection time) 256 tps = 25601.141556 (without initial connection time) 512 tps = 19911.947502 (without initial connection time) 1024 tps = 20158.692952 (without initial connection time) 2048 tps = 16180.195463 (without initial connection time) Good to see that these rewrites haven't really hurt the numbers much, which makes sense because the rewrites have really been about putting the code in the right place. BTW, these are the numbers for the same benchmark repeated with plan_cache_mode = auto, which causes a custom plan to be chosen for every execution and so unaffected by this patch. 32 tps = 13359.225082 (without initial connection time) 64 tps = 15760.533280 (without initial connection time) 128 tps = 15825.734482 (without initial connection time) 256 tps = 15017.693905 (without initial connection time) 512 tps = 13479.973395 (without initial connection time) 1024 tps = 13200.444397 (without initial connection time) 2048 tps = 12884.645475 (without initial connection time) Comparing them to numbers when using force_generic_plan shows that making the generic plans faster is indeed worthwhile. -- Amit Langote EDB: http://www.enterprisedb.com