Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
技術領域から考える Webバックエンドロードマップ Yuki Watanabe (@ukwhatn) from KINDAI Info-Tech HUB
Slide 2
Slide 2 text
SPEAKER ● 渡邉 雄貴 / Yuki Watanabe ○ 近畿大学 理工学部 B3 ■ KINDAI Info-Tech HUB 役員 ■ KC3運営委員会(NPO法人NxTEND) 理事 ○ Webバックエンド・インフラエンジニア ■ 長期インターンシップ・業務委託での開発 ■ 転職型プログラミングスクール メンター
Slide 3
Slide 3 text
SPEAKER ● 渡邉 雄貴 / Yuki Watanabe ○ SKILLS ■ Webバックエンド ● Ruby(Rails) / Python(FastAPI, Flask) / Kotlin / TS ■ Webフロントエンド ● TS(React) / JS / HTML-CSS ■ インフラ・その他 ● Linux / AWS / Docker / DB / 認証・認可
Slide 4
Slide 4 text
今日お話すること Webバックエンドとは? 何がバックエンドなのか / 構成技術は何なのか 01 具体的なロードマップ どう学習していけば良いのか 02 学習のコツ 膨大な技術領域を学習していく方法 03
Slide 5
Slide 5 text
Webバックエンドとは?
Slide 6
Slide 6 text
Webバックエンドとは? ● Webバックエンド ○ サーバで行われる処理を担う部分 ■ Webアプリケーションだけでなく、 モバイルでもゲームでも、バックエンドは大抵Web技術 ○ 関連する技術領域 ■ API / RDBMS / NoSQL / Webセキュリティ / Webサーバ CI・CD / インフラ / フロントエンド
Slide 7
Slide 7 text
関連する技術領域(一部) Webバックエンドとは? バックエンドの処理を記述するための言語を知らないと始まりません。 大抵の(主要な)言語にはWebアプリケーションを作成するためのフレームワークが 存在しているので、お好きな言語で取り組んでみるのが良いでしょう。 プログラミング言語・フレームワーク Web API モダンなWebバックエンドの主な仕事は、フロントエンド(Reactなど)からの リクエストに応じて処理を行い、レスポンスを行うことです。 ここには「Web API」が使われることがほとんどです。
Slide 8
Slide 8 text
Webバックエンドとは? Appがデータを保存しておくのに必要なのがデータベースです。 MySQL/MariaDBやPostgreSQLに代表されるRDBMSや、MongoDBや AWS DocumentDBなどのDocDB、RedisなどのKVSなど、多くの種類があります。 RDBMS・NoSQL Webセキュリティ Webアプリケーションを安全に提供し、ユーザの情報が侵害されないようにするため には、セキュリティの知識が不可欠です。XSSやCSRF、セッションハイジャック、 SQLインジェクションなど、絶対に抑えておくべきものもいくつかあります。 関連する技術領域(一部)
Slide 9
Slide 9 text
Webバックエンドとは? Webアプリケーションは、NginxやApache HTTP ServerなどのWebサーバソフトに よってインターネットからのアクセスを受け付けます。多くのフレームワークには Devサーバ機能がありますが、Prod環境では別で用意することが一般的です。 Webサーバ インフラ Webアプリケーションを実行する基盤となるインフラ(サーバやNW, 仮想化など)に 関する基本的な知識もバックエンドエンジニアには必要です。最近はVercel等で 簡単にホストできますが、それでも知識として持っておく必要はあります。 関連する技術領域(一部)
Slide 10
Slide 10 text
Webバックエンドとは? Continuous Integration / Delivery / Deploymentの略で、主にテストやビルド、 デプロイの自動化を指します。最近は個人〜企業までGitHub Actionsを利用する ことが多くなっています。 CI・CD フロントエンド バックエンドエンジニアがWebAppを個人開発する上で必要なのがUIです。APIを 作って終わりではなく、ユーザが触ることのできるUIを作成してはじめて使ってもら うことができるので、最低限のフロントエンドへの知識が必要です。 関連する技術領域(一部)
Slide 11
Slide 11 text
具体的なロードマップ
Slide 12
Slide 12 text
Webバックエンドエンジニアになるには? 具体的なロードマップ https://roadmap.sh/backend より
Slide 13
Slide 13 text
Webバックエンドエンジニアになるには? 具体的なロードマップ https://roadmap.sh/backend より
Slide 14
Slide 14 text
Webバックエンドエンジニアになるには? 具体的なロードマップ https://roadmap.sh/backend より
Slide 15
Slide 15 text
Webバックエンドエンジニアになるには? 具体的なロードマップ https://roadmap.sh/backend より
Slide 16
Slide 16 text
Webバックエンドエンジニアになるには? 具体的なロードマップ https://roadmap.sh/backend より
Slide 17
Slide 17 text
Webバックエンドエンジニアになるには? 具体的なロードマップ https://roadmap.sh/backend より
Slide 18
Slide 18 text
学習のコツ 膨大な技術領域をどうキャッチアップするか
Slide 19
Slide 19 text
各要素技術のキャッチアップ ● 手を動かす ○ これに尽きる! ■ 知識も大切ですが、実践が伴わなければ身に付かず、 作りたいものを形にする力も育ちません ■ シンプルに形にならないのに勉強し続けるのつらいです ■ まずは簡単なもので良いので、なにか作ってみましょう 学習のコツ
Slide 20
Slide 20 text
各要素技術のキャッチアップ ● 好きな言語でやる ○ テンション上がらない言語でやるのつらい ■ 主要な言語であればたいていフレームワークがある ■ 1つの言語でできれば、大抵の言語でできるようになる ■ 書いてて楽しいことが大事! 学習のコツ
Slide 21
Slide 21 text
各要素技術のキャッチアップ ● 必要になったときに調べて実装する ○ 最初から全部勉強するのはムリ! ■ インプットだけで数年経っちゃうので、 作りたいものに必要な実装方法だけをとりあえず調べる ■ 繰り返していけば、いつのまにかできることが増えている ● 一回で学ぶ量を最小限にして、 「できた!」を増やすことが大切 学習のコツ
Slide 22
Slide 22 text
各要素技術のキャッチアップ ● 詳しいことは後から勉強する ○ とりあえず実装方法だけ調べてやってみる ■ 実装中は「こうやればできるんだな」にとどめておいて、 後から「どういう仕組みだったんだろう」に入る ● 実装はノリが大切 一旦休むと再開するためのコストが高い ■ 後からちゃんと分かって、その上で修正したほうが楽しい 学習のコツ
Slide 23
Slide 23 text
各要素技術のキャッチアップ ● 技術書を読む ○ ネットだけでは効率が悪い! ■ ネット上の記事は玉石混交(石多め) ● 取捨選択だけでも時間がかかるし難しい ■ 実績ある著者がまとめてくれた技術書はインプットに最適 ■ デメリット:高い ● 学校の図書館の購入申請などをうまく使おう! 学習のコツ
Slide 24
Slide 24 text
各要素技術のキャッチアップ ● おすすめ技術書 ○ 〇〇Webアプリケーション入門 ■ とりあえず好きな言語でやれ ○ Web技術がこれ一冊でしっかりわかる教科書 ■ 概観を掴むのにおすすめ ○ プロになるためのWeb技術入門 ■ これわか読んでから読むとめっちゃわかる 学習のコツ
Slide 25
Slide 25 text
各要素技術のキャッチアップ ● おすすめ技術書(中級者向け) ○ Web技術 ■ Webを支える技術, Real World HTTP, Web配信の技術 ○ セキュリティ ■ 徳丸本, フロントエンド開発のためのセキュリティ入門 ○ DB ■ 達人に学ぶDB設計/SQL, おうちで学べるDBのきほん 学習のコツ
Slide 26
Slide 26 text
各要素技術のキャッチアップ ● おすすめ技術書(中級者向け) ○ 仮想化・サーバ ■ DockerとKubernetes, Linuxのしくみ(増補改訂版) ○ クラウド ■ ベンダー資格のテキスト (Solution Architectからがおすすめ) ○ その他 ■ 各技術・FWの公式ドキュメント・チュートリアル 学習のコツ
Slide 27
Slide 27 text
Webバックエンド、やりませんか? ご清聴ありがとうございました