Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
フロントエンジニアでも GKEの開発環境を作りたいっ!!
Search
Yasushi Asahi
February 14, 2019
Programming
490
0
Share
フロントエンジニアでも GKEの開発環境を作りたいっ!!
Yasushi Asahi
February 14, 2019
More Decks by Yasushi Asahi
See All by Yasushi Asahi
VueでCSSモジュールを使った感想
yasushiasahi
1
710
Other Decks in Programming
See All in Programming
Going Multiplatform with Your Android App (Android Makers 2026)
zsmb
2
350
安いハードウェアでVulkan
fadis
1
930
生成 AI 時代のスナップショットテストってやつを見せてあげますよ(α版)
ojun9
0
340
Coding as Prompting Since 2025
ragingwind
0
770
Linux Kernelの1文字のミスで 権限昇格ができた話
rqda
0
2.3k
AWS re:Invent 2025の少し振り返り + DevOps AgentとBacklogを連携させてみた
satoshi256kbyte
2
150
Reactive ❤️ Loom: A Forbidden Love Story
franz1981
2
230
実践ハーネスエンジニアリング #MOSHTech
kajitack
7
6k
おれのAgentic Coding 2026/03
tsukasagr
1
140
Nuxt Server Components
wattanx
0
260
PHP 7.4でもOpenTelemetryゼロコード計装がしたい! / PHPerKaigi 2026
arthur1
1
540
SkillがSkillを生む:QA観点出しを自動化した
sontixyou
6
3.1k
Featured
See All Featured
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
400
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
1
350
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
480
Embracing the Ebb and Flow
colly
88
5k
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
720
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
The B2B funnel & how to create a winning content strategy
katarinadahlin
PRO
1
330
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.3k
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
68
38k
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
89
Heart Work Chapter 1 - Part 1
lfama
PRO
5
35k
Transcript
フロントエンジニアでも GKEの開発環境を作りたいっ!!
自己紹介 名前 zero 本名:旭康史(あさひやすし) 所属 カラビナテクノロジー 仕事 フロントエンド 経歴 エンジニアとしは半年足らずのペーペーです(元々は広告の営業) 技術 React好き。Docker好き。Golang好き。TypeScript好き。 趣味 テレビアニメ鑑賞(今期の覇権は「わたてん」)
まずは作ったものをご紹介
Karabiner Members http://35.244.227.203/ 人の名前を覚えるのが苦手なので、入社したての 頃にメンバーの顔と名前を一致させるために作り ました。 こいつをGKE上で走らせています。 使用しているGCPのサービス ・Kubernates Engine(GCP上のkubernates環境) ・Container
Registry(Docker image置き場) ・Source Repositories(gitのレポジトリ) ・Cloud Build(自動ビルド、自動デプロイ)
Golang Ingress kubernetesクラスター httpリクエストの受け口 apiと静的ファイルの ルーティング 静的ファイルを返す apiサーバー 永続Volume pod
pod pod 構成図 Persistent Volumes DBサーバー pod
本日はこれの 開発&デプロイ環境のお話です
開発環境
Docker for Desktop(ローカルkubernates環境) ・おおむねGKEと同じように動かせる ・Docker for Mac(Docker for Windows)に付属さ れているので楽ちん
・Minikubeという方法もあるが別途インストールが 必要 ここから有効化できます。
・クラスタ内のコンテナのフォルダとローカ ルのフォルダをバインドする。 ・ここではローカルでwebpackから出力さ れたhtmlとjsをクラスタ内のnginxコンテ ナからも見れるようにしている。 本番用のyaml(一部抜粋) 開発用のyaml(一部抜粋) nginxコンテナ内の /usr/share/nginx/html と
ローカルのディレクトリ( webpackが生成するdistフォルダ) をバインドする。 使用するdocker imageを変更 プロセスが停止してもコンテナを維持 開発用の yamlを作る フロント編
開発用の yamlを作る サーバー編 ・フロントと同じ要領でコンテナとローカル のフォルダをバインド。 ・この場合はGolangの開発フォルダまる まるバインド。 ・ローカルでコードを変更するとクラスタ内 のGolangコンテナが検知して、再ビルド、 サーバー起動を行ってくれるように設定
する。 grm.sh Dockerfile_dev コンテナ起動時に この コマンドが実行される
demo①
思ったこと ・考え方は普通のDockerの開発環境と同じ(ディレクトリのバインド、ポートフォワード)。 ・本番用、開発用でyamlファイルが分かれてしまうので、管理方法を検討する必要がある。 helm、 kustomizeなど。 ・ローカルのパス指定はルートからの絶対パスしか受け付けてくれないので、 PCを変える時に書き換えが 必要
デプロイ環境
Cloud Build ・GCPが用意しているCI/CDサービス ・Container RegistryとSource Repositoriesを使っていれば認証関連を一切気にする必要がない。
トリガーを設定 ・コンソールからポチポチと設定すればト リガーを作れます。
ビルドステップを yamlで定義 ・yaml or Dockerfileでビルドステップを定 義します。 ・ここでは、 → docker imageをビルド
→ imageをRepositoryにpush → GKEのコンテナを更新 ということをしています。
demo②
思ったこと ・CI/CDを設定するのは初めてでしたが簡単でした。 ・やはり認証が必要ないことが大きい。
まとめ ・kubernatesは慣れると簡単 ・GCP内で物事を完結させると楽ち ん ・フロントエンドエンジニアでも構築 出来ました!!
ありがとうございました 旭康史
[email protected]
(株)カラビナテクノジー 801-0001 福岡市中央区天神1-2-4 農業共済ビル2F