Slide 1

Slide 1 text

IBM Dojo ǏĽ¡O§ OpenShift(Minishift) 101 Aya Tokura Developer Advocate Tokyo City Team

Slide 2

Slide 2 text

本⽇のタイムテーブル 13:30-13:35 (5min) オープニング 13:35-14:30 (55min) OpenShift概要 ⽇本アイ・ビー・エム株式会社 デベロッパーアドボケイト ⼾倉 彩 14:30-16:30 (120min) Minishift 101 ワークショップ ⽇本アイ・ビー・エム株式会社 デベロッパーアドボケイト ⼾倉 彩 / ⻄⼾ 京⼦ 16:30-17:00 (30min) クロージング

Slide 3

Slide 3 text

学習の⽬的とゴール ⽬的 OpenShift概要について理解する ゴール Minishiftを利⽤したアプリケーションを動かす このコースを学ぶ⽅の想定スキル コンテナ実⾏環境を初めて利⽤する⽅

Slide 4

Slide 4 text

ayatokura ƤȢ ɜ (Aya Tokura) IBM Developer Advocate ©Å´Oˆ–ÀÓ²ǿɟHȚÞȹȈHɈȾźě‘ĂjuH Ċìã{òNz IBM Cloud ˆWatson{ƦDŽɛɤ‘ß^I

Slide 5

Slide 5 text

G,;!,2h‰qzd~†‰x„BWVaQ^XHΎ¥¹ ŠŒXBjB£Mª^aEhnpru€F ¢Ÿ£Y–“UX¬Êc_Lª^SK\PA ąþ|ªµO{ɗǛÑ®²S/70=T{ĊìIJêv źɃÚ{ŹÙǓȪť‘`ȰciuHÔÙv{3D)3:{ ƕŒòˆHÿŒò‘…yh’wÝɌz²Ož¥ÌO‘ Ű_uŪ_u]ep‹wŲ]„kI ÔóL Ö æÔȑĊȘ êĭL¦ÊӞȷŶơ șɑÙơ ǡŘLŎĖħ £O»§¡O´‡id|`Œļv WٖÀÓ²zÿk`ĩ]ämHgŎĖ|fr‹ ¦ÊӞȷŶơșɑÙơ +# éĥŅǹĴƃƅșɑ 07B :F 3D)3:==9

Slide 6

Slide 6 text

F .5+ IBM Cloud #)(8MURLL ibm.biz/dojo20191129 ! IBM Cloud 3$ 5 "!5+ CD 3$ 5 ! IBM Cloud 1 +"!5+;B "!5+CD KPR UÙÔ{`ȸ]

Slide 7

Slide 7 text

事前準備まだお済みでない⽅ 1. IBM Cloudアカウント(無料)の取得 ☆操作解説動画: https://ibm.biz/action1 2. IBM Cloud 従量課⾦アカウントへのアップグレード ☆操作解説動画: https://ibm.biz/action2 ※ ワークショップでは有償アカウントを使⽤しますが、無料枠内で作業します。 従って、今回の有償アカウントへのアップグレードや、ワークショップ参加によって 利⽤料⾦が請求されることはありません

Slide 8

Slide 8 text

⽬次 1. コンテナが注⽬されている理由 2. Kubernetesとは 3. Red Hat OpenShiftとは 4. Minishift ワークショップ

Slide 9

Slide 9 text

1. コンテナが注⽬されている理由 なぜ「今」 コンテナ/Docker/Kubernetesなどの テクノロジーが注⽬されているのか

Slide 10

Slide 10 text

コンテナ以前の様⼦ コンテナ⾰命以前の港湾荷役 http://military.wikia.com/wiki/Battle_of_Pusan_Perimeter_logistics ⼤勢の作業員 倉庫に⼀時保管 物流の最⼤の ボトルネック

Slide 11

Slide 11 text

https://www.jsanet.or.jp/seminar/text/seminar_177.html 物流コンテナによる⾰命 コンテナの発明者は、全⽶有数のトラック 運送会社のオーナーとなったマルコム・ マクリーン(Malcom P. McLean) 国際貨物輸送の分野に 海陸⼀貫輸送という⼤変⾰ 1970年代には世界の主要航路のコンテナ 化がほぼ完了した。わずか10年程度でこれ ほど急激な形態の変化が起こったのは海運 史上でも他に例がない。 https://en.wikipedia.org/wiki/Malcom_McLean

Slide 12

Slide 12 text

ǬȨɊƧ{²϶®ž‘ŝƬ ŖƢ¡§²{ȄŐw§¼O³”®¿ ¡Ó°´DžǑ|ÞįŔDž ȤĻÝɒNJƲ ĻÛNJƲ ȤƲQ²Í®žR ȤƲQǦňR ǬȨɊƧ ǬȨɊƧ ¡Ó°´Ƕ

Slide 13

Slide 13 text

いま、IT業界の コンテナ⾰命が 始まる

Slide 14

Slide 14 text

SɉǐÄ¥Ó-$TwS¡Ó°´T ¡Ó°´|ɉǐÄ¥Ó-$zƥuΪO§ǚƛbŠ] § Oϔ—²bɄȓ

Slide 15

Slide 15 text

¡Ó°´‘ŷspĊì{ƢŽ Dockerfileyx Docker –ÇO¦yx ¡Ó°´O Ц§²Î ĵ½˜§²v ¡Ó°´åċ{ ɐȝ‘ŢǪ Ċìã ¡Ó°´O –ÇO¦ŦĮ –ÇO¦{ ǿǘ Ċì㠔¿ÎĎß ”¿ÎĊì ǩȊ{¿Ñ©§

Slide 16

Slide 16 text

コンテナーのポータビリティ nコンテナーのポータビリティ •アプリケーション稼働に必要な依存ファイルを パッケージングできる •物理サーバーに固定されない → 同じアーキテクチャの環境であれば ポータビリティが存在する システム基盤 (クラウド) ホストOS システム基盤 (オンプレミス) ホストOS コ ン テ ナ エ ン ジ ン App1 Bin/Lib s App2 Bin/Lib s App3 Bin/Lib s 「僕の環境では動いた」 問題が発⽣しない コ ン テ ナ エ ン ジ ン App3 Bin/Lib s

Slide 17

Slide 17 text

What is Container (コンテナ)? https://youtu.be/1PPPUPcUkSs

Slide 18

Slide 18 text

コンテナのはじめ⽅ n CNCFの Cloud Native Trail Map を参照 1. コンテナ化 • ⼀般的には Docker コンテナで実施 • いかなるサイズのアプリケーションも依存性もコンテナ化可能 • 時間が経つにつれ、アプリケーションを分割し マイクロサービス化したくなるだろう 2. CI/CD(継続デリバリの仕組み) • 継続インテグレーション・継続デリバリの仕組みをセットアップ • コード変更が 新しいコンテナ・イメージとして、 ⾃動的にビルドされ、テストされ、デプロイされるように 3. オーケストレーション&アプリ定義 • 互換性試験に合格している Certified Kubernetes 環境を選択 • もっとも複雑なアプリケーションであっても HELMで 定義して、導⼊して更新していくことが可能

Slide 19

Slide 19 text

コンテナのまとめ • 仮想マシン(VM)に⽐べてリソース効率がよい • ボータビリティーが⾼い • スケールアウトが容易 • 3段階のプロセスをコンテナのpushに使⽤することで、 よりアジャイルなDevOpsと継続的インテグレーション およびデリバリーが可能になる 動画をもう⼀度⾒たい⽅はこちら: • https://developer.ibm.com/jp/new-builders/containerization/ ⽂章での説明もあります

Slide 20

Slide 20 text

2. Kubernetesとは コンテナーの運⽤実⾏と管理を⾏うオーケストレーションツール • コンテナーが⼤量になってくると管理しきれない部分をカバー • 複数のDockerホストの管理 • 死活監視 • スケジューリング • スケーリング • 障害時のリカバリー • アプリ実⾏に必要なインフラリソースを管理 • 永続的なストレージ • ネットワーク • クレデンシャル情報 etc… • 宣⾔的設定モデル • 「あるべき状態」を記述すると、それを実現し続けようとしてくれる • 障害時も⾃動で復旧作業を実施

Slide 21

Slide 21 text

Kubernetesの代表的な機能 スケールアウト 負荷分散 バージョン管理 (ロールアウト) ネットワーク管理 永続ストレージ管理 死活監視 ⾃⼰復旧 CPU / Memory リソース管理

Slide 22

Slide 22 text

What is Kubernetes? https://youtu.be/zGXYRQ-8pU0

Slide 23

Slide 23 text

IBM{¡Ó°´ƦDŽHȂƏЀ{ĠŒŊ… žÍ—³¶–°•¾K”¿Î ȂƏЀǙǫøzĿď =193@"C03@<3B3A€{ ¡Å®² "C03@<3B3AÀO§{ ¡Ó°´řȩªÎÊO¥ÌÓ ÖæJ!$ˆ ==5:3yx Ė {ŚÞJŜċbİĀ ¡Ó°´ƦDŽ ¡Ó°´ƻē "#$ !"#$% %&'()*(+(,-.()/01(-2"%.3 £O»§Ç®¥Ê @/43/A £O»§Ç®¥Ê £O»§Ç®¥Ê @/43/A £O»§Ç®¥Ê £O»§Ç®¥Ê @/43/A @/43/A £O»§Ç®¥Ê @/43/A £O»§Ç®¥Ê £O»§Ç®¥Ê £O»§Ç®¥Ê £O»§Ç®¥Ê £O»§Ç®¥Ê "#$ !"#$% 4)0/5+(-2"643 ´s~wfgdXn‰uy”®c¾Ÿ '!=<<31BJ./BA=<=;>/@3=;>:FJ +@/63@3J ,@0/<=23 3>:=FJ'$J0 J $(J!!J>>=<<31BJ/B/'=E3@Jo{Ȓőĸ

Slide 24

Slide 24 text

Kubernetesのまとめ 動画をもう⼀度⾒たい⽅はこちら: • https://developer.ibm.com/jp/new-builders/kubernetes/ ⽂章での説明もあります • コンテナーのオーケストレーション・ツール • 理想状態を宣⾔すると、その状態を維持しようとしてくれる • 3つの主要コンポーネント • Pod, Deployment, Service • PodはDeploymentによって作成され、管理されます。 Deploymentによって作成されたPodへのアクセスは、 Serviceを使⽤することで容易になります。

Slide 25

Slide 25 text

3. Red Hat OpenShiftw|

Slide 26

Slide 26 text

© 2019 IBM Corporation OpenShift|HKubernetesw{ȺȁĬ‘ȧņiyb‹HCICDğŵ‘īĐHĊìã zėsuH»Ï³HÎæ²ÎǿǘH±¿Ñ–‘åěĎßi„kI OPENSHIFT ğŵǽǃ OpenShift CICDľĔ ”¿Î O¥ÌÓ Q¡Ó°´R Kubernetes ”¿Î O¥ÌÓ Q¡Ó°´R Ubuntu / CentOS… Linux Kubernetes ”¿Î O¥ÌÓ Q¡Ó°´R ¡Ó°´ ÍÓ«–Æ Linux OS ¡Ó°´ ›O §²ÐO¥ÌÓ Kubernetes{ȂƏğŵ vƵȱip”¿Î O¥ÌÓ xr‹v‡ ěŦƞŵ RHEL / RHCOS ¡Ó°´ ÍÓ«–Æ "C03@<3B3Aw&>3<*674B

Slide 27

Slide 27 text

What is OpenShift? https://youtu.be/KTN_QBuDplo

Slide 28

Slide 28 text

KuberneteswOpenShift{ƿ]

Slide 29

Slide 29 text

KubernetesとOpenShiftの違い まとめ • Deploy: • ソースコードからコンテナ作成とデプロイまでの⾃動化 • Manage: • Webコンソールとコマンドラインの両⽅から操作可能。 • 実⾏状態のメトリックス監視とログ分析も提供 • 運⽤: • Ansible Playbookを使ってオートスケーリングが可能 • Security: • Project単位で簡単に管理可能

Slide 30

Slide 30 text

Kubernetes and OpenShift: What's the Difference? https://youtu.be/cTPFwXsM2po

Slide 31

Slide 31 text

Red Hat OpenShift on IBM Cloud IBM Cloud™Û{RedHat®OpenShift®|Hîćz§ O;ÏvĶȎĬ{î]IBM Cloud¿Í®²½šOÆvȗĕzƻēhŽpOpenShiftžÍ§«O‘ŧǒkɇɎøy £O»§vkI The WeatherCompany®vȶÔ2,500Ō{›Ó±ÄÓ³ŎȮ‘ȧņk Kubernetes£O»§zŬǣƩähŽu]„kI

Slide 32

Slide 32 text

4. Minishift ÒOž¥Ì®¿ 6BB>A EEE =92 7= ;7<7A674B

Slide 33

Slide 33 text

ワークショップ 5-1. IBM CloudでOpenShiftを使う 5-2. Minishift とは 5-3. Minishift ワークショップ

Slide 34

Slide 34 text

5-1. !$:=C2v&>3<*674B‘ŷ^ !$:=C2zџ–Ó ÙÔ| 70; 07G 2=8= z”ž©§iu ȃÛ{Sџ–ÓTa‹ џ–Óiudqh] Ăƴ| https://cloud.ibm.com/ a‹ÑŸ–Óƞŵvk

Slide 35

Slide 35 text

5-1. !$:=C2v&>3<*674B‘ŷ^ ¬®¥ÊÂO³a‹Sœ«ÑŸT‘žÎ®ž

Slide 36

Slide 36 text

5-1. !$:=C2v&>3<*674B‘ŷ^ ȃÛ{ŕɏ½•Oϳa‹2(),2ƒew‘ÁÀ J2(),2ƒew‘ȄǼ

Slide 37

Slide 37 text

5-1. !$:=C2v&>3<*674B‘ŷ^ ǾŸ{œ°¢ÎOa‹S¡Ó°´T‘žÎ®žH S)32 /B&>3<*674B:CAB3@T‘žÎ®ž

Slide 38

Slide 38 text

5-1. !$:=C2v&>3<*674B‘ŷ^ )32 /B&>3<*674B:CAB3@ŦĮƉůbĜŨhŽ„kI pqi͖²”œ—Ó²v|ŦĮvcy]p†H ͖²”œ—Ó²{êä|S”®¿ŸÐO³T«ÓbĜŨhŽ„kI

Slide 39

Slide 39 text

5-1. IBM CloudでOpenShiftを使う 6. 「 Red Hat OpenShift Cluster 」を作成します。動画で⾒てみましょう: https://youtu.be/UJ2frartWFk

Slide 40

Slide 40 text

5-1. IBM CloudでOpenShiftを使う 補⾜情報: 3分でわかるIBM Cloudシリーズ(動画) • OpenShiftクラスターに対してocコマンドでアクセスする • OpenShiftクラスターにHelloWorldアプリをデプロイしてみよう IBM Demos (デモ動画サイト、英語): • Red Hat OpenShift on IBM Cloud

Slide 41

Slide 41 text

5-2. Minishift とは • OpenShiftは、Kubernetesに、Red Hat社独⾃の拡張を加え、さらに、 Red Hatのソフトウェア保守とウェブや電話での問い合わせ対応 サービスを提供する企業向けKubernetesのプラットフォーム • OpenShiftは、Red Hat社が提供する有償サービス(サブスクリプション) のもとで利⽤できるソフトウェア • OpenShiftの学習やローカルの開発環境⽤に無償で提供されるのが、 Minishift (OpenShift 3.11に相当) 「MiniShiftに関する疑問の整理、「 Dockerから⼊るKubernetes」執筆打明け話とか、OKDやCRCとの整理など」 https://qiita.com/MahoTakara/items/3c1c208640518e832660 より抜粋

Slide 42

Slide 42 text

5-3. Minishift ワークショップ (準備) Setup 1 「仮想化環境を構成する」の⽇本語版はこちら」 • Windows: ibm.biz/Bdz39H • Mac: ibm.biz/Bdz39E Setup 2 MinishiftのインストールおよびOpenShiftサーバーを開始する ibm.biz/openshift1 Setup 3 コードエディタをインストールする(オプション)

Slide 43

Slide 43 text

5-3. Minishift ÒOž¥Ì®¿ &(9854%08:(2!,*5.409054c§RQ 45+,18X«Ë¤¿&,)d„ https://github.com/kyokonishito/watson-vr-node c0408/0-9T—ŽPa 47#&0*-?9@-2JQ /7'

Slide 44

Slide 44 text

Watson API£O»§Ýɚ 2019‹3‘­ &(985488089(49 ”¿Î O¥ÌÓzåǮŇǀ–Ó«O½˜O§‘ǏĽiu ™Ó³ËO¤w{ˆŒĠŒ‘åěĐ #,=995"6,,*/ °§²Žɍ‘ȆƶzƖȁk "6,,*/95#,=9 Ȇƶ‘°§²ŽɍzƖȁk %08:(2!,*5.409054 Ɖȼ¡Ó°Ó¯zǖ„ŽĨǴ‘ŕÜk 08*5;,7> ŏĵøyɝǭ™Ó¦Ó‘ľĔiuH±O «{ɀŽpŤǝ‘ŝĄiHþǵˆ²ÐÓ ³‘ìëk 08*5;,7>,<8 7A1=D3@FÛzĎȞhŽH™Óή­şł ‡ƈĽhŽpµÊO§zÿkĝĊ±O «©®² ,7854(209>480./98 °§²a‹Ⱦã{ĬŻ‘ǰ÷k (4.:(., #7(482(957 °§²‘ȒŇǀ€ɢɓ‘ß^ (9:7(2(4.:(.,$4+,789(4+04. åǮŇǀƝē‘ĂjuOÒO³ɞÜH™Ó °•°•OɞÜHɖLj«ŸƈeHÿƀɞÜy x‘ß^ (9:7(2(4.:(.,2(880-0,7 °§²Žɍ{çȇ‘ß^Ƽĩ{ĨDZǰ÷yx #54,4(2>?,7ŠŒ·Ã”® °§²a‹Ⱦã{ƐşHâŰĬHŽċ‘ŝɋ 45<2,+.,"9:+05 ¡O±•ÓŸyizHÞįšDza‹íĮip ğɘĚțȱÏvHȍƵLJ°§²±O«a ‹ɝǭ‘ĠśĚțŋƹ¯OÏ ŞēǺ ŇǀǺ ɅØƙǵǺ šDzȽɏǺ ȆƶǺ ƉȼǺ 6BB>A EEE 70; 1=; E/BA=< 8>8/ 23D3:=>3@1:=C2 A3@D713A1/B/:=5 6B;:

Slide 45

Slide 45 text

Watson Visual Recognition (画像認識) 画像認識「⼀般種別」(General Tagging): • 事前学習済みの分類器の出⼒を返す 画像認識「カスタム」: • 識別を⾏いたいクラスのイメージを事前学習させ、 その分類器の出⼒を返す 事前学習 不要 事前学習 必要 https://www.ibm.com/watson/jp-ja/developercloud/visual-recognition.html 画像に写った物体・情景など様々なものを分析・認識するAIサービス

Slide 46

Slide 46 text

0. Visual Recognitionサービスの作成 以下を参考に、 Visual Recognitionサービスを作成してください。 https://github.com/kyokonishito/watson-vr-node#2-visual-recognition- %E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%81%AE%E4%BD%9C%E6%88%90

Slide 47

Slide 47 text

1. Visual Recognitionサービス ibm-credentials.env のダウンロード 1.1: IBM Cloudにログインし、 Visual Recognitionサービスの管理画⾯を表⽰します。 ⼿順が不明の⽅は、下記を参照してください: https://qiita.com/nishikyon/items/9b8f697db7ad0a693839#2- %E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%81%AE%E8%B3%87%E6%A0%BC% E6%83%85%E5%A0%B1%E5%8F%96%E5%BE%97

Slide 48

Slide 48 text

70;1@323

Slide 49

Slide 49 text

70;1@323

Slide 50

Slide 50 text

70;1@323

Slide 51

Slide 51 text

f{\w|HZ[Z[¡ÄÓ³ɂŦvkM «OÅ´Ï$/1„p| '=E3@*63::.7<2=EA ‘Ċc„kI

Slide 52

Slide 52 text

2. Minishift アプリ作成 2.1. クラスターにログインします $ oc login -u system:admin minishift startを実⾏した後、下記のコマンドでクラスターにログイン します。 2.2. プロジェクトを作成する $ oc new-project watson-vr --display-name="watson-vr" -- description="Sample Watson Visual Recognition Node.js app" 下記コマンドで、新しいアプリケーション⽤に新しいプロジェクトを 作成します。 (コマンドは1⾏です)

Slide 53

Slide 53 text

2.3. アプリケーションの作成 $ oc new-app https://github.com/kyokonishito/watson-vr-node.git -- build-env-file= --build-env CLASSIFIER_ID=food githubのソースコードから、下記のコマンドでアプリケーションを作成 します。 • 1.2でダウンロードしたibm-credentials.envをPATHも含めて、 下記に指定します。 (コマンドは1⾏です) $ oc new-app https://github.com/kyokonishito/watson-vr-node.git -- build-env-file=./ibm-credentials.env --build-env CLASSIFIER_ID=food 例

Slide 54

Slide 54 text

2.4. ビルドログを表⽰します $ oc logs -f bc/watson-vr-node 下記のコマンドでビルドログを表⽰し、「 Push successful 」で終わる まで待ちます。 2.5. ポートを公開します $ oc expose dc watson-vr-node --port=3000 --type=LoadBalancer -- name=watson-vr-node-ingress 下記コマンドを実⾏します。(コマンドは1⾏です)

Slide 55

Slide 55 text

2.6. 作成されたNodePortを確認します $ oc get --export svc watson-vr-node-ingress 2.7. アクセス可能なクラスターIPアドレスを確認します NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE watson-vr-node-ingress LoadBalancer 172.29.77.196 3000:31202/TCP 下記コマンドを実⾏します。(コマンドは1⾏です) 下記コマンドを実⾏します。(コマンドは1⾏です) $ oc get node -o wide 出⼒: 下記の場合、マッピングされた外部ポートは31202 NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP OS-IMAGE KERNEL-VERSION CONTAINER-RUNTIME localhost Ready 26m v1.11.0+d4cacc0 192.168.64.19 CentOS Linux 7 (Core) 3.10.0-957.5.1.el7.x86_64 docker://1.13.1 出⼒: 下記の場合、アクセス可能なクラスターIPアドレスは192.168.64.19

Slide 56

Slide 56 text

¾Í—¤Ov”¿Î O¥ÌÓz”ž©§i„k vĠśipÃO² vĠśip!'”³Ð§ { êä| http://192.168.64.19:31202/ z”ž©§i„kI gåç{ǝ‘`ŷ]dqh] ”¿Î O¥ÌÓ|ĜŨvc„ipa «ӑȔiuěŦžŠiu…„i‰^

Slide 57

Slide 57 text

5-4. 追加ワークショップ (オプション) • Node-RED on Minishift https://github.com/yamachan/node-red-workshop- starter/blob/japanese-readme/README-ja.md • RedHat Japanのハンズオントレーニング ⽇本語訳 複数コンテナの連携: https://github.com/osonoi/minishift/tree/master/lab1 様々なデプロイメント⼿法: https://github.com/osonoi/minishift/tree/master/lab2

Slide 58

Slide 58 text

5-5. 補⾜ • Minishiftの停⽌コマンド $ minishift stop • Minishiftの起動、初期メモリ・ディスクの制限 $ minishift start --memory 2G --disk-size 10G --vm-driver • Minishift VM削除(VM再作成したい場合などに、、、) $ minishift delete • Minishift コマンドラインで作成したProjectをWebコンソール で表⽰(developerでログイン) $ oc policy add-role-to-user admin developer

Slide 59

Slide 59 text

IBM Code Patterns https://ibm.biz/ibmcodejp ŝƽ ±ÈěƉ ªO§¡O³bɧsp”¿ÎĊ캫OÓƒ

Slide 60

Slide 60 text

–“ Noew IBM Developer ibm.biz/IBMDevJP ġüşłˆ§Ï”®¿zƧĀt‘Ǣ_ƦDŽŢá‘ŧǒ

Slide 61

Slide 61 text

No content