Skip to content

Latest commit

 

History

History
89 lines (56 loc) · 7.07 KB

README.md

File metadata and controls

89 lines (56 loc) · 7.07 KB

Technology showcase: microservices, docker compose, event-driven architecture with RabbitMQ, REST WebApi and my implimentation of lock-free hash table as a in-memory cache, unit test, performance test.

How To Use

  • Environment: VS Code, .NET 8.0, Docker Desktop, RabbitMQ.Client 7.0
  • git clone https://github.com/daleiyang/LockFreeHashTable
  • Open local floder "LockFreeHashTable" with VS Code.
  • Start a Terminal and execute: " docker compose up --build ".

alt tag

  • If all goes well, you should see four microservices successfully built.

alt tag

  • If all goes well, you should see four microservices successfully deployed in Docker Desktop, and they should be able to maintain continuous communication with other microservices.

alt tag

Architecture

alt tag

$${\color{red}Step\ 4}$$ Load 3 million records into lock-free hash table. See Program.cs (line 3 to 4) and CAS.cs (line 104 to 130). For example: records[1] has properties "linkId = 2 clid = 2 sbp = 2" and value = "http://www.microsoft.com/abc.asp+1"

$${\color{red}Step\ 1}$$ The RPC Client continuously randomly selects "Get" or "Update" or "Delete" records[1] and sends requests to RabbitMQ. See RPCClient.cs (line 105 to 122)

$${\color{red}Step\ 2}$$ The callback function of the RPC Server obtains requests from RabbitMQ. See RPCServer.cs (line 36 to 37)

$${\color{red}Step\ 3}$$ The RPC Server calls corresponding REST Web Api. See RPCServer.cs (line 39 to 51)

$${\color{red}Step\ 5}$$ The Web API receives requests and performs operations on lock-free hash table. See Program.cs (line 10 to 44)

$${\color{red}Step\ 6}$$ The RPC Server receives response from Web Api. See RPCServer.cs (line 43 to 49)

$${\color{red}Step\ 7}$$ The RPC Server sends responses to RabbitMQ. See RPCServer.cs (line 62 to 65)

$${\color{red}Step\ 8}$$ The callback function of the RPC Client obtains responses from RabbitMQ. See RPCClient.cs (line 128)

Implementation of lock-free hash table

How To Use

alt tag

First, the conclusion

  • If you can combine the required keys into a 64-bit integer, using .Net's Concurrent Dictionary is a good option.

Background

  • Saw an article outlining the core data structures and algorithms used in the Shanghai Stock Exchange's securities trading system.
  • Since 2010, the Shanghai Stock Exchange has been using this core algorithm, and even in the face of the bull market in 2015 and the explosive growth of daily trading volume exceeding one trillion RMB, the system has continued to operate smoothly.
  • Implemented in C# as a candidate solution for MS's short link service.

Data Structure

  • The key value in the hash table is a 64-bit integer:
  • 54 bytes are reserved for the business logic to set the real key value;
  • 1 byte is used to mark whether the "writer" has obtained an exclusive lock;
  • 1 byte is used to mark whether this record has been deleted or not;
  • 8 byte are used to record the number of "readers".

alt tag

  • The combination of linkId, clcId, sbp in the figure above becomes the key value of the business logic, with a size of 54 bytes.
  • The code in the figure below is the process of generating a 54-byte key value based on business logic, refer to KeyIn54BitCASHashTable.cs [line 44 to 47].

alt tag

  • In securities trading system, the value is 64-bit integer instead of 256 byte array in my demo. For performance reasons, 64-bit integers are the most efficient choice.
  • According to the number of keys in the business logic, select a prime number as the length of the hash table so that the load factor is 0.5. This can control the average number of hash table lookups to 1.1.

Algorithms

  • The TrySet, TryGet and TryDelete functions in KeyIn54BitCASHashTable.cs [line 11 to 42] are the entry points.
  • KeyIn54BitCASHashTableBase.cs contains detailed comments explaining the principles of each bit operation and how to use the CAS API to read, add, update, and delete data.
  • The "do... . while" loop in the figure below is a typical CAS API usage.

alt tag

Performance Test Report [PerformanceReport.xlsx]

alt tag

Test Project