Skip to content
forked from pingcap/tidb

TiDB is an open source distributed HTAP database compatible with the MySQL protocol

License

Notifications You must be signed in to change notification settings

CheneyDing/tidb

This branch is 11373 commits behind pingcap/tidb:master.

Folders and files

NameName
Last commit message
Last commit date
Jul 12, 2021
Apr 23, 2016
Jul 9, 2021
Jul 20, 2021
Jul 15, 2021
Jul 21, 2021
Jul 13, 2021
Jul 16, 2021
Jul 19, 2021
Jul 10, 2021
Jul 21, 2021
Jul 21, 2021
Oct 9, 2020
Jul 19, 2021
Jul 12, 2021
Nov 25, 2020
Jul 13, 2021
Jul 19, 2021
Jun 11, 2021
Jul 21, 2021
May 14, 2021
Jul 20, 2021
Jul 21, 2021
Jul 21, 2021
Jul 21, 2021
Jul 15, 2021
Jul 19, 2021
Jun 26, 2021
Jul 20, 2021
May 17, 2021
Jul 21, 2021
Jul 14, 2021
Jul 16, 2021
Jul 5, 2021
Jun 16, 2021
Jul 21, 2021
Jul 21, 2021
Jun 16, 2021
Sep 26, 2019
Mar 5, 2017
Aug 22, 2018
Feb 4, 2021
Jul 9, 2021
Sep 3, 2019
Sep 29, 2020
Jun 25, 2021
Jun 29, 2021
May 15, 2017
Apr 23, 2016
Jul 5, 2021
Oct 27, 2020
May 20, 2021
Jul 7, 2021
Jun 5, 2017
Dec 28, 2019
Feb 26, 2021
Apr 28, 2017
Jul 16, 2021
Jul 20, 2021
Jul 20, 2021
Jan 10, 2020

LICENSE Language Build Status Go Report Card GitHub release GitHub release date CircleCI Status Coverage Status GoDoc

What is TiDB?

TiDB ("Ti" stands for Titanium) is an open-source NewSQL database that supports Hybrid Transactional and Analytical Processing (HTAP) workloads. It is MySQL compatible and features horizontal scalability, strong consistency, and high availability.

  • Horizontal Scalability

    TiDB expands both SQL processing and storage by simply adding new nodes. This makes infrastructure capacity planning both easier and more cost-effective than traditional relational databases which only scale vertically.

  • MySQL Compatible Syntax

    TiDB acts like it is a MySQL 5.7 server to your applications. You can continue to use all of the existing MySQL client libraries, and in many cases, you will not need to change a single line of code in your application. Because TiDB is built from scratch, not a MySQL fork, please check out the list of known compatibility differences.

  • Distributed Transactions with Strong Consistency

    TiDB internally shards table into small range-based chunks that we refer to as "Regions". Each Region defaults to approximately 100 MiB in size, and TiDB uses a Two-phase commit internally to ensure that Regions are maintained in a transactionally consistent way.

  • Cloud Native

    TiDB is designed to work in the cloud -- public, private, or hybrid -- making deployment, provisioning, operations, and maintenance simple.

    The storage layer of TiDB, called TiKV, is a Cloud Native Computing Foundation (CNCF) Graduated project. The architecture of the TiDB platform also allows SQL processing and storage to be scaled independently of each other in a very cloud-friendly manner.

  • Minimize ETL

    TiDB is designed to support both transaction processing (OLTP) and analytical processing (OLAP) workloads. This means that while you may have traditionally transacted on MySQL and then Extracted, Transformed and Loaded (ETL) data into a column store for analytical processing, this step is no longer required.

  • High Availability

    TiDB uses the Raft consensus algorithm to ensure that data is highly available and safely replicated throughout storage in Raft groups. In the event of failure, a Raft group will automatically elect a new leader for the failed member, and self-heal the TiDB cluster without any required manual intervention. Failure and self-healing operations are also transparent to applications.

For more details and latest updates, see TiDB docs and release notes.

Community

You can join these groups and chats to discuss and ask TiDB related questions:

In addition, you may enjoy following:

For support, please contact PingCAP.

Quick start

To start using TiDB

See Quick Start Guide.

To start developing TiDB

If you want to build TiDB right away, there are two options:

You have a working Go environment.

mkdir -p $GOPATH/src/github.com/pingcap
cd $GOPATH/src/github.com/pingcap
git clone https://github.com/pingcap/tidb.git
cd tidb
make
cd bin && ./tidb-server

You have a working Docker environment.

docker pull pingcap/tidb:latest
docker run --name tidb-server -d -p 4000:4000 pingcap/tidb:latest

Now you can use official mysql client to connect to TiDB.

mysql -h 127.0.0.1 -P 4000 -u root -D test --prompt="tidb> " 

Contributing

The community repository hosts all information about the TiDB community, including how to contribute to TiDB, how TiDB community is governed, how special interest groups are organized, etc.

contribution-map

Contributions are welcomed and greatly appreciated. See Contribution Guide for details on submitting patches and the contribution workflow. For more contributing information, click on the contributor icon above.

Adopters

View the current list of in-production TiDB adopters here.

Case studies

Roadmap

Read the Roadmap.

Architecture

architecture

License

TiDB is under the Apache 2.0 license. See the LICENSE file for details.

Acknowledgments

About

TiDB is an open source distributed HTAP database compatible with the MySQL protocol

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 99.7%
  • Other 0.3%