• Stars
    star
    201
  • Rank 194,491 (Top 4 %)
  • Language
    Perl
  • License
    MIT License
  • Created over 8 years ago
  • Updated almost 5 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Fast and dependency-free UUID library for LuaJIT/ngx_lua

lua-resty-jit-uuid

Module Version Build Status Coverage Status

A pure LuaJIT (no dependencies) UUID library tuned for performance.

Table of Contents

Motivation

This module is aimed at being a free of dependencies, performant and complete UUID library for LuaJIT and ngx_lua.

Unlike FFI and C bindings, it does not depend on libuuid being available in your system. On top of that, it performs better than most (all?) of the generators it was benchmarked against, FFI bindings included.

Finally, it provides additional features such as UUID v3/v4/v5 generation and UUID validation.

See the Benchmarks section for comparisons between other UUID libraries for Lua/LuaJIT.

Back to TOC

Usage

LuaJIT:

local uuid = require 'resty.jit-uuid'

uuid.seed()        ---> automatic seeding with os.time(), LuaSocket, or ngx.time()

uuid()             ---> v4 UUID (random)
uuid.generate_v4() ---> v4 UUID

uuid.generate_v3() ---> v3 UUID (name-based with MD5)
uuid.generate_v5() ---> v5 UUID (name-based with SHA-1)

uuid.is_valid()    ---> true/false (automatic JIT PCRE or Lua patterns)

OpenResty:

http {
    init_worker_by_lua_block {
        local uuid = require 'resty.jit-uuid'
        uuid.seed() -- very important!
    }

    server {
        location / {
            content_by_lua_block {
                local uuid = require 'resty.jit-uuid'
                ngx.say(uuid())
            }
        }
    }
}

Note: when generating v4 (random) UUIDs in ngx_lua, it is very important that you seed this module in the init_worker phase. If you do not, your workers will generate identical UUID sequences, which could lead to serious issues in your application. The seeding requirement also applies in uses outside of ngx_lua, although seeding is less delicate in such cases. Additionally, you should be weary about the usage of the lua_code_cache directive: if Lua code cache is disabled, all sequences of UUIDs generated during subsequent requests will be identical, unless this module is seeded for every request. Just like disabling Lua code cache, such behavior would be considered an ngx_lua anti-pattern and you should avoid it.

Back to TOC

Installation

This module can be installed through Luarocks:

$ luarocks install lua-resty-jit-uuid

Or via opm:

$ opm get thibaultcha/lua-resty-jit-uuid

Or can be manually copied in your LUA_PATH.

Back to TOC

Documentation

Documentation is available online at http://thibaultcha.github.io/lua-resty-jit-uuid/.

Back to TOC

Benchmarks

This module has been carefully benchmarked on each step of its implementation to ensure the best performance for OpenResty and plain LuaJIT. For example, UUID validation will use JIT PCRE over Lua patterns when possible.

The bench.lua file provides benchmarks of UUID generation for several popular UUID libraries.

Run make bench to run them:

LuaJIT 2.1.0-beta1 with 1e+06 UUIDs
UUID v4 (random) generation
1. resty-jit-uuid   took:   0.064228s    0%
2. FFI binding      took:   0.093374s   +45%
3. C binding        took:   0.220542s   +243%
4. Pure Lua         took:   2.051905s   +3094%

UUID v3 (name-based and MD5) generation if supported
1. resty-jit-uuid   took:   1.306127s

UUID v5 (name-based and SHA-1) generation if supported
1. resty-jit-uuid   took:   4.834929s

UUID validation if supported (set of 70% valid, 30% invalid)
1. resty-jit-uuid (JIT PCRE enabled)    took:   0.223060s
2. FFI binding                          took:   0.256580s
3. resty-jit-uuid (Lua patterns)        took:   0.444174s

Note: UUID validation performance in ngx_lua (JIT PCRE) can be greatly improved by enabling lua-resty-core.

Back to TOC

Contributions

Suggestions improving this module's or the benchmarks' performance (of any benchmarked library) are particularly appreciated.

Back to TOC

License

Work licensed under the MIT License.

Back to TOC

More Repositories

1

TCBlobDownload

Concurrent large files downloads for iOS
Objective-C
923
star
2

lua-resty-mlcache

Layered caching library for OpenResty
Perl
370
star
3

TCBlobDownloadSwift

Powerful file downloads in Swift
Swift
152
star
4

lua-cassandra

Pure Lua driver for Apache Cassandra
Lua
99
star
5

lua-resty-socket

Automatic LuaSocket/cosockets compatibility module
Perl
36
star
6

TCCopyableLabel

A copyable UILabel subclass
Objective-C
34
star
7

lua-resty-busted

Test OpenResty scripts with busted
Lua
32
star
8

lua-argon2-ffi

LuaJIT FFI binding for the Argon2 password hashing algorithm
Lua
20
star
9

lua-argon2

Lua C binding for the Argon2 password hashing algorithm
C
20
star
10

Equiprose

A static website and blog generator in Node.js
JavaScript
12
star
11

MonteCarlo

A single and multithread Java implementation of the Monte Carlo algorithm.
Java
10
star
12

TCQueuePlayer

A wrapper class with controls for AVQueuePlayer
Objective-C
9
star
13

DTC3DViewAnimation

A nice iOS animation
Objective-C
7
star
14

lua-resty-multipart

Multipart parsing library for OpenResty
Lua
7
star
15

node-recursive-search

Recursively search a file in given directory
CoffeeScript
5
star
16

setup-openresty

JavaScript
3
star
17

TCProgressView

A customizable progress view for iOS
Objective-C
3
star
18

Counter

Simple Node.js and Socket.IO example.
JavaScript
2
star
19

kong-tests-compose

Docker compose for Kong's integration test suite
Shell
2
star
20

ECE_hadoop_mahout

Classification of tweets using Mahout
Java
1
star
21

Miranda

The original Equiprose
JavaScript
1
star
22

chasum.net

Personal website
HTML
1
star
23

lapis-syntax

A profound, purple based, dark colored theme for Atom.
CSS
1
star
24

macos-unused-files

Bash script to find unused files in a given period of time
Shell
1
star
25

homebrew-kong

Homebrew tap for Kong
Ruby
1
star
26

TweetStats

Assignment for the Software Quality course at ECE Paris 2013
Java
1
star