Java开发人员需要了解的地域分布数据库

在过去的七年里,我一直在使用分布式系统、平台和数据库。早在2015年,许多架构师就开始使用分布式数据库扩展单个机器或服务器的边界。他们选择这样的数据库是因为它的水平可伸缩性,尽管它的性能依然只能与传统的单服务器数据库相媲美。 

现在,随着云原生应用程序和无服务器架构的兴起,分布式数据库需要做的不仅仅是提供横向可伸缩性。架构师需要在主要云区中断期间能够保持可用的数据库,支持混合云部署,并为接近客户和最终用户的数据提供服务。这就是地域分布数据库发挥作用的地方。 

作为一名Java开发人员,我有两个问题:

1. 我应该投入多少精力为云原生地域分布数据库创建应用程序?

2. 这只是对我现有应用程序的快速重构还是彻底重新设计/重写?

工作量因用例而异。但即便如此,在构建一个简单的应用程序时,你也可以从“入门”体验中学到很多东西。在这篇文章中,我将分享使用YugabyteDB作为地域分布数据库创建Java应用程序时的主要见解。你可以在GitHub上找到完整的源代码。现在让我们开始吧!

数据库部署

YugabyteDB提供完全托管的云版本,支持AWS和GCE,类似于其他云原生数据库。作为开发人员,这对我来说意义重大。我只想运行一个实例,以使我可以专注于应用程序逻辑。

最后,我花了几分钟在AWS上启动一个免费实例,并将连接信息复制到我的应用程序。正如预期的那样,体验是顺利而快捷的。在编写一行代码之前,我必须下载、安装和配置数据库的日子已经一去不复返了。

数据库连接

作为一名后端开发人员,我很感激有一个原生使用SQL的数据库。这缩短了学习曲线,让我可以重用现有的逻辑。尽管我使用Spring Data或Micronaut,我仍然编写和执行直接的SQL查询。

只要YugabyteDB使用Postgres方言,我想我的简单Java应用程序就可以通过一个很好的老JDBC接口连接到正在运行的数据库实例。使用Yugabyteb,你可以选择标准PostgreSQL JDBC驱动程序或带有一些性能优势的原生Yugabyte JDBC驱动程序。我选择了后者。

几分钟后,我把笔记本电脑的IP地址添加到Yugabyte Cloud的IP允许列表中。我还编译和启动了示例应用程序,并成功地连接到云实例。JDBC连接逻辑与MySQL、Postgres和其他关系数据库要求我遵循的逻辑没有什么不同。这是一个非常好的迹象。

YBClusterAwareDataSource ds = new YBClusterAwareDataSource();

ds.setUrl("jdbc:yugabytedb://" + settings.getProperty("host") + ":"
+ settings.getProperty("port") + "/yugabyte");
ds.setUser(settings.getProperty("dbUser"));
ds.setPassword(settings.getProperty("dbPassword"));

// Additional SSL-specific settings. See the source code for details.

Connection conn = ds.getConnection();

更好的是,虽然我的测试使用了一个免费的单节点实例,但是,就算我的数据库中有60个节点跨越几个大洲,连接逻辑仍然保持不变。对于应用程序开发人员来说,YugabyteDB是一个单一的逻辑实例,所有与数据分区、节点间通信和分布式查询执行相关的复杂性都是在幕后透明地进行。

基本CRUD操作

建立连接逻辑后,我介绍几个方法,通过JDBC连接,创建示例表然后查询和更新其记录。这意味着我的简单Java应用程序必须尽可能初级。因此,我选择了一个非常基本的用例:两个帐户之间的资金转移。

示例表是用标准的CREATE TABLE命令创建:

Statement stmt = conn.createStatement();

stmt.execute("CREATE TABLE IF NOT EXISTS " + TABLE_NAME +
"(" +
"id int PRIMARY KEY," +
"name varchar," +
"age int," +
"country varchar," +
"balance int" +
    ")");

并且只填充了两记录(足以评估入门体验):

stmt.execute("INSERT INTO " + TABLE_NAME + " VALUES" +
"(1, 'Jessica', 28, 'USA', 10000)," +
    "(2, 'John', 28, 'Canada', 9000)");

最后,在Postgres或MySQL中查询和更新类似表的SQL查询在我的地域分布数据库中的工作方式是相同的。以下是两种方法的完整实现:第一种方法查询分布式记录,第二种方法使用分布式事务一致地更新记录:

private static void selectAccounts(Connection conn) throws SQLException {
Statement stmt = conn.createStatement();

ResultSet rs = stmt.executeQuery("SELECT * FROM " + TABLE_NAME);

while (rs.next()) {
System.out.println(String.format("name = %s, age = %s, country = %s, balance = %s",
rs.getString(2), rs.getString(3), rs.getString(4), rs.getString(5)));
}
}

private static void transferMoneyBetweenAccounts(Connection conn, int amount) throws SQLException {
Statement stmt = conn.createStatement();

try {
stmt.execute(
"BEGIN TRANSACTION;" +
"UPDATE " + TABLE_NAME + " SET balance = balance - " + amount + "" + " WHERE name = 'Jessica';" +
"UPDATE " + TABLE_NAME + " SET balance = balance + " + amount + "" + " WHERE name = 'John';" +
"COMMIT;"
);
} catch (SQLException e) {
if (e.getErrorCode() == 40001) {
// The operation aborted due to a concurrent transaction trying to modify the same set of rows.
// Consider adding retry logic for production-grade applications.
e.printStackTrace();
} else {
throw e;
}
}

System.out.println();
System.out.println(">>>> Transferred " + amount + " between accounts.");
}

结束语

我很高兴地确认,现代地域分布数据库的创建者保护我(应用程序开发人员)免受与分布式系统相关的大多数复杂性的影响。我在一分钟内启动了一个分布式数据库实例,作为单个逻辑实例连接,并通过熟悉的SQL和JDBC接口查询数据库。我承认,我的简单Java应用程序远不是一个包含底层、特定于数据库的优化的实际解决方案。然而,入门就像单服务器数据库一样简单,这很重要。 

你可以在GitHub上找到我的完整应用程序。我鼓励你尝试自己运行它。 

译者介绍

杨晓娟,社区编辑,西安电子科技大学计算机专业硕士研究生,资深研发工程师,信息系统项目管理师,拥有近20年Java开发经验。分别在NEC、甲骨文、英方从事数据存储、Oracle数据库的数据迁移以及同构/异构数据库复制等研发工作,尤其在数据库、数据编码等方面有深入钻研和了解。

原文标题:​​What Java Developers Need to Know About Geo-Distributed Databases​​,作者:Denis Magda

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/290240.html<

(0)
运维的头像运维
上一篇2025-05-19 03:18
下一篇 2025-05-19 03:19

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注