Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zalopay-oss/zpd
A simple SQL-like database built on top of Key-Value storages
https://github.com/zalopay-oss/zpd
golang grpc sql
Last synced: about 2 months ago
JSON representation
A simple SQL-like database built on top of Key-Value storages
- Host: GitHub
- URL: https://github.com/zalopay-oss/zpd
- Owner: zalopay-oss
- License: apache-2.0
- Created: 2019-11-28T02:36:22.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-07-06T01:40:53.000Z (over 1 year ago)
- Last Synced: 2024-05-07T18:14:02.265Z (8 months ago)
- Topics: golang, grpc, sql
- Language: Go
- Size: 18 MB
- Stars: 22
- Watchers: 4
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ZPD
![Build Status](https://img.shields.io/badge/build-passing-brightgreen)
![Coverage Status](https://img.shields.io/badge/coverage-90%25-green)
[![version](https://img.shields.io/badge/repo%20status-active-brightgreen)](https://github.com/zalopay-oss/zpd)
[![version](https://img.shields.io/badge/contributors-2-blueviolet)](#tham-gia-phát-triển)
[![version](https://img.shields.io/badge/open%20issues-0-red)](https://github.com/zalopay-oss/zpd/issues)
- [ZPD](#zpd)
- [Overview](#overview)
- [Architecture](#architecture)
- [Requirement](#requirement)
- [Install](#install)
- [Build](#build)
- [Run](#run)
- [Test](#test)
- [Document](#document)
- [Contribution](#contribution)
- [Acknowledgments](#acknowledgments)
- [License](#license)## Overview
ZPD (or ZaloPay Database) is a probationary challenge performed at ZaloPay. It's an `experiment` to gain deep knowledge about handling simple SQL queries and how to glue them with a key-value storage.
ZPD is implemented using Golang as a gRPC service and built on top of following frameworks:
- [Consul](https://www.consul.io/) for leader elections.
- [TiKV](https://github.com/tikv/tikv) as the main key-value storage
## Architecture
The architecture of the ZPD:
Including layers:
- Connection layer
- Parser layer
- Core layer:
- Executor
- Consul Agent
- Bridge API
- Data access layer
- Storage:
- TiKV client layerSee the architecture of ZPD [here](./docs/architecture.md).
## Requirement
- Golang version >= 1.12
- gRPC
- Docker version >= 17.06 and Docker Compose
- Locust## Install
- Install [Golang](https://golang.org/doc/install)
- Install [gRPC](https://grpc.io/docs/quickstart/go/)
- Install [Docker](https://docs.docker.com/get-started/)
- Install [Locust](https://locust.io/)
- Install TiKV and PD using [Docker Compose](https://tikv.org/docs/3.0/tasks/deploy/docker-compose/)
- Install Consul bằng [Docker](https://hub.docker.com/_/consul).## Build
Clone this project:
```sh
# Clone
$ git clone https://gitlab.zalopay.vn/zpx-core-team/tidb-internals.git
```## Run
ZPD, PD, TiKV, Consul are all built with Docker compose. Just go to the docker-compose folder and run docker-compose up.
```sh
# go to the folder docker-compose
$ cd ./tidb-layer/source/docker-compose# Run docker-compose
$ docker-compose up
```## Test
Must run ZPD as the section above, then run tests of the APIs:
```sh
# go to cmd/client
$ cd ./tidb-layer/source/cmd/client# run tests
$ go test -run TestClientExecuteCreateDB
```- You can write more tests into `client_test.go` like the available format.
## Document
Read more document about ZPD:
- [Specific description](./docs/specific-description.md)
- [Sequence diagram](./docs/sequence-diagram.md)
- [Architecture ZPD](./docs/architecture.md)
- [Overview ZPD](docs/overview-ZPD.md)Read blogs:
- [SQL Planning: Parser & Optimizer](https://medium.com/zalopay-engineering/sql-planning-parser-optimizer-ee118a9705ed)
- [SWIM: Protocol of friends](https://medium.com/zalopay-engineering/https-medium-com-zalopay-engineering-swim-giao-thuc-cua-nhung-nguoi-ban-8df88e68d816)
- [Building a SQL Database using key-value storage](https://medium.com/zalopay-engineering/xay-dung-sql-service-su-dung-tikv-5c5adb63c885)## Contribution
This project was built by [AJPham](https://github.com/phamtai97) and [Alex Nguyen](https://github.com/quocanh1897) under the guidance from [Anh Le (Andy)](https://github.com/anhldbk).
## Acknowledgments
- This project used open source:
- [xwb1989/sqlparser](https://github.com/xwb1989/sqlparser): a SQL parser.
- [Consul](https://github.com/hashicorp/consul): handle leader election.
- [PingCap](https://github.com/pingcap): support PD and TiKV parts.## License
See the [LICENSE](./LICENSE) file for license rights and limitations.