コンテンツにスキップ

設計原則

Paideia LMSは、開発を導き、プラットフォームが約束を果たすことを保証する6つの核となる設計原則の上に構築されています。これらの原則は、Paideiaを作成した理由、解決する問題、Paideiaがあなたの機関にとって最良の選択肢となるであろう理由を説明します。

Paideiaは最初から最新技術とベストプラクティスで構築されています。 これは、レガシーコードなし、技術的負債なし、古いパターンをサポートする必要がないことを意味します。私たちは、パフォーマンスが高く、保守性が高く、将来性のある技術を選択しました。

対照的に、MoodleやCanvasなどの従来のLMSプラットフォームは、古い技術で何年も前に構築されました。何年もの開発で技術的負債が蓄積され、保守が困難になり、更新が遅くなり、デプロイが複雑になっています。これらのプラットフォームは、パフォーマンスの問題、セキュリティの脆弱性に苦労し、維持に多大なリソースが必要です。

Paideiaのモダンな技術スタック — Bunランタイム、React Router v7、Elysia、TypeScript — により、最新のWeb標準とともに進化できるパフォーマンスの高い保守可能なプラットフォームを提供できます。モダンな技術への焦点により、今日のニーズと明日の機会のために構築されたプラットフォームを提供できます。

PaideiaはReactを中心とした堅固な基盤の上に構築されています。 私たちはReactを選択しました。それは、実績があり、広く採用されており、大規模なエコシステムがあるためです。Mantineコンポーネントと組み合わせることで、強力でアクセスしやすい一貫性のあるモダンなUIを提供します。

私たちのアーキテクチャ決定は最初から本番グレードです。私たちは以下を使用します:

  • 包括的な型生成を伴う型安全なTypeScript
  • try-catchブロックの代わりに結果ベースのエラーハンドリング
  • データ整合性のためのトランザクションベースのデータベース操作
  • 非破壊的で後方互換性のあるマイグレーション
  • 内部関数でゼロ型キャストの厳格なコーディング標準

この堅牢な基盤は、Paideiaが信頼性が高く、保守可能で、最初から本番使用の準備ができていることを意味します。プラットフォームを「強化」するのを待つ必要はありません — それは最初からエンタープライズグレードの実践で構築されています。

Paideiaはすぐに使える包括的なLMS機能を提供します。 わずか30日の開発で、すべての基本的なLMS機能をカバーする27のデータベースコレクションを持つ完全な学習管理システムを構築しました。

Paideiaには以下が含まれます:

  • セクションとカテゴリを持つコース管理
  • ロールベースのアクセス制御(管理者、コンテンツマネージャー、分析ビューアー、インストラクター、学生)を持つユーザー管理
  • アクティビティモジュール:ページ、ホワイトボード、課題、クイズ、ディスカッション
  • ドラッグアンドドロップインターフェースを持つ高度なクイズビルダー
  • カテゴリとアイテムを持つ成績簿システム
  • グループを持つ登録管理
  • S3統合を持つメディアストレージ
  • 検索機能
  • 外部ツールとのシームレスな統合のためのLTI(Learning Tools Interoperability)サポート
  • プラットフォームに組み込まれたAIネイティブ機能
  • 組み込みMicrosoft統合(Teams、OneDrive、Office 365)

プラグインや広範な設定を必要とする他のプラットフォームとは異なり、Paideiaは機能が完全な状態で提供されます。プラグインを探したり、互換性を心配したり、複雑な依存関係を管理したりする必要はありません。

Paideiaは単一バイナリとしてデプロイされます — ダウンロードして実行します。 この設計は、バックエンドアプリケーションのデプロイ方法を革新した最も人気のあるオープンソースプロジェクトの1つであるPocketBaseにインスピレーションを得ています。複雑なセットアップなし、設定する複数のサービスなし、依存関係管理なし。プラットフォーム(macOS ARM64、Linux ARM64、またはLinux x64)用のバイナリをダウンロードし、実行可能にして、実行するだけです。

これは、以下を必要とする従来のLMSプラットフォームとは対照的です:

  • 複数のサービス(Webサーバー、データベース、アプリケーションサーバー)
  • 複雑な設定ファイル
  • 依存関係管理
  • バージョン互換性の懸念
  • 継続的なメンテナンスと更新

Paideiaでは、デプロイは数時間や数日ではなく、数分の問題です。PostgreSQLデータベースとS3互換ストレージを起動し、環境変数を設定すれば、準備完了です。単一バイナリアプローチは、環境間で一貫した動作と簡単な更新を意味します — バイナリを置き換えるだけです。

PaideiaはPostgreSQLとS3を基盤として使用します — 最小限のフットプリントですが、驚異的にスケーラブルです。 PostgreSQLは利用可能な最も信頼性が高くスケーラブルなデータベースの1つで、あらゆる規模の企業に信頼されています。S3互換ストレージは、業界標準の信頼性で無制限のストレージ容量を提供します。

このアプローチは以下を意味します:

  • 小さなフットプリント: Paideia自体は軽量で、インフラストラクチャ(PostgreSQL + S3)はあらゆる本番システムで使用するものです
  • 大規模なスケーラビリティ: PostgreSQLは数百万のレコードを処理し、S3はエクサバイトまでスケールします
  • 実証済みの信頼性: 両方の技術は世界中の本番環境で実績があります
  • コスト効率: 使用した分だけ支払い、スケールする際にコストを最適化できます

100人の学生をサービスする場合でも100,000人をサービスする場合でも、Paideiaのアーキテクチャはあなたとともにスケールします。データベースとストレージレイヤーは成長を処理するように設計されており、Paideiaの効率的なクエリは、データが成長しても一貫したパフォーマンスを保証します。

PaideiaはMoodleやCanvasを悩ませるプラグインアーキテクチャを回避します。 互換性の問題、管理のオーバーヘッド、セキュリティ上の懸念につながるプラグインシステムの代わりに、Paideiaにはすべての重要な機能が組み込まれています。

プラグインアーキテクチャを持つ従来のLMSプラットフォームは、いくつかの問題に直面しています:

  • プラグインの互換性: 更新がプラグインを壊す可能性があり、継続的なメンテナンスが必要
  • セキュリティの脆弱性: 各プラグインは潜在的なセキュリティリスク
  • 管理のオーバーヘッド: プラグイン、更新、依存関係を追跡する必要
  • パフォーマンスの問題: 不適切に書かれたプラグインはシステム全体を遅くする可能性
  • ベンダーロックイン: 一部のプラグインは商用のみで、コストがかかる

Paideiaのアプローチは異なります。すべての重要な機能が組み込まれているため、コア機能にプラグインは必要ありません。これは以下を意味します:

  • 互換性の懸念なし
  • より良いセキュリティ(動く部品が少ない)
  • より簡単な管理
  • 一貫したパフォーマンス
  • ベンダーロックインなし

カスタム機能が必要な場合、Paideiaのモダンなコードベースは拡張が容易です。しかし、MoodleやCanvasとは異なり、基本機能にプラグインは必要ありません — すべてが含まれています。

Paideiaは完全にステートレスです — すべてのデータはPostgreSQLとS3に保存されます。 このステートレス設計は、Paideiaがサーバー自体にデータや状態を保存しないことを意味します。すべて — コース、ユーザー、課題、成績、メディアファイル — はPostgreSQL(構造化データ用)とS3(メディアとファイル用)に保存されます。

このアーキテクチャは、いくつかの利点をもたらします:

  • 大規模なスケーラビリティ: サーバー上にデータがないため、より多くのアプリケーションインスタンスを追加するだけで、Paideiaを数百万のユーザーにスケールできます。データベースとストレージレイヤーは独立してスケールを処理します。

  • 簡単な移行: サーバー上に何も保存されていないため、Paideiaの移行は非常に簡単です。新しいPaideiaインスタンスを同じPostgreSQLデータベースとS3ストレージに向けるだけで完了です。データのエクスポート/インポート、複雑な移行スクリプトは不要です。

  • 高可用性: ステートレス設計は、ロードバランサーの背後で複数のPaideiaインスタンスを実行できることを意味します。1つのインスタンスがダウンしても、他のインスタンスはシームレスにリクエストを処理し続けます。

  • ゼロダウンタイムデプロイ: バイナリを置き換えてサービスを再起動するだけでPaideiaを更新します。データはPostgreSQLとS3に独立して存在するため、データ移行は不要です。

なぜPaideiaが構築されたかと、これらの原則があなたの機関にどのように利益をもたらすかについて詳しく学びます。
Ask DeepWiki
貢献する コミュニティ スポンサー