GithubHelp home page GithubHelp logo

k8s_handson's Introduction

k8s_handson

Handson of k8s.

【 Step 0 】RDSの作成

【 Step 1 】ローカルDBを利用したWordpressの構築

ローカルDBの作成

  • ディレクトリ 1-wordpress_local_db の配下に進む

  • ローカルDB(MySQL)接続時の情報を保存するため、Secretを作成

# kubectl create secret generic local-mysql-secret-info --from-literal=DB_PASSWORD=${Your local db password}
  • MySQLのPVを作成する
# kubectl apply -f mysql-pv.yml
persistentvolume/mysql-pv created
  • MySQLのPVCを作成する
# kubectl apply -f mysql-pvc.yml
persistentvolumeclaim/mysql-pvc created
  • MySQLのDeploymentを作成する
# kubectl apply -f mysql.yml
deployment.extensions/mysql created
  • Wordpressからアクセスできるように、MySQLのServiceを作成する
# kubectl apply -f mysql-service.yml
service/mysql created
  • MySQLの諸確認
# kubectl get deploy,pv,pvc,svc

Wordpressの作成

  • WordpressのPVを作成する
# kubectl apply -f  wordpress-pv.yml
  • WordpressのPVCを作成する
# kubectl apply -f  wordpress-pvc.yml
  • WordpressのDeploymentを作成する
# kubectl apply -f  wordpress.yml
  • 外部からアクセスできるように、WordpressのServiceを作成する
# kubectl apply -f  wordpress-service.yml
  • Wordpressの諸確認
# kubectl get deploy,pv,pvc,svc
  • WordpressのServiceのIPを確認する
# kubectl get svc

【 Step 2 】ローカルDBからRDSへ切り替え

  • ディレクトリ 2-wordpress_rds の配下に進む

  • RDSの接続情報を設定する

export SECRET_NAME=mysql-secret-info
export DB_USER=wordpress
export DB_HOST={Your RDS intranet host}
export DB_PASSWORD={Your DB password}
  • RDSの接続情報をSecretに保存する
# kubectl create secret generic ${SECRET_NAME} \
--from-literal=DB_USER=${DB_USER} \
--from-literal=DB_HOST=${DB_HOST} \
--from-literal=DB_PASSWORD=${DB_PASSWORD}
  • WordpressのDeploymentを作り直す
kubectl apply -f wordpress.yml
  • WordpressのServiceを作り直す
kubectl apply -f wordpress-service.yml
  • 外部からアクセスしてみる

Ingressを利用したBlue/Green Deployment

  • ディレクトリ 3-ingress_blue_green の配下に進む

  • Blue環境のIngressを作成する

# kubectl apply -f ingress_blue.yml
  • IngressのIPを確認する
kubectl get ingres
  • ローカル環境にて、Blue環境へアクセスしてみる
curl -H "Host:wordpress.io" {Ingress_IP}
  • Green環境のNginxを作成する
# kubectl create deployment nginx --image nginx
deployment.apps/nginx created
  • Ingressからアクセスできるように、NginxのServiceを作成する
# kubectl expose deployment nginx --type NodePort --port 80
service/nginx exposed
  • Blue環境とGreen環境へのアクセスはそれぞれ50%にできるようなIngressを更新する
# kubectl apply -f ingress_blue_green.yml
ingress.extensions/ingress configured
  • ローカル環境にて、Blue/Green環境へアクセスしてみる
curl -H "Host:wordpress.io" {Ingress_IP}
  • Green環境へ切り替える
# kubectl apply -f ingress_green.yml
ingress.extensions/ingress configured
  • ローカル環境にて、Green環境へアクセスしてみる
curl -H "Host:wordpress.io" {Ingress_IP}

k8s_handson's People

Contributors

jobbin avatar marufeuille avatar

Stargazers

JimmyFu avatar  avatar

Watchers

James Cloos avatar  avatar

Forkers

marufeuille

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.