Company
Date Published
June 8, 2021
Author
Rebecca Taft
Word count
4939
Language
English
Hacker News points
24

Summary

CockroachDB is a distributed SQL database designed for multi-region deployment. It provides built-in support for global data distribution, enabling developers to easily create rows homed in different regions while still being accessible using familiar declarative SQL syntax. This feature, called REGIONAL BY ROW, allows users to specify the region where each row of data should be stored, making it easy to deploy a database across multiple regions and ensuring that data is always available even if entire regions fail. To demonstrate this capability, we can create a sample table with rows distributed across different regions using CockroachDB's SQL syntax. We will also configure the default region for each node in the cluster and enable locality optimized partitioned index scans to improve query performance. Here are some key points about REGIONAL BY ROW: 1. It is built into CockroachDB, making it easy to use without requiring additional configuration or tools. 2. Users can specify the region where each row of data should be stored using SQL syntax, allowing for fine-grained control over data distribution across regions. 3. Locality optimized partitioned index scans are enabled by default, which means that CockroachDB will automatically try to access data from the closest available node when executing queries, improving query performance and minimizing latency. 4. Data is always accessible even if entire regions fail, thanks to CockroachDB's distributed architecture and built-in replication features. 5. The ability to easily deploy a database across multiple regions can help organizations improve the availability and resilience of their applications while reducing costs associated with data storage and transfer. In summary, REGIONAL BY ROW is a powerful feature in CockroachDB that makes it easy for developers to create globally distributed databases with built-in support for multi-region deployment. By allowing users to specify the region where each row of data should be stored, this feature enables organizations to improve the availability and resilience of their applications while reducing costs associated with data storage and transfer.