본문으로 건너뛰기
버전: 0.0.3

UDF Guide

User Defined Functions (UDFs) are Lua scripts that execute on the Aerospike server node owning the record.

API

# Register
client.udf_put("my_udf.lua")

# Execute on a record
result = client.apply(key, "module_name", "function_name", [arg1, arg2])

# Remove
client.udf_remove("module_name")

Example: Counter UDF

counter.lua

function increment(rec, bin_name, amount)
if aerospike:exists(rec) then
rec[bin_name] = rec[bin_name] + amount
aerospike:update(rec)
else
rec[bin_name] = amount
aerospike:create(rec)
end
return rec[bin_name]
end

Python

client.udf_put("counter.lua")

key = ("test", "demo", "counter1")
result = client.apply(key, "counter", "increment", ["count", 5]) # 5
result = client.apply(key, "counter", "increment", ["count", 3]) # 8

client.udf_remove("counter")

Async

await client.udf_put("counter.lua")
result = await client.apply(key, "counter", "increment", ["count", 1])
await client.udf_remove("counter")

Notes

  • Lua is the only supported UDF language
  • UDF changes take a few seconds to propagate to all nodes
  • Keep UDFs simple for best performance