Developers Summit 2019
日時:2019年2月14日(木)10:00-18:45
2019年2月15日(金)10:00-18:25 |
会場:ホテル雅叙園東京
【公開された登壇資料】
■ Cloud Native時代における Docker / Kubernetes による開発
Speaker:青山 真也[サイバーエージェント]
登壇資料
【memomeo】
・Cloud Native
OpenかつScalableなシステムを実現すること
CNCFがホストしているproductがKubernetesを前提としているため、Kubernetesを使うべき
・Microservice Architecture(⇔モノシリックサービス)
疎結合に組まれているのでメリットが大きい。
ただし、500以上のマイクローサービスが数珠つなぎなっており、本当にObservilityがあるのか?
→Service Meshと言う考え方が生まれる
(メリット)Microservice間の観測性を確保、柔軟な通信の制御を実現、暗号化を実現
・Container(VMとの大きな違い)
2種ある”system container”と”application container”
app containerの代表格がDocker
→VMと比べてイメージ化が容易、高速起動が可能・・・
・Kubernetes Overview
Container orchestrater engineがCloudNativeを実現する
・Kubernetesがもたらすもの
1.
2.Self-healing
障害時の縮退運転、振り分け機能を自動でしてくれる
3.
●key point
−Kubernetesはgoogleが社内で長年使われていたため、様々なワークロードへの対応や洗練化された自動化、拡張性がある。独自開発をすると、属人化されてしまうため管理が難しくなる。kubernetesでできないと思うことの8割は解決できる。
・分散システムとしてのKubernetes
Kubernetesはただ単純にマニフェストを実行しているのではなく、Control Loopをしている。
【HP概要】
今日Dockerなどのコンテナ技術は広く普及し、GCP・Azure・AWSがマネージドサービスをリリースしたことなどからも、コンテナオーケストレーションエンジンとしてはKubernetesがデファクトスタンダードだと言えます。
本講演ではKubernetesが必要な理由・機能及びコンセプト・解決できる問題について、また分散システムとしてのKubernetesの仕組みについて紹介します。あわせて、コンテナを利用した開発をするにあたり切り離すことのできない「Cloud Native」や「マイクロサービス」の考え方、最近のKubernetesを取り巻く技術動向、将来性についても紹介します。
【Speaker概要】
株式会社サイバーエージェントアドテク本部。2016年新卒入社。OpenStackを使ったプライベートクラウドやGKE互換なコンテナプラットフォームをゼロから構築し、国内カンファレンスでのKeynoteに登壇。その後、世界で2番目にCertified Kubernetes Application Developer、138番目にCertified Kubernetes Administratorの認定資格を取得。著書に『Kubernetes完全ガイド』。現在はKubernetesやOpenStackなどOSSへのコントリビュート活動をはじめ、Cloud Native Days Tokyo Co-chair、CNCF公式のCloud Native Meetup TokyoのOrganizerやJapan Container Daysの運営などコミュニティ活動にも従事しています
■【第1部セッション】いまなぜGoogle Cloud Platformを学ぶのか!?〜GCPを支えるGoogleテクノロジーと愛を語る〜
①『Google社内の開発環境ってどんなの?GCPとの関係は?〜Googleの開発環境から見るGCPの魅力〜』
Speaker:中井悦司
【memomeo】
・GCPについての愛を語る
【Googleの開発】
・googleは社内共有がゆるゆるで全てソースコードが見れる
・googleのミッション「全世界の人々が平等につかること」というスケールでサービスを考える
・Dataセンターのインフラは全て共通化されているため、全世界の全サーバで稼働する。
→Borg(Kubernetesの大元)のコンテナが全てのサーバにふられている
・MWについても共通化されている。
【リポジトリについて】
・単一リポジトリによるソースコード管理
全てのPJのソースコードを1つのリポジトリに保存
PJごとにディレクトリを分けて管理
→背景はPJ間でのソースの公開を簡単にするため。(つまり、バイナリファイルでの連携ではなく、ソースコードレベルでincludeできる)
複数バージョンにまたがる依存関係問題が起きない
リポジトリ全体にまたがった大規模なリファクタリングが可能(実例として、リファクタリングチームが立ち上がり、全てのソースコードに大して自動でリファクタリングをかけた)
※Google社員は直ぐに自動化する。
・ブランチを切らない開発ツリー(全員が同じマスタを見ながら開発ができるため)
※ただし、リリース用のブランチのみ分けて管理
・単一リポジトリのデメリット
−専用ツールの開発・メンテナンス:インフラコストがすごい
-検索システムがないと柔軟に探せない
-ライブラリ依存関係の適切な管理が必要
【自動テスト環境】
・Blazeで依存関係と自動テストのルールを指定
・10ホップを超える場合はUnitテストでFailすることはほぼない
【コードレビュープロセス】
・ソースコードの更新プロセス(ほぼgit)
リポジトリ全体を(仮想的に)ローカルレビューする
・コードレビューシステム
Critique(ほぼGerrit)上で実施
アサインするレビュアーは任意
・コードレビューの目的
他人が理解できるコードを書くこと(★)
副次効果として、メンテナンス性の向上やバグの混入防止などがある
【いまなぜGCPを学ぶのか?】
・最先端のサービスを提供しているGoogleの開発ツール(コンポーネント)が誰でも使用できる。
(あのサービスにあのコンポーネントが使われている)
『グーグルを支えるテクノロジー』のサイトで日本語版のコラムを掲載
英語の参考
【エンジニアとしてこの先、生き残るためには。。。】
・役割としてのフルスタックは古い。知識範囲としてフルスタックが重要となる。
・インフラを構成するソフトウェアの特性を深く理解して、最適なアプリ、アーキを見極めることが重要。
・それぞれの技術要素を理解して、システム全体のアーキを俯瞰できる能力が必要。
②『GCPでわくわくしよう!〜スペシャリストが語るGCPの魅力〜』
Speaker:Google Cloud チーム
【memomeo】
【深堀まど佳】:カスタマーエンジニア(→セールフォース)
【福田潔(F)】:カスタマーエンジニア(UNISYS, accebture, Oracle, hea →VM)
SIer8年、SoftwareVebder11年
【岩崎大志(I)】エンジニアリングサポートマネージャ(Sun→Oralce)
【千藏大輔(S)】プロフェッショナル・サービス技術コンサルタント(TOSHIBA→TOSHIBA.Solu→google.app)
【有賀征爾(A)】ネットワークスペシャリスト(NTTコム→AWS)
Q.Googleエンジニアとして働くことのやりがい
I:特に動きがはやい。やる気と時間があれば多くの知識を得ることができる環境
A:個人的な興味を満たせる。グローバルインフラの背景や開発のノウハウを知ることができている。
技術的な部分は論文で公開されているが開発背景やバックボーンを知ることができる。
大企業ではあるが開発速度がトップスピードで行われている。(人間の縦関係横関係が近い)
Q.自分の好きな製品と理由
F:Cloud PubSub。非常にシンプルな製品。
S:マネジメントサービス。ゼロ環境に近づくことができるサービス。
Q.どのようにして日々最新のテックをキャッチしてますか?
A:全部を全て深くは無理。広く浅く、特に興味があるところは深くする(T字)。
深くするためにはHowToと新しい情報が何故必要なのか?どうやって作られてのか?などの背景(バックボーン)を知るようにしている。技術は繰り返される。
S:新しいのがでれば、すぐに触る。チュートリアルで試す。優秀な技術者のブログを読むようにする。
F:フィルターアウトする。フィルターした分野で重要なことは嫌でも入ってくるので、割り切る。
新しい技術がでてきたときに、目利きをする。煽りがすごい業界なので惑わされないようにする。
【HP概要】
①みなさんは、GmailやGoogle Driveなど、Googleが提供するサービスのインフラに興味があるでしょうか? ―― Google Cloud Platform(GCP)は、Google社内のインフラ技術に基づいたパブリッククラウドであり、GCPを通してGoogleのソフトウェア開発者の体験を知ることができます。
本セッションでは、Google社内のソフトウェア開発環境やCIの仕組みをご紹介します。GCPを支えるテクノロジーを通して、GCPの魅力、そして、これからのソフトウェア開発者・インフラエンジニアに求められるスキルについて考えてみましょう。
②Google Cloud Platform(GCP)は、Googleの各種サービスを支えるインフラを基礎とした、ツール、プラットフォーム、各種APIサービスを企業や開発者に提供しています。パネルディスカッション形式の本セッションでは、この多岐にわたるパブリッククラウドサービスのさまざまな魅力を、各分野で活躍するスペシャリストがあますことなくディープに語ります。
GCPを日本の皆さまに提供するチームがいったいどんな熱い想いをもっているのか、どんな働き方をしているのかも垣間見ることができる、エンジニアのキャリアを考える上でも、ここでしか聞けない、必見・必聴のセッションです。
■ 「ITエンジニアに読んでほしい!技術書・ビジネス書大賞 2019」プレゼン大会
【memomeo】
公式サイト
個人的にはこの書籍は読んでみて、おもしろかった書籍です。
・エンジニアの知的生産術
・イシューからはじめよ
・学びを結果に変えるアウトプット大全
・1分で話せ
・the four GAFA
【HP概要】
ITエンジニアの皆さんでおすすめ本を選ぶイベント「ITエンジニアに読んでほしい!技術書・ビジネス書大賞(ITエンジニア本大賞)2019」のプレゼン大会です!プレゼンの対象となる本は、皆さんの投票が特に多かった技術書3冊とビジネス書3冊。当セッションでは下記の合計6冊の著者、編集者らによるプレゼンを行い、本に対する思いやおすすめのポイントなどを語っていただきます。その後、会場の特別ゲストと観覧の皆さんからの投票で大賞を決定します。
その他登壇者の資料
ヤフー株式会社におけるフロントエンドの取り組み
メンバーの成長とチャレンジのためにエンジニアリングマネージャーとして大切にしたこと