1. create consul

# kcompose convert -f /root/gitSwarm/dbcm-base-managers/compose/consul.yml

genetate two files:

consul-deployment.yaml  consul-service.yaml

# kubectl create -f consul-deployment.yaml -f consul-service.yaml

get consul cluster virtual ip:

# kubectl get svc consul

NAME      TYPE        CLUSTER-IP    EXTERNAL-IP   PORT(S)                                        AGE

consul    ClusterIP   10.0.54.163   <none>        8500/TCP,8300/TCP,8301/TCP,8302/TCP,8400/TCP   16h

2. create mysql

After put metadata to consul(no change):

# kcompose convert -f /root/gitSwarm/dbcm-base-managers/compose/mysql.yml

genetate two files:

mysql-deployment.yaml  mysql-service.yaml

modify mysql-deployment.yaml:

------------

spec.replicas = (instance number)

image = (mysql latest image)

env:

CLUSTER_ID

CONSUL = (consul cluster virtual ip)

-------------

# kubectl create -f mysql-deployment.yaml -f mysql-service.yaml

# kubectl get po -l io.kompose.service=mysql

NAME                     READY     STATUS    RESTARTS   AGE

mysql-5b5d895b79-gxrbl   1/1       Running   0          2h

mysql-5b5d895b79-s9j5k   1/1       Running   0          2h

note:

consul service name no change

service id changes to mysql-all-{pod name}  mysql-primary-{pod name}

just like "mysql-all-mysql-5b5d895b79-gxrbl"  "mysql-primary-mysql-5b5d895b79-gxrb2"

3. scale cluster

# kubectl scale -f mysql-deployment.yaml --replicas=3

auto scale:

# kubectl autoscale -f mysql-deployment.yaml --min=2 --max=5 --cpu-percent=70

4. delete cluster

# kubectl delete -f mysql-deployment.yaml

5. get node log

# kubectl logs mysql-5b5d895b79-gxrbl(pod name)

6. RollingUpdate

# kubectl set image deployment/mysql mysql=registry.bst-1.cns.bstjpc.com:5000/dbelt/mysql-ms-mysql-v5.6.36-v0.5.0:20180206_update

check update status

# kubectl rollout status deployment/mysql

rollback

# kubectl rollout undo deployment/mysql

7. multiAZ

# kubectl label nodes mhc zone=beijing

modify mysql-deployment.yaml:

add:

spec.nodeSelector.zone=north

8. run command

kubectl exec [flag] pod_name shell_command

# kubectl exec -ti mysql-55d5cbc5c4-fjgfj bash

9. resize

resize:

kubectl set resources deployment nginx-deployment -c=nginx --limits=cpu=200m,memory=512Mi

lack:

1. stop/restart cluster

2. get cluster log

other:

1. make deployment name unique

[root@mhc k8s]# kubectl label pod consul-5f557878f4-974hw role=master
pod "consul-5f557878f4-974hw" labeled
[root@mhc k8s]#
[root@mhc k8s]# kubectl label pod consul-5f557878f4-hg6sh role=slave
pod "consul-5f557878f4-hg6sh" labeled
[root@mhc k8s]# kubectl get po -l role=master
NAME                      READY     STATUS    RESTARTS   AGE
consul-5f557878f4-974hw   1/1       Running   0          17h

1. https://github.com/kubernetes/kompose

2. https://github.com/kubernetes/kubernetes

dbcm with kubenetes的更多相关文章

  1. 使用kubeadm平滑地升级kubenetes集群(v1.10.2到v1.10.3)

    写在前面 kubernetes是目前最炙手火热的容器管理.调度.编排平台,不仅拥有全面的生态系统,而且还开源.开放自治,谁贡献的多,谁的话语权就大,云提供商都有专门的工程师来从事kubernetes开 ...

  2. Kubenetes 资源清单定义入门

    Kubernetes 常用资源 资源  对象 工作负载型资源对象(workload): Pod  Replicaset  ReplicationController  Deployments Stat ...

  3. kubenetes安装记录和要点

    https://blog.csdn.net/jinglexy/article/details/79813546 在官网web上进行kubenetes测试:kubectl run kubernetes- ...

  4. kubenetes master使用curl 操作API

    前提条件: 已经使用kubeadm 安装集群 查看 kebelet.conf 配置内容 kubectl --kubeconfig /etc/kubernetes/kubelet.conf config ...

  5. Rancher2.3.2部署Kubenetes Dashboard

    首先进入到集群中的System命令空间,因为kubenetes dashboard是给整个集群使用的,并不是默认的Default命名空间使用的 Default命名空间,是默认的命名空间,也是在部署其他 ...

  6. Docker & Kubenetes 系列四:集群,扩容,升级,回滚

    本篇将会讲解应用部署到Kubenetes集群,集群副本集查看,集群自愈能力演示,集群扩容,滚动升级,以及回滚. 本篇是Docker&Kubenetes系列的第四篇,在前面的篇幅中,我们向Kub ...

  7. K8s炼气期(一)| minikube安装本地Kubenetes环境

    前言 根据Kubenetes学习路径的七大阶段,炼气期.筑基期.金丹期.元婴期.化神期.炼虚期.大乘期:开始炼气期的第一个小阶段,安装Kubenetes环境. 目录 1.安装kubectl 2.安装m ...

  8. 利用shell脚本使用kubeadm部署kubenetes 1.18.6集群环境

    # README # 此脚本需要在master节点上使用 # 注意root密码,请提前修改 # 个人实验环境,注意机器最低配置:master(2G内存,1cpu2核心,否则集群会创建失败),node( ...

  9. kubenetes 环境的塔建

    最近听我朋友说他们公司准备上云,全线把服务迁到 k8s 上面,一下感觉,我们就 lower 了不少,之前服务器一直跑的就是 docker ,想想弄到 k8s 应该还是没有啥,于是我们也开始改造了 参考 ...

随机推荐

  1. 接口测试框架——第六篇-读Excel封装方法

    谢谢@小麦苹果的提醒,才发现我借口测试少写了一个文件,今天给大家补上: common->service->excel_case_data.py # coding: utf-8 import ...

  2. 接口结构+一个selenium例子

    大家今天可以先建一个项目目录,明天我们在码代码: 我看好多朋友都在看selenium方面的东西,在这里给大家一个和讯网自动发文章的selenium代码,有兴趣的朋友可以试试,船长已亲测可用,不明白的地 ...

  3. 连电子硬件行业都在开始使用 Git 了你还在等什么?

    连电子硬件行业都在开始使用 Git 了你还在等什么? 无论二进制还是文本 Git 都可以管理. 相对于电子行业传统的复制粘贴式的版本管理, git 的版本管理先进太多太多了,没有理由不用. 虽然做不到 ...

  4. undefined vs. null

    undefined vs. null 一.相似性 在JavaScript中,将一个变量赋值为undefined或null,老实说,几乎没区别. var a = undefined; var a = n ...

  5. oracle的时间

    今天发现之前从oracle导出的数据时间格式很奇怪: "ACTIVETIME","ACTIVITYID" "2018-08-10 06:08:43&q ...

  6. ubuntu :安装skype聊天工具

    如题,今天就想搞个软件在ubuntu能聊天,查一下skype,好像网上有人说不是每个安装包都用的了,skype-ubuntu-precise_4.2.0.13-1_i386.deb可以, 我在微盘下载 ...

  7. emacs之配置etags-select

    etags-select比自带的etags定位的更好 ~/emacsConfig/etags-select-setting.el (require 'etags-select) (global-set ...

  8. linux命令ls -l的默认排序方式

    差不多快实现完了ls -l,但是在测试阶段发现一个问题,对于包含[a-ZA-Z]之外的字符,系统的排序方式并不一样. 很想了会儿,总算发现原来它的排序方式是无视[a-ZA-Z]之外的字符的 至于怎么发 ...

  9. FPGA的新变化

    FPGA SoC通过融合FPGA和ASIC两者的元件,跨越了灵活性和性能之间的界限.但随着它们进入高安全性.任务关键型市场,它们也面临着与标准SoC相同的问题,包括在日益复杂的器件中快速传输越来越多的 ...

  10. send函数和recv函数

    1.send 函数 int send( SOCKET s, const char FAR *buf, int len, int flags );   不论是客户还是服务器应用程序都用send函数来向T ...