Skip to content

Apex is CLI that concurrently uploads files to the ScyllaDB cluster using gRPC streaming.

Notifications You must be signed in to change notification settings

sourikghosh/go-grpc-streaming-scylla

Repository files navigation

APEX

Apex is a multi-upload cli. Using Golang, gRPC-stream and ScyllaDB. It is using golang's concurrency primitives for multi-upload, gRPC stream to uplaod chunck-data of blob to server and stores the uploaded files in ScyllaDB, which is a distributed real-time big-data Database.

Installation

  • git clone git@github.com:sourikghosh/go-grpc-streaming-scylla.git
  • cd go-grpc-streaming-scylla
  • go mod downlaod
  • make server
  • make client

Usage

~
🚀 apex
Apex searchs all file/s in the input directory to concurrently upload them to scyllaDB.
It was a project to get familiarize with gRPC streams and scyllaDB.Apex takes two config --flag. For example:

If the apex server is not running on localhost:1500 you can change it with
        apex --addr localhost:8080

You can change the concurrency with
        apex --workerCount 6
Higher workerCount means higher concurrency
The default value is 6.

Usage:
  apex [command]

Available Commands:
  completion  generate the autocompletion script for the specified shell
  help        Help about any command
  upload      uplaods all file/s concurrently to scyllaDB

Flags:
  -a, --addr string       the server address (default "localhost:1500")
  -h, --help              help for apex
  -w, --workerCount int   no of concurrent worker count to upload files (default 6)

Use "apex [command] --help" for more information about a command.

About

Apex is CLI that concurrently uploads files to the ScyllaDB cluster using gRPC streaming.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published