Skip to content

Commit

Permalink
perf: speed up xqueue.upgrade() for large spaces
Browse files Browse the repository at this point in the history
  • Loading branch information
ochaton committed Aug 7, 2024
1 parent bcadffd commit 77d5121
Show file tree
Hide file tree
Showing 6 changed files with 113 additions and 20 deletions.
4 changes: 4 additions & 0 deletions .env
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
BENCHER_PROJECT=xqueue
BENCHER_ADAPTER=json
BENCHER_TESTBED=localhost
LUABENCH_USE_BMF=true
27 changes: 27 additions & 0 deletions .github/workflows/benchmark.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
name: Benchmarking code

on:
- push

jobs:
run-unit-benchmarks:
runs-on: ubuntu-latest
strategy:
matrix:
version: ["2.10.6", "2.11.0", "2.11.2"]
steps:
- uses: actions/checkout@v4
- uses: tarantool/setup-tarantool@v3
with:
tarantool-version: '${{matrix.version}}'
- name: install argparse
run: tarantoolctl rocks install argparse
- name: install luabench
run: tarantoolctl rocks --server=https://moonlibs.org install luabench 0.3.0
- name: run benchmarks
env:
LUABENCH_USE_BMF: false
LUABENCH_TIMEOUT: 60
LUABENCH_DURATION: '10s'
run: |
.rocks/bin/luabench
2 changes: 2 additions & 0 deletions .luabench
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
jit = 'on'
duration = '10s'
2 changes: 1 addition & 1 deletion benchmarks/001_put_take_bench.lua
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ xqueue.upgrade(box.space.queue, {

local queue = box.space.queue --[[@as xqueue.space]]
lb.before_all(function() queue:truncate() end)
lb.after_all(function() queue:truncate() box.snapshot() end)
lb.after_all(function() box.space.queue:truncate() box.snapshot() end)

local M = {}

Expand Down
62 changes: 62 additions & 0 deletions benchmarks/002_initial_stat_bench.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
local lb = require 'luabench'
local fiber = require 'fiber'
local fun = require 'fun'

local M = {}

local STATUS = { 'R', 'T', 'W', 'B', 'Z', 'D' }

lb.before_all(function()
box.cfg{ memtx_memory = 2^30 }

box.schema.space.create('q1', {
if_not_exists = true,
format = {
{ name = 'id', type = 'unsigned' },
{ name = 'status', type = 'string' },
},
})

box.space.q1:create_index('primary', { parts = {'id'}, if_not_exists = true })
box.space.q1:create_index('xq', { parts = {'status', 'id'}, if_not_exists = true })

if fiber.extend_slice then
fiber.extend_slice({ err = 3600, warn = 3600 })
end

box.begin()
local tab = {}
for no = 1, 4e6 do
tab[1], tab[2] = no, STATUS[math.random(#STATUS)]
box.space.q1:replace(tab)
end
box.commit()
end)

lb.after_all(function()
box.space.q1:drop()
box.snapshot()
end)

function M.bench_iterate_all(b)
local limit = b.N
local scanned = 0
local stats = {}
for _, t in box.space.q1:pairs({}, { iterator = "ALL" }) do
stats[t.status] = (stats[t.status] or 0ULL) + 1
scanned = scanned + 1
if limit == scanned then break end
end
b.N = scanned
end

function M.bench_count(b)
local total = 0
for _, s in pairs(STATUS) do
total = total + box.space.q1.index.xq:count(s)
if b.N < total then break end
end
b.N = total
end

return M
36 changes: 17 additions & 19 deletions xqueue.lua
Original file line number Diff line number Diff line change
Expand Up @@ -215,6 +215,15 @@ local function _table2tuple ( qformat )
return dostring(fun)
end

local pretty_st = {
R = "Ready",
T = "Taken",
W = "Waiting",
B = "Buried",
Z = "Zombie",
D = "Done",
}

---@class xqueue.space
local methods = {}

Expand Down Expand Up @@ -583,19 +592,17 @@ function M.upgrade(space,opts,depth)
tube = stat_tube;
}
if self.fields.tube then
for _, t in space:pairs(nil, { iterator = box.index.ALL }) do
local s = t[self.fields.status]
self._stat.counts[s] = (self._stat.counts[s] or 0LL) + 1

local tube = t[self.fields.tube]
if stat_tube[tube] then
stat_tube[tube].counts[s] = (stat_tube[tube].counts[s] or 0LL) + 1
for status in pairs(pretty_st) do
self._stat.counts[status] = 0LL+self.index:count(status)
end
for tube in pairs(stat_tube) do
for status in pairs(pretty_st) do
stat_tube[tube].counts[status] = 0LL+self.tube_index:count({ tube, status })
end
end
else
for _, t in space:pairs(nil, { iterator = box.index.ALL }) do
local s = t[self.fields.status]
self._stat.counts[s] = (self._stat.counts[s] or 0LL) + 1
for status in pairs(pretty_st) do
self._stat.counts[status] = 0LL+self.index:count(status)
end
end
else
Expand Down Expand Up @@ -1748,15 +1755,6 @@ function methods:truncate()
return ret
end

local pretty_st = {
R = "Ready",
T = "Taken",
W = "Waiting",
B = "Buried",
Z = "Zombie",
D = "Done",
}

local shortmap = { __serialize = 'map' }

---@param pretty? boolean
Expand Down

0 comments on commit 77d5121

Please sign in to comment.