Overview
The Hank Go Client handles connecting to Hank in a reliable manner - there should be no visible effect if Rings or Servers go down. This is a reimplementation of the Hank Java client and is comparable featurewise.
In addition, since Hank uses rendevous hashing, the Client also handles figuring out which servers queries are routed to.
The Go Client has several options that govern retries, timeouts, number of connections and caching.
- NumConnectionsPerHost: Number of separate connections to a single host. The greater the number, the greater the number of simultaneous queries per host.
- MinConnectionsPerPartition: Minimum number of connections to minimum number of live replicas of each record. Guarentees client can serve all queries.
- TryLockTimeoutMs: Time to wait for a connection to a host before giving up. Connections might not be available if a specific server is experiencing high loads.
- EstablishConnectionTimeoutMs: Time before a connection attempt fails. Governs how long client takes to start up.
- EstablishConnectionRetries: Number of times to try to connect to a server. Governs how long client takes to start up.
- QueryTimeoutMs: Time before a query fails. Governs how client latency.
- ResponseCacheNumItems: Size of client cache.
- ResponseCacheExpiryTime: Time till cache item is expired.
A quick example of how to use the client can be seen here.
Connecting to Hank
The client connects to Hank as such:
- Connect to Zookeeper. Retrieve a list of Rings and servers for each ring, including how data is partitioned across servers.
- Attempt to establish NumConnectionsPerHost connections to all servers in all rings.
- Make sure MinConnectionsPerPartition connections to partitions are established. Hank data is partitioned across servers. This gives the client the minimum set of servers needed to serve all queries.
- If all above conditions are fulfilled, succeed. Otherwise fail loudly.
Note: Various connection options will affect how long the client takes to start up. For example, a high connection time out and/or retry number will significantly extend the time to success/failure.
Querying from Hank
Queries proceed as follows:
- As part of rendevous hashing, the client hashes the key being queried with. Using this hash, the client determines which Hank server contains the associated data.
- If caching is enabled, the client first looks to its cache, returning any found value not expired.
- If no value is found, or caching is not enabled. The client attempts to grab a connection to any server containing the value associated with the key. To minimize costs, the client prefers servers in the same AZ. There can be several queries executing simultaneously and a connection might not be available if there is high load on a particular server.
- If no connection is available, the query fails. Otherwise the client attempts to query the selected server, respecting time out settings.
Note: Various query options will affect query latency. The client is asynchronous and threadsafe - it is okay for multiple go routines to be using the same client at the same time.