Skip to content

sgkandale/ShareLock

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Distributed Locking Service

This repository provides a distributed locking service implemented over HTTP and gRPC interfaces, enabling distributed systems to synchronize access to shared resources across multiple nodes or instances. The service offers mechanisms to acquire and release locks, ensuring mutual exclusion in a distributed environment, in a serialised fashion.

Table of Contents

  1. Overview
  2. Features
  3. Architecture
  4. Getting Started
  5. Contributing
  6. License

Overview

This distributed locking service allows clients to request locks for resources over an HTTP and gRPC interface. It handles locking in a fault-tolerant and scalable way, ensuring that only one client can hold a lock on a given resource at any time. All the incoming requests for the same key are processed serially to ensure the order of acquisition. Supports automatic lock expiry after a deadline in case of client crash.

The service is ideal for use cases in microservices architectures, cloud-based applications, or systems that require synchronization and exclusive access to resources.

Features

  • Distributed Locking: Supports acquiring and releasing locks across multiple nodes in a distributed system.
  • HTTP Interface: Simple HTTP interface to quickly get started.
  • gRPC Interface: Fast, efficient communication via gRPC for high-performance locking.
  • Timeouts and Retry Logic: Configurable lock timeouts and retries for handling transient issues.
  • Automatic Expiry: Locks automatically expire after a configurable time to prevent deadlocks in case of client crashes.

Architecture

The service provides HTTP and gRPC for communication. The architecture is designed to be fault-tolerant and provides automatic lock expiration to avoid deadlocks.

Key Components

  1. HTTP and gRPC Server: Provides the API for acquiring and releasing locks.
  2. Lock Manager: Handles the internal logic of managing lock state (acquire, release, expire).

Getting Started

Prerequisites

Before you begin, ensure you have the following installed:

  1. Go (v1.23.2 or higher)
  2. Protocol Buffers (protoc) compiler
  3. Protobuf plugins like protoc-gen-go and protoc-gen-go-grpc

Installation

  1. Clone the repository:
git clone https://github.com/sgkandale/ShareLock.git
cd ShareLock
  1. Install Go dependencies:
go mod tidy
  1. Generate the gRPC code from the .proto files:
./generatePB.sh
  1. Cross check config.yaml file one for all the values

Running the Service

  1. Build the binary
go build ./cmd/sharelock
  1. Start the server
./sharelock

Using the Service

Once the server is running, you can use the client to interact with the locking service. For examples on how to use the service, refer the examples directory inside cmd

API Reference

Payload structures are in sharelock.proto file. Refer the same to build your own gRPC client or to use over HTTP.

Contributing

Contributions to improve this project are always welcomed. If you'd like to help, please fork the repository and create a pull request. Here are some ways you can contribute:

  • Bug fixes and optimizations
  • Enhancing the documentation
  • Implementing new features or lock types

Please follow the standard GitHub workflow:

  1. Fork the repository.
  2. Create a new branch for your feature/fix.
  3. Make your changes.
  4. Submit a pull request with a clear description of your changes.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Releases

No releases published

Packages

No packages published