SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

トップエスイーからのアウトカム ~ ソフトウェア工学の現場から

クラウド上での運用を効率化――環境を提供する仕組みをサービスとして捉える「PaaSaaS」

トップエスイーからのアウトカム ~ ソフトウェア工学の現場から 第12回


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

 社会人エンジニア向けの教育プログラム「トップエスイー」から、エンジニアの皆さんに対して有用な情報をお届けするコーナーです。クラウドでのコンピュータ―利用は広く行われていますが、要求は次第に高くなってきています。また、用途も広がるにつれて、ニーズをサービスとして手軽に利用できる必要性も高まってきます。今回は、そうしたサービスを提供するプラットフォームを開発した事例を紹介します。

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

開発環境基盤の導入における問題点

 企業内で開発を行う場合、開発環境構築基盤(PaaS)があると、一定の環境であれば効率よく構築できて非常に便利です。しかしながら、実際には開発チームごとに個別のカスタマイズが必要となるため、運用するには非常に高いコストがかかります。また、構築できるメンバーも限られてしまい作業が属人化してしまいがちです。

 最近ではWeb上に構築手順をまとめた記事はたくさんあるのですが、これらを参考にしても、社内Proxyや開発環境特有の構成などが原因で失敗するケースがあります。作業者は、原因調査に時間をかけすぎるのは避けるべきですが、一部完成しないままの状態で構築作業を切り上げ、動作する部分のみで運用を開始することも好ましくありません。本稿では、こうした問題を解決するために「Literate Computing for Reproducible Infrastructure(以下、LC4RI)」を使ったPaaS環境を提供するサービス、「PaaSaaS」について紹介します。

 LC4RIとは、Jupyter Notebookを利用して実行・再現な可能手順書の整備と、手順書を用いた作業の証跡の管理を表裏一体で機械化し、人間が読み解ける文芸的コンピューティングの実現を目指す試みです。AnsibleなどのDevOpsツールと組み合わせた、再構築可能なインフラの構築・運用に適用している実績があります。

 Jupyter Notebookとは、Pythonを始めとする複数のプログラミング言語をインタラクティブに操作可能なオープンソースのWebアプリケーションです。Ansibleは、同じくオープンソースソフトウェアであり、Pythonで記述された構成管理ツールです。

 LC4RIを手順書に沿った処理を進める仕組みとしてだけでなく、手順書自体を生成できる基盤として捉えました。手順書を自動生成する上で、誰が操作しても同じ結果となるような仕組みを作れないかと考えました。

 この手法を前述の問題点に適用することで、以下の課題を解決しようと試みました。

  • 課題1:チームごとに異なる開発環境一式を提供できるようになること
  • 課題2:エラー発生時に調査できるようになること
  • 課題3:ミスの少ない手順書を作って、誰でも構築できるようになること

 これらの課題を解決するため、チームごとの専用の手順書(Notebook)を自動生成させることを目指しました。LC4RIを使うことで、実行ログを記録しながら操作可能であり、障害発生時に調査・問題の切り分けが可能となること、さらに自然言語と実行コードを備えた手順書を提供できるため、誰が実行しても同じ結果となることが期待されます。つまり、課題2と課題3は解決可能で、属人化も排除できます。

 さらに残った課題1を解決するため、任意の手順書を自動生成させる仕組みを新たに作りました。こうして開発環境を提供する仕組みを提供することから、PaaS as a Service(PaaSaaS)と名付けました。

会員登録無料すると、続きをお読みいただけます

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

次のページ
PaaSaaSの概要

この記事は参考になりましたか?

  • このエントリーをはてなブックマークに追加
トップエスイーからのアウトカム ~ ソフトウェア工学の現場から連載記事一覧

もっと読む

この記事の著者

古川 勇志郎(富士通株式会社)(フルカワ ユウシロウ)

 日本OpenStackユーザ会メンバー兼OpenStackコアデベロッパー、OpenStack Neutron Firewall as a Service(FWaaS)などのコアデベロッパーとして、OpenStack開発コミュニティで活動。富士通株式会社 プラットフォームソフトウェア事業本部 Li...

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/11050 2018/10/04 11:14

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング