Skip to content

Commit

Permalink
perf(lmdb): remove the key with global workspace id *
Browse files Browse the repository at this point in the history
  • Loading branch information
chobits committed Dec 17, 2024
1 parent fad17ba commit 372553f
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 35 deletions.
62 changes: 35 additions & 27 deletions kong/db/declarative/import.lua
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ local function workspace_id(schema, options)
return get_workspace_id()
end

-- global query, like routes:each(page_size, GLOBAL_QUERY_OPTS)
if options.workspace == null then
return GLOBAL_WORKSPACE_TAG
end
Expand Down Expand Up @@ -243,26 +244,39 @@ local function find_ws(entities, name)
end


-- unique key
local function unique_field_key(schema_name, ws_id, field, value)
return string_format("%s|%s|%s|%s", schema_name, ws_id, field, sha256_hex(value))
return string_format("U|%s|%s|%s|%s", schema_name, field, ws_id, sha256_hex(value))
end


-- foreign key
local function foreign_field_key_prefix(schema_name, ws_id, field, foreign_id)
return string_format("%s|%s|%s|%s|", schema_name, ws_id, field, foreign_id)
if ws_id == GLOBAL_WORKSPACE_TAG then
return string_format("F|%s|%s|%s|", schema_name, field, foreign_id)
end

return string_format("F|%s|%s|%s|%s|", schema_name, field, foreign_id, ws_id)
end


local function foreign_field_key(schema_name, ws_id, field, foreign_id, pk)
assert(ws_id ~= GLOBAL_WORKSPACE_TAG)
return foreign_field_key_prefix(schema_name, ws_id, field, foreign_id) .. pk
end

-- item key
local function item_key_prefix(schema_name, ws_id)
return string_format("%s|%s|*|", schema_name, ws_id)
if ws_id == GLOBAL_WORKSPACE_TAG then
return string_format("I|%s|", schema_name)
end

return string_format("I|%s|%s|", schema_name, ws_id)
end


local function item_key(schema_name, ws_id, pk_str)
assert(ws_id ~= GLOBAL_WORKSPACE_TAG)
return item_key_prefix(schema_name, ws_id) .. pk_str
end

Expand Down Expand Up @@ -307,10 +321,6 @@ local function _set_entity_for_txn(t, entity_name, item, options, is_delete)
-- store serialized entity into lmdb
t:set(itm_key, itm_value)

-- for global query
local global_key = item_key(entity_name, GLOBAL_WORKSPACE_TAG, pk)
t:set(global_key, idx_value)

-- select_by_cache_key
if schema.cache_key then
local cache_key = dao:cache_key(item)
Expand Down Expand Up @@ -347,12 +357,9 @@ local function _set_entity_for_txn(t, entity_name, item, options, is_delete)
value_str = pk_string(kong.db[fdata_reference].schema, value)
end

for _, wid in ipairs {field_ws_id, GLOBAL_WORKSPACE_TAG} do
local key = unique_field_key(entity_name, wid, fname, value_str or value)

-- store item_key or nil into lmdb
t:set(key, idx_value)
end
local key = unique_field_key(entity_name, field_ws_id, fname, value_str or value)
-- store item_key or nil into lmdb
t:set(key, idx_value)
end

if is_foreign then
Expand All @@ -361,12 +368,9 @@ local function _set_entity_for_txn(t, entity_name, item, options, is_delete)

value_str = pk_string(kong.db[fdata_reference].schema, value)

for _, wid in ipairs {field_ws_id, GLOBAL_WORKSPACE_TAG} do
local key = foreign_field_key(entity_name, wid, fname, value_str, pk)

-- store item_key or nil into lmdb
t:set(key, idx_value)
end
local key = foreign_field_key(entity_name, field_ws_id, fname, value_str, pk)
-- store item_key or nil into lmdb
t:set(key, idx_value)
end

::continue::
Expand All @@ -380,18 +384,22 @@ end
-- the provided LMDB txn object, this operation is only safe
-- is the entity does not already exist inside the LMDB database
--
-- The actual item key is: <entity_name>|<ws_id>|*|<pk_string>
-- The actual item key is: I|<entity_name>|<ws_id>|<pk_string>
--
-- This function sets the following key-value pairs:
--
-- This function sets the following:
-- key: I|<entity_name>|<ws_id>|<pk_string>
-- value: serialized item
--
-- * <entity_name>|<ws_id>|*|<pk_string> => serialized item
-- * <entity_name>|*|*|<pk_string> => actual item key
-- key: U|<entity_name>|<unique_field_name>|<ws_id>|sha256(field_value)
-- value: actual item key
--
-- * <entity_name>|<ws_id>|<unique_field_name>|sha256(field_value) => actual item key
-- * <entity_name>|*|<unique_field_name>|sha256(field_value) => actual item key
-- key: F|<entity_name>|<foreign_field_name>|<foreign_key>|<ws_id>|<pk_string>
-- value: actual item key
--
-- * <entity_name>|<ws_id>|<foreign_field_name>|<foreign_key>|<pk_string> => actual item key
-- * <entity_name>|*|<foreign_field_name>|<foreign_key>|<pk_string> => actual item key
-- The format of the key string follows the sequence of the construction order:
-- `item type > entity name > specific item info > workspace id > item uuid`
-- This order makes it easier to query all entities using API lmdb_prefix.page().
--
-- DO NOT touch `item`, or else the entity will be changed
local function insert_entity_for_txn(t, entity_name, item, options)
Expand Down
28 changes: 20 additions & 8 deletions kong/db/strategies/off/init.lua
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ local item_key_prefix = declarative.item_key_prefix
local workspace_id = declarative.workspace_id
local foreign_field_key_prefix = declarative.foreign_field_key_prefix


local PROCESS_AUTO_FIELDS_OPTS = {
no_defaults = true,
show_ws_id = true,
Expand All @@ -38,11 +37,6 @@ _mt.__index = _mt
local UNINIT_WORKSPACE_ID = "00000000-0000-0000-0000-000000000000"


local function need_follow(ws_id)
return ws_id == "*"
end


local function get_default_workspace()
if kong.default_workspace == UNINIT_WORKSPACE_ID then
local res = kong.db.workspaces:select_by_name("default")
Expand Down Expand Up @@ -324,7 +318,7 @@ local function page(self, size, offset, options)
return page_for_tags(self, size, offset, options)
end

return page_for_prefix(self, prefix, size, offset, options, need_follow(ws_id))
return page_for_prefix(self, prefix, size, offset, options)
end


Expand All @@ -333,8 +327,26 @@ local function select(self, pk, options)
local schema = self.schema
local ws_id = workspace_id(schema, options)
local pk = pk_string(schema, pk)

-- if no specific ws_id is provided, we nedd to search all workspace ids
if ws_id == "*" then
for workspace, err in kong.db.workspaces:each() do
if err then
return nil, err
end

local key = item_key(schema.name, workspace.id, pk)
local entity = select_by_key(schema, key)
if entity then
return entity
end
end

return nil, "not found"
end

local key = item_key(schema.name, ws_id, pk)
return select_by_key(schema, key, need_follow(ws_id))
return select_by_key(schema, key)
end


Expand Down

0 comments on commit 372553f

Please sign in to comment.