百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

使用 SQLite 的特定于分支机构的数据库

liebian365 2024-11-13 13:24 8 浏览 0 评论

这是一系列帖子中的第一篇,我想重点介绍增强 Ruby on Rails 应用程序的方法。 具体来说,在第一个系列中,我想深入探讨我们可以利用和授权使用 SQLite 作为 Rails 应用程序的数据库引擎的方法。 在这篇首篇文章中,让我们深入探讨如何使用 SQLite 作为我们的数据库引擎为我们的本地开发工作流程开辟强大的新可能性; 具体来说,允许我们拥有并使用特定于部门的数据库。

过去几年,人们对在 Web 应用程序生产中使用 SQLite 的兴趣激增。 我欣然承认我也完全同意。 SQLite 消除了网络延迟,简化了操作,并使针对生产堆栈的自动化测试变得容易。

在本系列的整个过程中,我想介绍一些我们可以对 Rails 应用程序进行的关键调整,以使 SQLite 的使用更加强大和愉快。 首先,我想重点关注本地开发的开发人员体验 (DX) 改进。

任何在开发团队中开发过 Rails 应用程序的人都知道,管理数据库模式可能很棘手。 每个开发人员的分支可能包括一些迁移,这些迁移会更新架构,但在本地您只有一个开发数据库。 在分支之间切换变得很痛苦,运行迁移也变得很痛苦,有时,当模式更改被合并时,错误会潜入生产中,而这些更改本来不应该成为该版本的一部分。

我最喜欢的 PlanetScale 功能之一是其分支功能:

分支是数据库模式的副本,它们存在于彼此完全独立的环境中。 在一个分支中进行更改不会影响其他分支,直到您合并它们,就像管理项目中的代码分支一样。

这很可爱,它解决了上面列出的痛点。 然而,在我看来这并不十分完美。 因为我们的应用程序现在有两种不同类型的“分支”。 我们有 Git 分支,它隔离我们的代码(包括迁移),还有我们的数据库分支,它隔离我们的模式。 现在拥有两个独立的分支会产生同步问题。 Git 分支和数据库分支如何关联? 我们如何将 git 分支合并与数据库分支合并与生产部署联系起来? ETC。

这是 PlanetScale 需要做出的必要权衡,因为他们的无服务器数据库平台无法与每个用户的代码库深度集成。 然而,作为使用 SQLite 的 Rails 开发人员,我们拥有独特的机会。


让我们描述一下我们的理想场景,然后深入研究如何实现它。 我们想要的是有一个单独的分支(Git 分支)来隔离我们的代码和模式。 我们希望切换 Git 分支来自动切换模式分支。 我们希望生产部署由 Git 分支合并驱动,同时还能自动确保可预测且稳定的生产模式。 听起来不错,不是吗? 幸运的是,Rails 和 SQLite 使这样的设置非常容易创建。

让我们从最后一个功能开始,因为这是 Rails 为我们提供的功能,无论我们的数据库引擎如何。 这个功能正是我们的 /migrations 目录和 /db/schema.rb 或 /db/struction.sql 文件的值。 通过将数据库模式管理集成到 Rails 应用程序代码库中,并确保所有模式更改都是通过 Rails 迁移实现,我们可以将生产模式绑定到简单的 Git 分支合并,同时还确保我们的生产模式是可预测的和稳定的。

老实说,其他两个功能也可以通过任何 Rails 支持的数据库适配器实现,但 SQLite 最适合这种方法。 而且方法很简单。 从根本上来说,我们需要做的就是告诉 Rails 使用与 Git 分支名称绑定的动态数据库名称进行本地开发。 Rails 通过 /config/database.yml 文件使这变得容易,这是我们配置数据库核心细节的地方。 默认情况下,当使用 SQLite 时,Rails 会生成一个 /config/database.yml ,如下所示:

# SQLite. Versions 3.8.0 and up are supported.
#   gem install sqlite3
#
#   Ensure the SQLite 3 gem is defined in your Gemfile
#   gem "sqlite3"
#
default: &default
  adapter: sqlite3
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
  timeout: 5000

development:
  <<: *default
  database: storage/development.sqlite3

# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
  <<: *default
  database: storage/test.sqlite3

production:
  <<: *default
  database: storage/production.sqlite3

简单合理。 每个 Rails 环境都有自己的数据库文件。 每个数据库文件都存储在 /storage 目录中(大多数托管提供商确保内容在部署中保留)。 并且每个数据库文件都有一个固定的文件名。 我们想要的是让我们的开发环境使用数据库的动态文件名,并且我们希望该文件名基于当前的 Git 分支。 快速谷歌搜索会得到一个 StackOverflow 答案,它提供了用于获取当前分支名称的 git 命令:

git branch --show-current

注意:如果您使用的 Git 版本低于 2.22(添加了 --show-current 选项时),您可以使用 git rev-parse --abbrev-ref HEAD 代替。

那么,我们如何在 /config/database.yml 文件中使用它呢? 嗯,Rails 使这一切变得简单,因为它允许 ERB。 为代码添加一点弹性,我们可以用以下内容替换我们的开发部分:

development:
  <<: *default
  database: storage/<%= `git branch --show-current`.chomp || 'development' %>.sqlite3

现在,我们不再总是使用 storage/development.sqlite3 作为数据库文件名,而是提供一个动态文件名,无论我们当前的 Git 分支名称是什么,该文件名都会命名数据库文件。 通过这一行更改,我们实现了第一个理想功能——我们有一个分支(Git 分支),它隔离了我们的代码和模式。

接下来,我们如何配置Rails在我们的Git分支发生变化时自动切换“模式分支”? 好吧,根据上面的解决方案,我们需要更清楚地阐明我们到底需要什么。 对 /config/database.yml 文件的更改已经确保了当我们切换 Git 分支时,我们的 Rails 应用程序将与隔离的开发数据库进行通信。 然而,仅此更改并不能确保一旦我们切换了 Git 分支,我们的独立开发数据库就可以使用了。 想象一下,一位同事创建了一个分支,添加了两个新的数据库迁移。 您拉下该分支来进行一些代码审查和本地手动测试。 当您第一次切换本地 Git 存储库以签出同事的分支时,我们的动态 /config/database.yml 配置将确保在 /storage 目录中创建新的 SQLite 数据库文件。 但是,这个新的 SQLite 数据库文件中还没有任何内容,也没有架构设置。 那么,我们如何确保每当我们切换数据库分支时Rails都会自动准备这个新的数据库文件呢?

好吧,对我们来说幸运的是,Rails 使这变得非常简单。 Rails 提供了 ActiveRecord::Tasks::DatabaseTasks 实用程序类,它“封装了用于管理数据库和迁移的常见任务背后的逻辑”。 根据我们的需要,我们可以使用 .prepare_all 方法,该方法相当于 Rails 6 中添加的 db:prepare Rake 命令。准备数据库意味着,如果数据库已经存在,则运行迁移,或者创建数据库并加载 如果没有,则为架构。 我们需要做的就是告诉 Rails 在开发中每次启动应用程序时运行此命令。 这将确保我们的动态数据库始终可供我们的 Rails 应用程序使用(无论是运行服务器还是跳转到控制台)。

为了让 Rails 在启动应用程序时在开发中运行此命令,我们只需将其添加到 /config/environments/development.rb 文件中:

# Ensure that our branch-specific SQLite database is prepared for our application to use
config.after_initialize do
  ActiveRecord::Tasks::DatabaseTasks.prepare_all
end

我们只需配置开发环境以在应用程序初始化后运行 .prepare_all 命令。

添加了这个简单的配置,我们现在有了理想的设置。 每个 Git 分支都有自己独立的数据库文件。 当我们启动 Rails 应用程序时,该数据库会自动准备好供按需使用。 由 Git 分支合并驱动的生产部署通过专门使用迁移来改变我们的模式,继续产生稳定且可预测的生产模式。

我可以说,我已经在几个不同的 Rails 应用程序中使用了这个设置,我非常喜欢它! 我喜欢 Rails 和 SQLite 如此轻松地设置这样的功能。 总共有四行(如果我们使用 after_initialize 的内联块,很容易就变成两行),为像 PlanetScale 这样的奇特平台提供类似的(并且在某些关键方面有所改进)功能。

相关推荐

快递查询教程,批量查询物流,一键管理快递

作为商家,每天需要查询许许多多的快递单号,面对不同的快递公司,有没有简单一点的物流查询方法呢?小编的回答当然是有的,下面随小编一起来试试这个新技巧。需要哪些工具?安装一个快递批量查询高手快递单号怎么快...

一键自动查询所有快递的物流信息 支持圆通、韵达等多家快递

对于各位商家来说拥有一个好的快递软件,能够有效的提高自己的工作效率,在管理快递单号的时候都需要对单号进行表格整理,那怎么样能够快速的查询所有单号信息,并自动生成表格呢?1、其实方法很简单,我们不需要一...

快递查询单号查询,怎么查物流到哪了

输入单号怎么查快递到哪里去了呢?今天小编给大家分享一个新的技巧,它支持多家快递,一次能查询多个单号物流,还可对查询到的物流进行分析、筛选以及导出,下面一起来试试。需要哪些工具?安装一个快递批量查询高手...

3分钟查询物流,教你一键批量查询全部物流信息

很多朋友在问,如何在短时间内把单号的物流信息查询出来,查询完成后筛选已签收件、筛选未签收件,今天小编就分享一款物流查询神器,感兴趣的朋友接着往下看。第一步,运行【快递批量查询高手】在主界面中点击【添...

快递单号查询,一次性查询全部物流信息

现在各种快递的查询方式,各有各的好,各有各的劣,总的来说,还是有比较方便的。今天小编就给大家分享一个新的技巧,支持多家快递,一次能查询多个单号的物流,还能对查询到的物流进行分析、筛选以及导出,下面一起...

快递查询工具,批量查询多个快递快递单号的物流状态、签收时间

最近有朋友在问,怎么快速查询单号的物流信息呢?除了官网,还有没有更简单的方法呢?小编的回答当然是有的,下面一起来看看。需要哪些工具?安装一个快递批量查询高手多个京东的快递单号怎么快速查询?进入快递批量...

快递查询软件,自动识别查询快递单号查询方法

当你拥有多个快递单号的时候,该如何快速查询物流信息?比如单号没有快递公司时,又该如何自动识别再去查询呢?不知道如何操作的宝贝们,下面随小编一起来试试。需要哪些工具?安装一个快递批量查询高手快递单号若干...

教你怎样查询快递查询单号并保存物流信息

商家发货,快递揽收后,一般会直接手动复制到官网上一个个查询物流,那么久而久之,就会觉得查询变得特别繁琐,今天小编给大家分享一个新的技巧,下面一起来试试。教程之前,我们来预览一下用快递批量查询高手...

简单几步骤查询所有快递物流信息

在高峰期订单量大的时候,可能需要一双手当十双手去查询快递物流,但是由于逐一去查询,效率极低,追踪困难。那么今天小编给大家分享一个新的技巧,一次能查询多个快递单号的物流,下面一起来学习一下,希望能给大家...

物流单号查询,如何查询快递信息,按最后更新时间搜索需要的单号

最近有很多朋友在问,如何通过快递单号查询物流信息,并按最后更新时间搜索出需要的单号呢?下面随小编一起来试试吧。需要哪些工具?安装一个快递批量查询高手快递单号若干怎么快速查询?运行【快递批量查询高手】...

连续保存新单号功能解析,导入单号查询并自动识别批量查快递信息

快递查询已经成为我们日常生活中不可或缺的一部分。然而,面对海量的快递单号,如何高效、准确地查询每一个快递的物流信息,成为了许多人头疼的问题。幸运的是,随着科技的进步,一款名为“快递批量查询高手”的软件...

快递查询教程,快递单号查询,筛选更新量为1的单号

最近有很多朋友在问,怎么快速查询快递单号的物流,并筛选出更新量为1的单号呢?今天小编给大家分享一个新方法,一起来试试吧。需要哪些工具?安装一个快递批量查询高手多个快递单号怎么快速查询?运行【快递批量查...

掌握批量查询快递动态的技巧,一键查找无信息记录的两种方法解析

在快节奏的商业环境中,高效的物流查询是确保业务顺畅运行的关键。作为快递查询达人,我深知时间的宝贵,因此,今天我将向大家介绍一款强大的工具——快递批量查询高手软件。这款软件能够帮助你批量查询快递动态,一...

从复杂到简单的单号查询,一键清除单号中的符号并批量查快递信息

在繁忙的商务与日常生活中,快递查询已成为不可或缺的一环。然而,面对海量的单号,逐一查询不仅耗时费力,还容易出错。现在,有了快递批量查询高手软件,一切变得简单明了。只需一键,即可搞定单号查询,一键处理单...

物流单号查询,在哪里查询快递

如果在快递单号多的情况,你还在一个个复制粘贴到官网上手动查询,是一件非常麻烦的事情。于是乎今天小编给大家分享一个新的技巧,下面一起来试试。需要哪些工具?安装一个快递批量查询高手快递单号怎么快速查询?...

取消回复欢迎 发表评论: