流行のものをモリモリとりこんで開発してみよー。
・・・と思ったが、ここ10年Javaメインのプロジェクトしか参画していなかった自分に、最近の流行開発など経験もなく、死角しかなかったのであったorz
そんなわけで、
『レガシーSIエンジニアのための最近の流行おいつき講座(第1話。記事に反応なければ最終話)』
はっじめっるよー。
ちなみにこちらは構築編で、BlueMix自体に対する考察とかアーキテクチャとか設計思想についてはBlogの方で記載します。興味がある人はこちらもどうぞ(IBM Garrage Methodを見て感じたITシステムのアーキテクトの変遷(と今後)について)。
無料のBlueMix環境を扱ってみる
この記事シリーズではBlueMixというサービスをつかってみるので、BlueMixについて。
BlueMixはIBM社が提供しているクラウド上の開発&サーバ基盤提供サービスです。
説明が難しいので、他の記事を参照して下さい。
※BlueMixは1ヶ月間のフリーとWEBページには記載していますが、実は無料用の機能を使う分には実質的な無料利用できるとか(クレジットの登録は必要なので、有料機能を使った時点で課金が発生してしまいますのでご注意を!)参考文献
BlueMixを味見程度に使うとしても、ソース自体はGITに公開保存もできるので、気軽に使えばいいのではと思ったり。ただし、使い方を誤って期待しない課金されても当方は一切の責任は負えないので自己責任でやってね(キリッ
BlueMixへの登録がまだな人はこの辺で。 BlueMixの登録方法の紹介記事
前提方針
サーバー立てるのがめんどくさいので、当分はBlueMixをつかってみることを前提とする。
そんなわけで2~3時間つかって調べてみた「ぼくのかんがえるさいきょうのJS試験環境」を発表します。(おー、パチパチ)
- 検証サーバー:BlueMix
- 統合開発環境onBlueMix:ToolChain+α *1
- ローカル開発環境:Eclipse(NEON)+α *2
*1 ToolChainという統合開発は、最近、試験版が出たばかりで、開発チームにメールを送らないとつかえないという、メンドクサイやつ。しかしながら、ちょっと触ってみた感じ、次世代の開発環境っぽい有効性を感じたので、味見がてら試してみようというものです。試作1号機と聞くとガンダムGPXXとかエヴァンゲリオンX号機っぽくてかっこいいので今回の環境として採用してみた。試作機だけあって、使えるメニューはまだ少ないです。
*2 JavaScript開発環境というと、VIMとかSublineXXXXとかオシャレなエディタが増えているので二番煎じでもいいかなーと思ったが、丁度、NEONが発表され、Node.js ランタイム
JavaScript デバッガ、JSONエディタにも対応してきたとのことで、味見がてら試してみようというものです。リリース直後の量産品と聞くと、エヴァ量産期という感じがしてキモイ性能向上がありそうなので怖いけど、人柱的な気分でチャレンジ採用してみた。もっさりしてなければいいけどー。とはいえ、リリース直後だけあって、世の中の情報がまだ少ないのでジタバタしてます。
今回は、まず環境の初期構築としてtoolChainの構築編だす。ふんだす。
ToolChainって何?
このへんがわかりやすい。
まだ詳細な解説については、日本語では無い模様(2016/7/30・Maru0kaリサーチ社調べ)。
英語をざっくり翻訳すると、「アイデアソン用のMURALとか、タスク管理のGIT Issuesとか、ソース管理のGUT HUBとか、リリース管理のJENKINSEとか、いろいろバラバラに使うのめんどいじゃん!? だったら、統合的に使えるアレがあると、いい感じに使いやすいじゃん」という理論に基づいた「アレ」の部分を示すもの・・・らしいです。
ToolChainを使ってみる
本家はここです。
翻訳版ではなく、実体験がてらに使い方を解説するよ。
※ToolChainは拡張される可能性があり、構成切り替えにより他の環境に影響するかもしれないらしいので(リンク先のtoolChainをつかえるようにするための申請メールにそれっぽい記載があった)、BlueMixを商用で利用している人は、そのアカウントとは別のアカウントでやったほうが無難かも。
今回はシンプルなToolChainを作ってみましょう。
ToolChainを使うにはまず、サイトにログインするべし。
- ここにアクセス。参考文献:Simple ToolChain ここで、Create ToolChainのボタンをおす。(押した後、BlueMixにログインする必要があります。)
-
ログインすると謎の動画とボタンがあると思いますが、このボタンはメール送信リンクになっています。この送信ボタンを押すことで、ToolChainが使えるようになるとか。
- 1週間後ぐらいに「できたよー」という英語のメールがとどくはず。
- んで、もういちどはじめのリンクを押すとこんなんでるはず。
- こんなん。その後で、Createボタンを押す
この時点で、アプリ実行環境は完成しています。内容を簡単に説明しておきましょう。
-
Issues このアイコンはGIT HUB Issuesとリンクできます。このアイコンあたりをクリックすると当該のIssuesに飛びます。飛ばないときは、設定を変えてリンクを定義する必要があります。
GIT HUB このアイコンはGIT HUB(ソースリポジトリ)とリンクできます。このアイコンあたりをクリックすると(以下略)。
-
Eclipse Orion Web IDE このアイコンはWEB上でソースコードの修正、GIT HUBへのPushができるもの。便利なんだけど、複数人で修正するには競合の問題があるので、少し難あり。それについてはこのへんの最後のほうのスライドでも言及しています。なるほど。
- とりあえず、この環境が気になる人はこのアイコンをクリックしてソース構造を見てみるといいかも。実態がNodeJSベースでできていることに気づくでしょう。
-
Delivery Pipeline このアイコンはBlueMixサーバへのリリースの自動化を担当します。どうやら、Delivery Pipelineの内部はJenkinsだそう(どこかのWebニュースで見ただけなので眉唾情報だけど)
てなわけで、お手軽にコーディング&リリース環境ができるわけです。
ToolChainを機能拡張してみる
アイコンの呼び方がわからないので、ここではアイコンのようなものをコマとよぶ。
深い意味は無い。
デフォルトではGITとかPilelineとかがあるが、更にふやすことができます。
今回は、皆で管理することを意識して、リリース時にSlackに通知される機能を作ってみましょう。
-
- これはSlackとリンク付けるもの。
- ここにアクセスして、緑色のGenerate Tokensを選ぶと、次のページに遷移する。
- ここの「Token」のアドレスと、対象Slackのチャネル#XXXXのXXXX部分を入れると認証される。
このTokeとチャネルの値をBlueMix ToolChainにセットする。
よし、これでサーバ側の作業がSlackで通知されたぞ。
一人だけど、いつかみんなで開発するときに役立てよう。
まとめ
コードを1行も書かずに、クリックだけで、Issue管理、ソース管理、リリース構成、サーバリリース(公開)環境、Slackでの状況管理までできました。
これは意外にすごい便利なツールなんじゃないか?
※今のところはBlueMix上のDevOpsと関連していない模様なのが玉に傷。きっと、試作機だからさ!