Skip to content

luckypolaris/leaf-snowflake

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Leaf-snowflake

Last Modified: 2017-06-28

Introduction

Leaf-snowflake is a distributed,monotonic increase long-type integer ID maker.

Support nearly 1000+ leaf-snowflake servers to provide id services simultaneously.

Based on http://tech.meituan.com/MT_Leaf.html leaf-snowflake.

Steps:

  1. mvn package
  2. Set ${LEAF_HOME} environment variable
  3. Config leaf.yaml at ${LEAF_HOME}/conf
  4. Exec ${LEAF_HOME}/bin/start.sh
  5. Communicate to the RPC server and get the unique , monotonic increase ID like startClient() in /rpc/rpcClient.java shows,just for test!

Commond line tools

  1. List the content of a znode dir:

    /bin/leaf.py zktool list /leaf/server-forever

  2. Read the content of a znode:

    /bin/leaf.py zktool read /leaf/server-forever/172.21.0.190:2182-0000000008

Throughput capacity test

Cost 191 seconds with 200W absolutely monotonic increase Ids generated.

TPS: 1W+/sec for a single machine

Author

weizhenyi Github: https://github.com/weizhenyi

Getting help

Email: [email protected] QQ:632155186

About

A distributed ID maker

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 89.1%
  • Python 9.6%
  • Shell 1.3%