TiDB explained

TiDB
Developer:PingCAP Inc.
Released:[1]
Programming Language:Go (TiDB), Rust (TiKV)
Language:English, Chinese
Genre:NewSQL
License:Apache 2.0

TiDB (/’taɪdiːbi:/, "Ti" stands for Titanium) is an open-source NewSQL database that supports Hybrid Transactional and Analytical Processing (HTAP) workloads.[2] Designed to be MySQL compatible, it is developed and supported primarily by PingCAP and licensed under Apache 2.0. It is also available as a paid product. TiDB drew its initial design inspiration from Google's Spanner and F1 papers.[3] [4] [5]

Release history

See all TiDB release notes.

Main features

Horizontal scalability

TiDB can expand both SQL processing and storage capacity by adding new nodes.

MySQL compatibility

TiDB acts like it is a MySQL 8.0 server to applications. A user can continue to use all of the existing MySQL client libraries.[6] Because TiDB's SQL processing layer is built from scratch, not a MySQL fork.[7]

Distributed transactions with strong consistency

TiDB internally shards a table into small range-based chunks that are referred to as "Regions".[8] Each Region defaults to approximately 100 MB 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. The storage layer of TiDB, called TiKV, became a Cloud Native Computing Foundation (CNCF) member project in August 2018, as a Sandbox level project,[9] and became an incubation-level hosted project in May 2019.[10] TiKV graduated from CNCF in September 2020.[11]

Real-time HTAP

TiDB can support both online transaction processing (OLTP) and online analytical processing (OLAP) workloads. TiDB has two storage engines: TiKV, a rowstore, and TiFlash, a columnstore.

High availability

TiDB uses the Raft consensus algorithm[12] to ensure that data is available and 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.

Deployment methods

Kubernetes with Operator

TiDB can be deployed in a Kubernetes-enabled cloud environment by using TiDB Operator.[13] An Operator is a method of packaging, deploying, and managing a Kubernetes application. It is designed for running stateful workloads and was first introduced by CoreOS in 2016.[14] TiDB Operator[15] was originally developed by PingCAP and open-sourced in August, 2018.[16] TiDB Operator can be used to deploy TiDB on a laptop,[17] Google Cloud Platform’s Google Kubernetes Engine,[18] and Amazon Web Services’ Elastic Container Service for Kubernetes.[19]

TiUP

TiDB 4.0 introduces TiUP, a cluster operation and maintenance tool. It helps users quickly install and configure a TiDB cluster with a few commands.[20]

TiDB Ansible

TiDB can be deployed using Ansible by using a TiDB Ansible playbook (not recommended).[21]

Docker

Docker can be used to deploy TiDB in a containerized environment on multiple nodes and multiple machines, and Docker Compose can be used to deploy TiDB with a single command for testing purposes.[22]

Tools

TiDB has a series of open-source tools built around it to help with data replication and migration for existing MySQL and MariaDB users.

TiDB Data Migration (DM)

TiDB Data Migration (DM) is suited for replicating data from already sharded MySQL or MariaDB tables to TiDB.[23] A common use case of DM is to connect MySQL or MariaDB tables to TiDB, treating TiDB almost as a slave, then directly run analytical workloads on this TiDB cluster in near real-time.

Backup & Restore

Backup & Restore (BR) is a distributed backup and restore tool for TiDB cluster data.[24]

Dumpling

Dumpling is a data export tool that exports data stored in TiDB or MySQL. It lets users make logical full backups or full dumps from TiDB or MySQL.[25]

TiDB Lightning

TiDB Lightning is a tool that supports high speed full-import of a large MySQL dump into a new TiDB cluster. This tool is used to populate an initially empty TiDB cluster with much data, in order to speed up testing or production migration. The import speed improvement is achieved by parsing SQL statements into key-value pairs, then directly generate Sorted String Table (SST) files to RocksDB.[26] [27]

TiCDC

TiCDC is a Change data capture tool which streams data from TiDB to other systems like Apache Kafka.

TiDB Binlog

TiDB Binlog is a tool used to collect the logical changes made to a TiDB cluster. It is used to provide incremental backup and replication, either between two TiDB clusters, or from a TiDB cluster to another downstream platform.[28] [29]

See also

Notes and References

  1. Web site: 1.0 GA release notes. .
  2. Web site: Xu. Kevin. October 17, 2018. How TiDB combines OLTP and OLAP in a distributed database. InfoWorld.
  3. Web site: 2013 . F1: A Distributed SQL Database That Scales .
  4. Web site: 2012 . Spanner: Google's Globally-Distributed Database .
  5. Web site: Hall. Susan. April 17, 2017. TiDB Brings Distributed Scalability to SQL. The New Stack.
  6. Web site: Tocker. Morgan. November 14, 2018. Meet TiDB: An open source NewSQL database. Opensource.com.
  7. Web site: Compatibility with MySQL. PingCAP.
  8. Web site: TiKV Architecture. TiKV.
  9. Web site: Evans. Kristen. August 28, 2018. CNCF to Host TiKV in the Sandbox. Cloud Native Computing Foundation.
  10. Web site: CNCF. May 21, 2019. TOC Votes to Move TiKV into CNCF Incubator. August 19, 2020. Cloud Native Computing Foundation.
  11. Web site: TiKV Authors. September 2, 2020. Celebrating TiKV's CNCF Graduation. TiKV.
  12. Web site: The Raft Consensus Algorithm .
  13. Web site: Jackson. Joab. January 22, 2019. Database Operators Bring Stateful Workloads to Kubernetes. The New Stack.
  14. Web site: Philips. Brandon. November 3, 2016. Introducing Operators: Putting Operational Knowledge into Software. CoreOS.
  15. Web site: TiDB Operator GitHub repo. GitHub.
  16. Web site: August 16, 2018. Introducing the Kubernetes Operator for TiDB. InfoWorld.
  17. Web site: Deploy TiDB to Kubernetes on Your Laptop.
  18. Web site: Deploy TiDB, a distributed MySQL compatible database, to Kubernetes on Google Cloud.
  19. Web site: Deploy TiDB, a distributed MySQL compatible database, on Kubernetes via AWS EKS . .
  20. Web site: Long. Heng. April 19, 2020. Get a TiDB Cluster Up in Only One Minute. August 19, 2020. PinCAP.
  21. Web site: Ansible Playbook for TiDB . .
  22. Web site: How to Spin Up an HTAP Database in 5 Minutes With TiDB + TiSpark .
  23. Web site: DM GitHub Repo. GitHub.
  24. Web site: Shen. Taining. April 13, 2020. How to Back Up and Restore a 10-TB Cluster at 1+ GB/s. PingCAP.
  25. Web site: Dumpling Overview. PingCAP.
  26. Web site: Chan. Kenny. January 30, 2019. Introducing TiDB Lightning. PingCAP.
  27. Web site: TiDB Lightning Overview. PingCAP.
  28. Web site: TiDB Binlog Cluster Overview. PingCAP.
  29. Web site: Wang. Xiang. January 29, 2019. TiDB-Binlog Architecture Evolution and Implementation Principles. PingCAP.