lua-resty-hyperloglog
is hyperloglog for openresty.
This library is still under early development and is still experimental.
http {
...
lua_shared_dict hll_count 10m;
init_by_lua_block {
local hll = require "resty.hyperloglog"
h = hll.new("hll_count", 12)
}
server {
listen 8080;
location / {
access_by_lua_block {
h:insert(ngx.var.uri)
}
...
}
location = /stats {
content_by_lua_block {
ngx.print("count:", h:count())
ngx.exit(ngx.HTTP_OK)
}
}
}
}
syntax: h, err = hll.new(name, log2m)
Create a hyperloglog object with 2^log2m bucket. Returns nil
on error.
syntax: h:insert(str)
Insert a string to hyperloglog object.
syntax: c = h:count()
Returns the cardinality of the hyperloglog object.
syntax: ok, err = h:merge(h2)
Merge another hyperloglog object(h2) into h. Returns false
on error.
syntax: h:close()
Close the hyperloglog object.
wenqiang li(vislee)
This module is licensed under the BSD License.
Copyright (C) by vislee.
All rights reserved.