新人がコンテナを理解した学習方法


はじめに

この記事は、IT超初心者で技術要素を学習する方法が知りたいという方を対象としています。

IT技術に触れ始めて早3年が経とうとしていますが、3年前まではIT超初心者でした。始めて配属されたプロジェクトでは"コンテナ"、"コンテナオーケストレーション"という言葉が飛び交い、プログラム中心に勉強をしたがために、インフラまわりの話についていけず焦りました。

そんな中、先輩にアドバイスを受けつつ勉強し始め、何から手を付け始めて、どうやったら使えるようになるのか、その勘所を探ろうとした結果得た学びをお伝えします。

初めての技術要素を学ぶ流れ

最終な目標を「使いこなせるようになる」とした場合、書籍などの情報をインプットするだけでは、使えるようにならないのを実感されていると思います。私自身も「使いこなせるようになる」が遠い目標過ぎてどのようなステップを踏めばよいかも分からず、ハードルを感じていました。

そこで、熟練者のアドバイスを受けながら勉強していき、学び方のポイントを習得していきました。

下記に示すステップを踏むことで「使いこなせるようになる」に少し近づくことができたと感じています。また、下記に示すコツを各ステップ内で行うことでより理解の助けになります。

ステップ1:実際に技術に触れる
● とりくみやすそうな目標を決め、それに適したgithub上のサンプルや公式のチュートリアルを行う
● 「理解は後からついてくる」という心構えで、深い理解をしていなくてもあまり気にしない。意外と作業しているうちに理解してくることもある
ステップ2:資料で頭を整理する
● ステップ1の中で不明な点は、Qiitaの記事等で調べる
● より深い理解をするために書籍やSlideShareの資料を読む
ステップ3:自分でイチからつくる
● ステップ1、2の知識を使って自分で設計する
● 自分の理解度を測ることができ、復習にもなる

コツ1:手書きでノートに書く
● 概念や構造の理解をするためには、手書きでノートにまとめた方が頭に入る
● きれいにノートにまとめるのではなく、あくまでも整理するために紙を使う
コツ2:Markdownでまとめる
● Markdownは手順系をまとめ易いため、作業を記録しておくのに適している
● 覚えておきたいコマンドやメモも残す
コツ3:仲間や先輩に共有する
● 人に説明することで自分が理解していないことに気付く
● 有識者の意見を吸収できる

実際に試した例

上記の「初めての技術要素を学ぶ流れ」を実際に試した例を紹介します。お題は以下の3つです。

A. Dockerの理解
B. コンテナオーケストレーションの理解
C. サンプルアプリをGKEで起動させる

A. Dockerの理解

目標
Dockerコンテナで何ができるか理解すること
→ ローカルでイメージをbuildしてDocker Hubにpushする
→ 書籍やQiitaの記事で知識を整理

Dockerの概要はあらかじめ調べてから、とりかかりやすい目標を立てました。ステップ1の手順はこちらを参考にしてください。ステップ2で実際に読んだ資料や、行ったことを以下でご紹介します。

B. コンテナオーケストレーションの理解

Dockerについて学んでいくと、コンテナオーケストレーションという技術があることを知りました。特にkubernetesが熱いようでした。ステップ1の「実際に技術に触れる」が鉄則なので、手軽に試せるクラウドサービスを選択します。

目標
コンテナオーケストレーションで何ができるかを理解すること
→ GCP Kubernetes Engine(GCP)を試す
→ AWS Elastic Container Service for Kubernetes(EKS)を試す

クラウドサービスの公式ページではチュートリアルが用意されているため、ステップ1として以下の公式チュートリアルを行いました。

ステップ2として動画と書籍を活用しました。

  • kubernetesの概念やネットワークについて解説している動画です。あまり理解が進んでいない状態でも、割とついていくことができるためおすすめです。
  • いきなり始めから読み物として読むのは難しいのですが、理解が進んできた後だと頭が整理されます。

C. サンプルアプリをGKEで起動させる

ステップ3として、フロントエンドアプリをGKEで動かすことにしました。実際に試したハンズオンはこちらをご覧ください。ステップ3を行うことでこれまで別々だった知識がつながり、やっと「使えそうかも」という状態までたどり着きました。

おわりに

実際に技術を試してみる、書籍で勉強する、など当たり前に言われていることなのですが、自分がつまづいたのと同様に学習方法がわからない初心者の方の助けになれば幸いです。まだ「使えそうかも」となっただけで、「使いこなせるようになる」まで到達していませんが、新しいことに対するハードルは下がったので、実践→情報収集を繰り返していきたいと思います。
最後までお付き合いいただきありがとうございました。