数百万件のレコードをMySQLにインポートする方法

activerecord-import という gem を使用すると、大量のレコードを mysql テーブルにインポートする作業が簡単になります。この投稿では、それを実現する方法を説明します。

Rails を 5.0 から 5.1 にアップグレードする

アプリケーション Rails のバージョンを 5.0 から 5.1 にアップグレードするのは、マイナー バージョン アップデートだけなので、4.2 から 5.0 よりも簡単です。ただし、フレームワークの変更や古い gem 依存関係が原因で、対処すべき問題がまだかなり残っている可能性があります。

Ruby rspec

RSpec は Ruby で人気のあるテスト フレームワークです。

Rails の自動ロードはスレッドセーフではありません

Rails フレームワークは定数を自動ロードするため、developmenttest などの環境では、リクエストを処理する前にアプリがすべてをメモリにロードする必要がありません。ただし、自動ロードは Rails ではスレッドセーフではないことが知られています (少なくともバージョン 6 未満の場合)。また、pumawebrick などのスレッド サーバーを使用している場合は、複数のスレッドによって予期しない問題が発生する可能性が非常に高くなります。

Rails を4.2から5.0にアップグレード

Rails を新しいメジャー バージョンにアップグレードするのは難しい場合があります。フレームワーク自体に多くの重大な変更があったり、プロジェクトで使用されている多くの gem が廃止またはサポート対象外になったりする可能性があるためです。ただし、正しい手順で実行すれば、スムーズに進むこともあります。この記事では、API サーバーの Rails を 4.2.11 から 5.0.7.2 にアップグレードした最近の実践的な経験に基づいて手順を紹介します。プロジェクトの構成や依存関係によっては、プロジェクトごとにアップグレード手順が若干異なる場合があることにご注意ください。

クッキーを使用した Ruby http リクエスト

クッキーを使用した Ruby http リクエスト。

Ruby parallel gem の使用例

Ruby parallel gem の使用例。

Ruby rack

Rack は、Ruby の世界において Web フレームワーク (ruby on railssinatra) と Web サーバー (webrickpumaunicorn) 間のインターフェースを提供する gem です。

Ruby rake

Rake は Ruby の Make のようなタスク ランナーです。まず Rakefile で ruby​​ 構文でタスクのリストを定義し、次に rake コマンドでタスクを呼び出します。

Ruby bundler

Bundler は Ruby プロジェクトにおける依存関係管理用です。