From 3f30dcbeddfb45d5451c428b88ea5516f1b39ba0 Mon Sep 17 00:00:00 2001 From: Xiaochen Wang Date: Fri, 27 Dec 2024 10:41:24 +0800 Subject: [PATCH] perf(router): load service with route.ws_id while building routers --- kong/runloop/handler.lua | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/kong/runloop/handler.lua b/kong/runloop/handler.lua index 54eb8cf0ba3..aa948b202e2 100644 --- a/kong/runloop/handler.lua +++ b/kong/runloop/handler.lua @@ -256,8 +256,9 @@ local function should_process_route(route) end -local function load_service_from_db(service_pk) - local service, err = kong.db.services:select(service_pk, GLOBAL_QUERY_OPTS) +local function load_service_from_db(service_pk, ws_id) + local options = ws_id and { workspace = ws_id, show_ws_id = true } + local service, err = kong.db.services:select(service_pk, options) if service == nil then -- the third value means "do not cache" return nil, err, -1 @@ -299,20 +300,21 @@ local function get_service_for_route(db, route, services_init_cache) end local err + local ws_id = route.ws_id -- kong.core_cache is available, not in init phase if kong.core_cache and db.strategy ~= "off" then local cache_key = db.services:cache_key(service_pk.id, nil, nil, nil, nil, - route.ws_id) + ws_id) service, err = kong.core_cache:get(cache_key, TTL_ZERO, - load_service_from_db, service_pk) + load_service_from_db, service_pk, ws_id) else -- dbless or init phase, kong.core_cache not needed/available -- A new service/route has been inserted while the initial route -- was being created, on init (perhaps by a different Kong node). -- Load the service individually and update services_init_cache with it - service, err = load_service_from_db(service_pk) + service, err = load_service_from_db(service_pk, ws_id) services_init_cache[id] = service end