Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bytedance/bitsail

BitSail is a distributed high-performance data integration engine which supports batch, streaming and incremental scenarios. BitSail is widely used to synchronize hundreds of trillions of data every day.
https://github.com/bytedance/bitsail

big-data data-integration data-lake data-pipeline data-synchronization flink high-performance real-time

Last synced: 29 days ago
JSON representation

BitSail is a distributed high-performance data integration engine which supports batch, streaming and incremental scenarios. BitSail is widely used to synchronize hundreds of trillions of data every day.

Awesome Lists containing this project

README

        

![logo](website/images/bitsail_logo.png)

English | [简体中文](README_zh.md)

[![Build](https://github.com/bytedance/bitsail/actions/workflows/cicd.yml/badge.svg)](https://github.com/bytedance/bitsail/actions/workflows/cicd.yml)
[![License](https://img.shields.io/badge/license-Apache%202-4EB1BA.svg)](https://www.apache.org/licenses/LICENSE-2.0.html)
[![Join Slack](https://img.shields.io/badge/slack-%23BitSail-72eff8?logo=slack&color=5DADE2&label=Join%20Slack)](https://join.slack.com/t/bitsailworkspace/shared_invite/zt-1l1vgcnlj-gPSWqggOeRHrSO5l7na2WQ)
[![Website](https://img.shields.io/badge/Website-%23BitSail-blue)](https://bytedance.github.io/bitsail/)
## Introduction
BitSail is ByteDance's open source data integration engine which is based on distributed architecture and provides high performance. It supports data synchronization between multiple heterogeneous data sources, and provides global data integration solutions in batch, streaming, and incremental scenarios. At present, it serves almost all business lines in ByteDance, such as Douyin, Toutiao, etc., and synchronizes hundreds of trillions of data every day.

Official website of BitSail: https://bytedance.github.io/bitsail/

## Why Do We Use BitSail
BitSail has been widely used and supports hundreds of trillions of large traffic. At the same time, it has been verified in various scenarios such as the cloud native environment of the volcano engine and the on-premises private cloud environment.

We have accumulated a lot of experience and made a number of optimizations to improve the function of data integration

- Global Data Integration, covering batch, streaming and incremental scenarios

- Distributed and cloud-native architecture, supporting horizontal scaling

- High maturity in terms of accuracy, stability and performance

- Rich basic functions, such as type conversion, dirty data processing, flow control, data lake integration, automatic parallelism calculation
, etc.

- Task running status monitoring, such as traffic, QPS, dirty data, latency, etc.

## BitSail Use Scenarios
- Mass data synchronization in heterogeneous data sources

- Streaming and batch integration data processing capability

- Data lake and warehouse integration data processing capability

- High performance, high reliability data synchronization

- Distributed, cloud-native architecture data integration engine

## Features of BitSail

- Low start-up cost and high flexibility

- Stream-batch integration and Data lake-warehouse integration architecture, one framework covers almost all data synchronization scenarios

- High-performance, massive data processing capabilities

- DDL automatic synchronization

- Type system, conversion between different data source types

- Engine independent reading and writing interface, low development cost

- Real-time display of task progress, under development

- Real-time monitoring of task status

## Architecture of BitSail
![](website/images/bitsail_arch.png)

```
Source[Input Sources] -> Framework[Data Transmission] -> Sink[Output Sinks]
```
The data processing pipeline is as follows. First, pull the source data through Input Sources, then process it through the intermediate framework layer, and finally write the data to the target through Output Sinks

At the framework layer, we provide rich functions and take effect for all synchronization scenarios, such as dirty data collection, auto parallelism calculation, task monitoring, etc.

In data synchronization scenarios, it covers batch, streaming, and incremental data synchronization

In the Runtime layer, it supports multiple execution modes, such as yarn, local, and k8s is under development

## Supported Connectors


DataSource
Sub Modules
Reader
Writer


Assert
-




ClickHouse
-

-


Doris
-




Druid
-




Elasticsearch
-




Fake
-




FTP/SFTP
-




Hadoop
-




HBase
-




Hive
-




Hudi
-




LocalFileSystem
-




JDBC
MySQL




Oracle


PostgreSQL


SqlServer


Kafka
-




Kudu
-




LarkSheet
-




MongoDB
-




Print
-




Redis
-




RocketMQ
-




SelectDB
-


Documentation for [Connectors](website/en/documents/connectors/README.md).

## Community Support
### Slack
Join BitSail Slack channel via this [link](https://join.slack.com/t/bitsailworkspace/shared_invite/zt-1l1vgcnlj-gPSWqggOeRHrSO5l7na2WQ)

### Mailing List
Currently, BitSail community use Google Group as the mailing list provider.
You need to subscribe to the mailing list before starting a conversation

Subscribe: Email to this address `[email protected]`

Start a conversation: Email to this address `[email protected]`

Unsubscribe: Email to this address `[email protected]`

### WeChat Group
Welcome to scan this QR code and to join the WeChat group chat.

qr

## Environment Setup
Link to [Environment Setup](website/en/documents/start/env_setup.md).

## Deployment Guide
Link to [Deployment Guide](website/en/documents/start/deployment.md).

## BitSail Configuration
Link to [Configuration Guide](website/en/documents/start/config.md).

## Contributing Guide
Link to [Contributing Guide](website/en/community/contribute.md).

## Contributors
**Thanks all contributors**



## License
[Apache 2.0 License](LICENSE).