Skip to content
  • About
    • What is Symfony?
    • Community
    • News
    • Contributing
    • Support
  • Documentation
    • Symfony Docs
    • Symfony Book
    • Screencasts
    • Symfony Bundles
    • Symfony Cloud
    • Training
  • Services
    • Platform.sh for Symfony Best platform to deploy Symfony apps
    • SymfonyInsight Automatic quality checks for your apps
    • Symfony Certification Prove your knowledge and boost your career
    • SensioLabs Professional services to help you with Symfony
    • Blackfire Profile and monitor performance of your apps
  • Other
  • Blog
  • Download
sponsored by
  1. Home
  2. Documentation
  3. Symfony: The Fast Track
  4. Japanese
  5. コードをブランチ運用する

コードをブランチ運用する

プロジェクトにおいてコード変更のワークフローを整理する方法は数多く存在します。しかし、Git の master ブランチで直接作業し、テストすること無しにそのまま本番環境にデプロイする方法はおそらく最善策ではありません。

テストするということは、ユニットテストやファンクショナルテストを実行することだけでなく、アプリケーションの振る舞いを本番データを使って確認することも意味します。アプリケーションがエンドユーザーにデプロイされた時に、あなた自身や ステークホルダー がブラウザで確認できるのであれば、そのことは大きなアドバンテージであり、自信を持ってデプロイすることが可能となります。非技術者が新機能を検証できることはとても心強いことです。

次のステップでは、単純化と冗長な記述を避けるために Git の master ブランチ上で全ての作業を続けますが、どうやってより良くするか見ていきましょう。

Git のワークフローを取り入れる

ワークフローの一例として、新しいフィーチャーやバグ修正毎にブランチを作成する方法があります。これは単純で効果的なやり方です。

ブランチを作成する

このワークフローは、Git ブランチの作成から始まります:

1
$ git branch -D sessions-in-db || true
1
$ git checkout -b sessions-in-db

このコマンドで master ブランチから sessions-in-db ブランチを作成します。そうすることで、コードとインフラストラクチャの設定を "フォーク" します。

データベースにセッションを格納する

ブランチ名から推測できるかもしれませんが、セッションストレージをファイルシステムからデータベース (PostgreSQL) に変更したいと考えています。

それを実現するために必要な手順は典型的なものです:

  1. Git ブランチを作成します。
  2. 必要に応じて Symfony の設定を変更します。
  3. 必要に応じてコードの追加や編集を行います。
  4. Update the PHP configuration if needed (like adding the PostgreSQL PHP extension);
  5. 必要であればDocker と Platform.sh 上のインフラストラクチャを変更します(PostgreSQL サービスを追加します)。
  6. ローカルでテストします。
  7. リモートでテストします。
  8. master ブランチにマージします。
  9. 本番環境にデプロイします。
  10. ブランチを削除します。

セッションをデータベースに保存するには、 session.handler_id をデータベースDSNを指すように変更します。

1
2
3
4
5
6
7
8
9
10
11
--- a/config/packages/framework.yaml
+++ b/config/packages/framework.yaml
@@ -7,7 +7,7 @@ framework:
     # Enables session support. Note that the session will ONLY be started if you read or write from it.
     # Remove or comment this section to explicitly disable session support.
     session:
-        handler_id: null
+        handler_id: '%env(DATABASE_URL)%'
         cookie_secure: auto
         cookie_samesite: lax
         storage_factory_id: session.storage.factory.native

セッションをデータベースに保存するには、 sessions テーブルの作成が必要です。 Doctrineマイグレーションを使って作成します:

1
$ symfony console make:migration

up() メソッドにテーブル追加の記述をおこないます:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
--- a/migrations/Version00000000000000.php
+++ b/migrations/Version00000000000000.php
@@ -21,6 +21,14 @@ final class Version00000000000000 extends AbstractMigration
     {
         // this up() migration is auto-generated, please modify it to your needs

+        $this->addSql('
+            CREATE TABLE sessions (
+                sess_id VARCHAR(128) NOT NULL PRIMARY KEY,
+                sess_data BYTEA NOT NULL,
+                sess_lifetime INTEGER NOT NULL,
+                sess_time INTEGER NOT NULL
+            )
+        ');
     }

     public function down(Schema $schema): void

データベースのマイグレーションを行います:

1
$ symfony console doctrine:migrations:migrate

Web サイトを閲覧してローカルでテストしてください。セッションをまだ利用しておらず見た目の変更がないので、全てこれまでと同じように機能するはずです。

Note

We don't need steps 3 to 5 here as we are re-using the database as the session storage, but the chapter about using Redis shows how straightforward it is to add, test, and deploy a new service in both Docker and Platform.sh.

新しいテーブルは Doctrine で管理しないので、次のデータベースマイグレーションでテーブルを削除しないように Doctrine を設定しなければいけません。

1
2
3
4
5
6
7
8
9
10
11
--- a/config/packages/doctrine.yaml
+++ b/config/packages/doctrine.yaml
@@ -5,6 +5,8 @@ doctrine:
         # IMPORTANT: You MUST configure your server version,
         # either here or in the DATABASE_URL env var (see .env file)
         #server_version: '13'
+
+        schema_filter: ~^(?!session)~
     orm:
         auto_generate_proxy_classes: true
         naming_strategy: doctrine.orm.naming_strategy.underscore_number_aware

新しいブランチに変更をコミットします:

1
2
$ git add .
$ git commit -m'Configure database sessions'

ブランチをデプロイする

本番環境にデプロイする前に、本番環境と同一のインフラストラクチャでこのブランチをテストすべきでしょう。また、 Symfony の prod 環境で全てが正常に動作することを検証すべきです(ローカルの Web サイトでは Symfony の dev 環境を利用していました)。

では、 Git ブランチ に基づいた Platform.sh 環境 を作成しましょう:

1
$ symfony cloud:env:delete sessions-in-db
1
$ symfony cloud:deploy

このコマンドで以下の新しい環境を作成します:

  • このブランチは現在の Git ブランチ (sessions-in-db) のコードとインフラストラクチャを引き継ぎます。
  • データベースやファイル(例えばユーザーがアップロードしたファイルです)を含む全サービスのデータについて一貫したスナップショットを取得することにより、マスタ環境(本番環境)からデータが取得されます。
  • コード、データ、インフラストラクチャをデプロイするために専用のクラスターが新たに作成されます。

今回のデプロイは本番へのデプロイと同じ手順に従うため、データベースのマイグレーションも実行されます。これは本番のデータでマイグレーションが機能することを検証するための良い方法です。

非 master 環境は master 環境と非常に良く似ていますが、多少の差分が存在します。例えば、メールはデフォルトでは送信されません。

デプロイが完了したら、新しいブランチをブラウザで開きます:

1
$ symfony cloud:url -1

すべての Platform.sh コマンドは現在の Git ブランチ上で動作することに気付きましたか?このコマンドを実行すると sessions-in-db ブランチのデプロイ URL が開きます。URL は https://sessions-in-db-xxx.eu-5.platformsh.site/ となります。

新しい環境の Web サイトをテストしてみてください。マスタ環境で作成した全てのデータを確認できるはずです。

master 環境でさらにカンファレンスを追加した場合、sessions-in-db 環境には表示されません。その逆の場合も同様です。各環境は独立しており、隔離されています。

もし master 上のコードが更新されていたら、コードとインフラストラクチャのコンフリクトを解消して、Git ブランチをリベースし、最新のバージョンをデプロイすることができます。

マスタ環境から sessions-in-db 環境にデータを同期することも可能です:

1
$ symfony cloud:env:sync

デプロイ前に本番のデプロイをデバッグする

すべての Platform.sh 環境はデフォルトで master/prod 環境(Symfonyの prod 環境)と同じ設定を利用しています。これによって、実際の条件でアプリケーションをテストすることが出来ます。本番サーバー上で直に開発とテストを行っている感覚になりますが、リスクはありません。FTP経由でデプロイしていた古き良き時代を思い出させますね。

何か問題が起きた時に、Symfony の dev 環境に切り替えたくなるかもしれません:

1
$ symfony cloud:env:debug

問題が解決した後は、本番設定に戻しておきましょう:

1
$ symfony cloud:env:debug --off

Warning

master ブランチ上では、決して dev 環境を有効化したり Symfony プロファイラを有効化したりしないでください。アプリケーションの動作がとても重たくなり、セキィリティ上の深刻な脆弱性が多く発生してしまいます。

デプロイ前に本番のデプロイをテストする

次期バージョンの Web サイトを本番データでアクセスすることで、見た目の回帰テストから性能テストに至るまで、多くの事を確認できます。`Blackfire`_ はこの仕事をやる上で完璧なツールです。

Blackfireを使ってデプロイ前にコードをテストする方法をもっと学ぶためには、Performance に関する手順を参照してください。

本番へマージする

ブランチの変更内容に問題が無ければ、コードとインフラストラクチャを Git の master ブランチにマージしてください:

1
2
$ git checkout master
$ git merge sessions-in-db

そしてデプロイを実行します:

1
$ symfony cloud:deploy

デプロイされると、コードとインフラストラクチャの変更のみ Platform.sh にプッシュされます。データは一切影響を受けません。

クリーンアップする

最後に、Git ブランチ と Platform.sh 環境を削除してクリーンアップします:

1
2
$ git branch -d sessions-in-db
$ symfony cloud:env:delete -e sessions-in-db

より深く学ぶために

  • Git ブランチ;
Previous page ユーザーインターフェースを構築する
Next page イベントをリッスンする
This work, including the code samples, is licensed under a Creative Commons BY-NC-SA 4.0 license.
TOC
    Version

    Symfony 5.4 is backed by

    Get your Sylius expertise recognized

    Get your Sylius expertise recognized

    Be trained by SensioLabs experts (2 to 6 day sessions -- French or English).

    Be trained by SensioLabs experts (2 to 6 day sessions -- French or English).

    Version:
    Locale:
    ebook

    This book is backed by:

    see all backers

    Symfony footer

    Avatar of Robin Lehrmann, a Symfony contributor

    Thanks Robin Lehrmann for being a Symfony contributor

    2 commits • 103 lines changed

    View all contributors that help us make Symfony

    Become a Symfony contributor

    Be an active part of the community and contribute ideas, code and bug fixes. Both experts and newcomers are welcome.

    Learn how to contribute

    Symfony™ is a trademark of Symfony SAS. All rights reserved.

    • What is Symfony?

      • What is Symfony?
      • Symfony at a Glance
      • Symfony Components
      • Symfony Releases
      • Security Policy
      • Logo & Screenshots
      • Trademark & Licenses
      • symfony1 Legacy
    • Learn Symfony

      • Symfony Docs
      • Symfony Book
      • Reference
      • Bundles
      • Best Practices
      • Training
      • eLearning Platform
      • Certification
    • Screencasts

      • Learn Symfony
      • Learn PHP
      • Learn JavaScript
      • Learn Drupal
      • Learn RESTful APIs
    • Community

      • Symfony Community
      • SymfonyConnect
      • Events & Meetups
      • Projects using Symfony
      • Contributors
      • Symfony Jobs
      • Backers
      • Code of Conduct
      • Downloads Stats
      • Support
    • Blog

      • All Blog Posts
      • A Week of Symfony
      • Case Studies
      • Cloud
      • Community
      • Conferences
      • Diversity
      • Living on the edge
      • Releases
      • Security Advisories
      • Symfony Insight
      • Twig
      • SensioLabs Blog
    • Services

      • SensioLabs services
      • Train developers
      • Manage your project quality
      • Improve your project performance
      • Host Symfony projects

      Powered by

    Follow Symfony