ご挨拶
Link-Uの技術開発部の部長をやっております土屋と申します。
サーバーサイド担当でAPIや管理画面の開発を主に行っています。
Link-Uでは今年から技術開発部のメンバーでアドベントカレンダーをやることにしました。
今回やろうと決めた理由としては1人1記事書けるだけのメンバーが揃ってきたというのと、
今まで特にアウトプットをしていないのもあり弊社を知って頂く一つのきっかけになれば良いなと思って企画しました。
技術開発部は
- クライアント班(スマホネイティブアプリやWebフロント)
- インフラ班(サーバー機器、ネットワークなど)
- サーバー班(API、管理画面など)
の3つに分かれており今回参加してくれるメンバーも各班からお願いしました。
皆がどういうことを書いてくれるのか楽しみにしています。
とりあえず先頭バッターとして私の方では内製ツールの紹介をしていきます。
fabistranoの紹介
Fabric + Capistrano から名前を取っておりそれらの機能を元に開発したデプロイツールです。
なぜPythonを選んだかと言うと
- Ubuntuで標準インストールされている
- ansibleを使うためやっぱりインストールされている
- プラグインが書きやすい
- インストールが簡単
- PHPのサービスが多いのでデプロイ時に差分やブランチを確認したい
特に最後のは重要でした。
今でこそデプロイも自動化されつつありますが、複数人で開発していると誰がどのブランチをデプロイしているのか、どこまでデプロイしているのかわからないことが多々ありました。下の方でもう少し詳しく書きます。
インストール方法
fabistranoはpipでインストール出来ます(privateリポジトリなので関係者じゃないとDLできませんが)
$ pip install git+ssh://git@github.com/link-u/fabistrano.git
依存ライブラリ
colorful
https://github.com/timofurrer/colorful
CLIの表示をわかりやすくするために利用しています。
PyYAML
https://github.com/yaml/pyyaml
各サーバーへの接続情報はYAML形式で設定しています。
click
https://click.palletsprojects.com/en/7.x/
コマンドのオプションの管理やサブコマンド化をするのが楽なので利用しています。
機能紹介
デプロイ先どういう状態問題
例えばdev環境を一時的に別のブランチに切り替えたいとか問題解決のため一瞬だけ何か修正を入れたいとかそういうケースがあると思います。
PHPの場合はスクリプト言語なので設置されているファイルの通りに動きます。そのためサーバーにログインし、直接編集することもあると思います。
複数人による作業や様々な環境依存による問題が発生する開発現場において、fabistranoでは極力事故を無くす為の機能が備わっています。
デプロイ先が環境別に記載されているconfig
IPやポートを間違えると他のサービスに影響を出してしまう可能性があります。プロジェクトで共有が出来る形になっており、デプロイ時はaliasを指定するだけです。
git status確認機能
gitのコミット漏れやpush忘れがあった場合に、警告を出してくれます。
branch確認機能
既にデプロイされているリモートホストのbranchとこれからデプロイしようとしているbranchが違う時に警告を出します。
差分確認機能
削除されたファイルや変更のあったファイルの一覧が色付きで表示されます。
差分詳細確認機能
デプロイした日時や人(git configの情報)を記録
よくわからない差分を見つけた時に誰に聞けば良いのかすぐにわかります。
プラグインによる機能拡張
管理画面などはwebpackでJSをビルドしないといけなかったりします。
それらをデプロイコマンドにインクルードすることが出来ます。
そうすることで必ず必要なビルド作業を強制させることが出来ます。
デプロイコマンドを上書きする例
# -*- coding: utf-8 -*-
import click
import invoke
import fabistrano
from fabistrano.commands.deploy import deploy as orig_deploy
@click.command(help=u'APPデプロイを行う')
@fabistrano.deploy_options
@click.option('--skip-build', help=u'yarn build をスキップします', is_flag=True, default=False)
@click.option('--skip-composer', help=u'composer installをスキップします', is_flag=True, default=False)
@click.pass_context
def deploy(ctx, config, ignore_git, ignore_diff, force, apply_force, skip_composer, skip_build):
"""
通常のデプロイ操作に加えてcomposer install, buildを行う
"""
if not skip_build:
c = invoke.Context()
with c.cd(config.env.local_root_dir + '/front-end'):
c.run('yarn build', pty=True)
# --no-devオプションを付与しない環境名のリスト
dev_envs = []
if not skip_composer:
c = invoke.Context()
if config.env.env_name in dev_envs:
with c.cd(config.env.local_root_dir):
c.run('COMPOSER_VENDOR_DIR=vendor ./composer.phar install', pty=True)
else:
with c.cd(config.env.local_root_dir):
c.run('COMPOSER_VENDOR_DIR=vendor-no-dev ./composer.phar install --no-dev', pty=True)
kwargs = {
'config': config,
'ignore_git': ignore_git,
'ignore_diff': ignore_diff,
'force': force,
'apply_force': apply_force,
}
ctx.invoke(orig_deploy, **kwargs)
所定のディレクトリに [コマンド名].py
と言うファイルを配置すると自動的にコマンド化してくれます。
既存のコマンドを上書き出来たり新規コマンドを簡単に追加することが出来たりします。
ただしこの機能はあまり使われておらず開発者である自分も使っていません
まとめ
ざっくりですがfabistranoの紹介をさせて頂きました。
いつかローカライズ対応してオープンソース化出来たら良いなと思っております。
Link-Uではサービスはもとより、内製ツールも作れる人を募集しています。
興味を持って頂けた方は弊社の採用ページよりご応募下さい!
https://www.link-u.co.jp/recruit/