内容简介:Go in memory cache using gRPC to generate API. Functionalities includeOnce you've cloned this repo, run these commands in this directory:
In memory cache, using gRPC
Contents
About
Go in memory cache using gRPC to generate API. Functionalities include
- Adding/Replacing key/value
- Getting value using a key
- Getting all keys
- Deleting a particular key
- Deleting all keys
- Concurrency safe and on client side calls can be made using goroutines
Requirements
Getting Started
Once you've cloned this repo, run these commands in this directory:
# Only needed the first time:
$ make build
# Then run to start server
$ ./server-cache --help
Usage of ./server-cache:
-addr string
Address on which you want to run server (default ":5001")
-cln int
Cleanup interval duration of expired cache is 5 min (default 5)
-exp int
Default expiration duration of cache is 10 min (default 10)
# To use client
$ ./client-cache --help
Usage of ./client-cache:
-addr string
Address on which you want to run server (default ":5001")
Usage
You can run server in 2 ways either using local setup or docker.
Local
- Start your server
./server-cacheormake server -
./server-cache -addr=":5001"to run server on port5001
Docker
make docker make dockerServer
After running the server, start your client ./client-cache or make client in a different terminal
-
./client-cache -addr=":5001"is server is running running on port5001
API
Proto syntax proto3 is used. You can find the proto file here
Add
This is used to add key/value to the cache
func (c Cache) Add(ctx context.Context, item *api.Item) (*api.Item, error)
Get
This is used to get key value pair for a particular key
func (c Cache) Get(ctx context.Context, args *api.GetKey) (*api.Item, error)
GetAllItems
Used to get all key value pairs
func (c Cache) GetAllItems(ctx context.Context, in *empty.Empty) (*api.AllItems, error)
DeleteKey
Used to delete item by a particular key from the cache
func (c Cache) DeleteKey(ctx context.Context, args *api.GetKey) (*api.Success, error)
DeleteAll
Used to clear the whole cache
func (c Cache) DeleteAll(ctx context.Context, in *empty.Empty) (*api.Success, error)
Testing
After running make build just run make test to run the tests. It has coverage of 91.2%
go test api/server/* -v -cover -race === RUN TestAdd --- PASS: TestAdd (0.04s) === RUN TestGet --- PASS: TestGet (0.03s) === RUN TestGetAllItems --- PASS: TestGetAllItems (0.01s) === RUN TestDeleteKey --- PASS: TestDeleteKey (0.01s) === RUN TestDeleteAll --- PASS: TestDeleteAll (0.01s) === RUN TestGetDeletedKey --- PASS: TestGetDeletedKey (0.01s) === RUN TestDeleteKeyByExpiration --- PASS: TestDeleteKeyByExpiration (2.01s) PASS coverage: 91.2% of statements ok command-line-arguments 3.617s coverage: 91.2% of statements
Example
Please refer to examples directory for more information
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
劫持
玛丽•K. 斯温格尔(Mari K. Swingle) / 邓思渊 / 中信出版集团股份有限公司 / 2018-5-1 / CNY 59.00
《劫持》是一本探讨人与科技的关系的书,基于一位心理学博士20年的临床经验及其作为神经认知科学研究者的脑—电研究成果。在这本面向大众的科普书中,作者以深入浅出的方式,探讨了手机、电脑等便携式数字设备及让人“永不下线”的互联网对现代人尤其是青少年大脑的影响,从神经认知科学和精神分析的角度,有力地证明了数字媒介与大脑和人类行为的关系,探讨了手机等如何对人的大脑进行劫持或操控,并给出了自己作为从业医师的实......一起来看看 《劫持》 这本书的介绍吧!