Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Stencil is a schema registry that provides schema management and validation dynamically, efficiently, and reliably to ensure data compatibility across applications.

License

NotificationsYou must be signed in to change notification settings

raystack/stencil

Repository files navigation

TestReleaseLicenseVersion

Stencil is a schema registry that provides schema mangement and validation to ensure data compatibility across applications. It enables developers to create, manage and consume schemas dynamically, efficiently, and reliably, and provides a simple way to validate data against those schemas. Stencil support multiple formats including Protobuf, Avro and JSON.

Key Features

Discover why users choose Stencil as their main schema registry

  • Version history Stencil stores versioned history of proto descriptor file on specified namespace and name
  • Backward compatibility enforce backward compatibility check on upload by default
  • Flexbility ability to skip some of the backward compatibility checks while upload
  • Descriptor fetch ability to download proto descriptor files
  • Metadata provides metadata API to retrieve latest version number given a name and namespace
  • Clients in multiple languages Stencil provides clients in GO, Java, JS languages to interact with Stencil server and deserialize messages using dynamic schema

Documentation

Explore the following resources to get started with Stencil:

  • Documentation provides guidance on using stencil.
  • Server provides details on getting started with stencil server.
  • Clients provides reference to supported stencil clients.

Installation

Install Stencil on macOS, Windows, Linux, OpenBSD, FreeBSD, and on any machine.

Binary (Cross-platform)

Download the appropriate version for your platform fromreleases page. Once downloaded, the binary can be run from anywhere.You don’t need to install it into a global location. This works well for shared hosts and other systems where you don’t have a privileged account.Ideally, you should install it somewhere in your PATH for easy use./usr/local/bin is the most probable location.

MacOS

stencil is available via a Homebrew Tap, and as downloadable binary from thereleases page:

brew install raystack/tap/stencil

To upgrade to the latest version:

brew upgrade stencil

Linux

stencil is available as downloadable binaries from thereleases page. Download the.deb or.rpm from the releases page and install withsudo dpkg -i andsudo rpm -i respectively.

Windows

stencil is available viascoop, and as a downloadable binary from thereleases page:

scoop bucket add stencil https://github.com/raystack/scoop-bucket.git

To upgrade to the latest version:

scoop update stencil

Docker

We provide ready to use Docker container images. To pull the latest image:

docker pull raystack/stencil:latest

To pull a specific version:

docker pull raystack/stencil:v0.5.1

Usage

Stencil has three major components. Server, CLI and clients. Stencil server and CLI are bundled in a single binary.

Server

Stencil server provides a way to store and fetch schemas and enforce compatibility rules. Runstencil server --help to see instructions to manage Stencil server.

Stencil server also provides a fully-featured GRPC and HTTP API to interact with Stencil server. Both APIs adheres to a set of standards that are rigidly followed. Please refer toproton for GRPC API definitions.

CLI

Stencil CLI allows users to iteract with server to create, view, and search schemas. CLI is fully featured but simple to use, even for those who have very limited experience working from the command line. Runstencil --help to see list of all available commands and instructions to use.

Clients

Stencil clients allows application to interact with stencil server to eserialize and deserialize messages using schema. Stencil supports clients in multiple languages.

Running locally

Dependencies:
- Git- Go 1.16 or above- Yarn (Needed for UI)- PostgreSQL 13 or above
# Clone the repo$ git clone git@github.com:raystack/stencil.git# Check all build comamnds available$ makehelp# Build meteor binary file$ make build# Init server config$ cp config/config.yaml config.yaml# Run database migrations$ ./stencil server migrate# Start stencil server$ ./stencil server start

Running tests

# Running all unit tests$ maketest# Print code coverage$ make coverage

Contribute

Development of Stencil happens in the open on GitHub, and we are grateful to the community for contributing bugfixes and improvements. Read below to learn how you can take part in improving stencil.

Read ourcontributing guide to learn about our development process, how to propose bugfixes and improvements, and how to build and test your changes to stencil.

To help you get your feet wet and get you familiar with our contribution process, we have a list ofgood first issues that contain bugs which have a relatively limited scope. This is a great place to get started.

This project exists thanks to all thecontributors.

About

Stencil is a schema registry that provides schema management and validation dynamically, efficiently, and reliably to ensure data compatibility across applications.

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Contributors24


[8]ページ先頭

©2009-2025 Movatter.jp