前回の記事 からだいぶ間が開いてしまいましたが、再びこのブログの移行のお話です。

WordPress から Middleman への移行に伴って、記事の構成管理やホスティング、デプロイについても検討して、現在は以下のようなものを使って運用しています。

記事の執筆とレビュは、GitHub の Pull Request 機能を使うようになりました。これまでは WordPress 上の慣れないエディタで書くのが嫌だったり、書いた記事を非公開の状態でレビュしてもらうのに地味〜に手間がかかったりと、執筆のモチベーションを下げる要因がいろいろあったのですが、普段から開発で利用しているPRのしくみを取り入れたことで、開発チームではやりやすい方法に向かえたのではないかと思っています。まぁその割に記事数は増えていませんね(笑)

GitHub Pages にホスティング

Middleman で構築したブログの運用として同様の組み合わせで、GitHub Pages にホスティングし、TravisCI で自動デプロイを行っているケースは多く拝見しました。このブログの構築でも大変参考にさせていただきました。

これもずいぶん時間が経ってしまいましたが、社内勉強会にて、同様の環境を利用して自分の個人サイトを運用している話を発表しましたので、基本部分についてはスライドでご紹介させていただきます。

Middlemanで個人ページを作っている話

スライドでは、GitHub Pages の機能でも "User Page" という機能を利用した方法について発表しました。このブログではブランチ構成が異なる "Project Page" の機能を利用して、gh-pages ブランチをサイト公開用のブランチとして利用する方法を採用しています。

CircleCI でデプロイ

個人では TravisCI を利用していましたが、社内では CI ツールとして CircleCI の利用が広まってきたのでそちらに乗り換えました。CI ツールの設定ファイルに書く内容はどちらもだいたい同じで、CircleCI では以下のようにしています。

# circle.yml
general:
  branches:
    ignore:
      - gh-pages

machine:
  timezone: Asia/Tokyo

dependencies:
  pre:
    - npm install -g bower
    - bower install

test:
  override:
    - bundle exec middleman build

deployment:
  publish:
    branch: master
    commands:
      - git config --global user.name "circleci"
      - git config --global user.email "circleci@feedforce.jp"
      - bundle exec middleman deploy

ポイントは、以下のような部分です。

  • 公開用ブランチである gh-pages は処理対象から除外
  • CircleCI の test は middleman build で代用
  • middleman-deploy gem を導入し、デプロイを設定+ワンラインで解決

これで、トピックブランチはすべてtestまで実行され、master ブランチにマージされたものは自動的に gh-pages ブランチにデプロイされます。

ただしこのままだと、 gh-pages ブランチにコミットされたものを CircleCI が無視することができず、おかしなデプロイが走ってしまいます。これを防止するために Middleman の source ディレクトリのなかに、build後に gh-pages ブランチ用の circle.yml ファイルが残るように、以下のファイルを配置します。

# source/circle.yml
general:
  branches:
    ignore:
      - gh-pages

また、CircleCI では test が無いと警告が出てしまうため middleman build を実行していますが、実際のところこれはかなり無駄なことをしています。CircleCI はいくつかのフレームワークを判断して、とくに設定などを書かなくても自動で適当な compile などを実施してくれます。Log を見ると、build コマンドが2回実行されているのがわかります。

これをもっと良さげに解決する方法はいくつかあります。test 内でコマンドの実行結果が正常終了と判断されるようにすれば良いです。ただ今回はいちおうのテストとして「静的ファイルが build できること」を確認するものとして、この記述を残しました。こじつけですね。

まとめ

導入した middleman-deploy gem の設定やその他設定、実際のPRの様子は、このブログのリポジトリで見ることができます。何かのご参考になれば幸いです。

最近では Tachikoma.io を利用した自動 bundle update も行うようになりました
春には Middleman v4 のリリースもあるし楽しみです。硝煙にまみれたゆるふわフロントエンジニア氏の関心は別のフレームワークに移っているようですが…それはそれで楽しみです٩(๑❛ᴗ❛๑)۶

  • このエントリーをはてなブックマークに追加
Feedforce Developer Blog

新しいブログへ移行しました!こちらもよろしくお願いします。