dbcm with kubenetes
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的更多相关文章
- 使用kubeadm平滑地升级kubenetes集群(v1.10.2到v1.10.3)
写在前面 kubernetes是目前最炙手火热的容器管理.调度.编排平台,不仅拥有全面的生态系统,而且还开源.开放自治,谁贡献的多,谁的话语权就大,云提供商都有专门的工程师来从事kubernetes开 ...
- Kubenetes 资源清单定义入门
Kubernetes 常用资源 资源 对象 工作负载型资源对象(workload): Pod Replicaset ReplicationController Deployments Stat ...
- kubenetes安装记录和要点
https://blog.csdn.net/jinglexy/article/details/79813546 在官网web上进行kubenetes测试:kubectl run kubernetes- ...
- kubenetes master使用curl 操作API
前提条件: 已经使用kubeadm 安装集群 查看 kebelet.conf 配置内容 kubectl --kubeconfig /etc/kubernetes/kubelet.conf config ...
- Rancher2.3.2部署Kubenetes Dashboard
首先进入到集群中的System命令空间,因为kubenetes dashboard是给整个集群使用的,并不是默认的Default命名空间使用的 Default命名空间,是默认的命名空间,也是在部署其他 ...
- Docker & Kubenetes 系列四:集群,扩容,升级,回滚
本篇将会讲解应用部署到Kubenetes集群,集群副本集查看,集群自愈能力演示,集群扩容,滚动升级,以及回滚. 本篇是Docker&Kubenetes系列的第四篇,在前面的篇幅中,我们向Kub ...
- K8s炼气期(一)| minikube安装本地Kubenetes环境
前言 根据Kubenetes学习路径的七大阶段,炼气期.筑基期.金丹期.元婴期.化神期.炼虚期.大乘期:开始炼气期的第一个小阶段,安装Kubenetes环境. 目录 1.安装kubectl 2.安装m ...
- 利用shell脚本使用kubeadm部署kubenetes 1.18.6集群环境
# README # 此脚本需要在master节点上使用 # 注意root密码,请提前修改 # 个人实验环境,注意机器最低配置:master(2G内存,1cpu2核心,否则集群会创建失败),node( ...
- kubenetes 环境的塔建
最近听我朋友说他们公司准备上云,全线把服务迁到 k8s 上面,一下感觉,我们就 lower 了不少,之前服务器一直跑的就是 docker ,想想弄到 k8s 应该还是没有啥,于是我们也开始改造了 参考 ...
随机推荐
- ubuntu 新手帖
作为菜鸟,接触ubuntu的时间不长,遇到一些问题,在这总结一下,可能不全不完善,但是希望能有用: 1,ubuntu 12.04的gedit打开中文记事本全是乱码的处理 参考:http://bbs.c ...
- <mvc:annotation-driven>注册了什么
前言 上一篇文章dispatcherservlet初始化中提到,如果没有配置handlermapping就会采取默认的策略进行配置handlermapping,这篇文章就要讲述mvc:annotati ...
- MTK-shot mode
enum EShotMode{ eShotMode_NormalShot, /*!< Normal Shot */ eShotMo ...
- flannel vxlan 实现原理【转】
flannel是coreos为kubernets提供的网络解决方案,主要为打通跨节点的容器通信,其中vxlan模式为flannel实现的一种后端模式,其他模式还包括udp, host-gw等,可以通过 ...
- mysql执行导入导出数据源
mysql执行导入导出数据源 一.导出数据表结构 导出数据库建表的结构,不带数据,windows环境下,在cmd下,执行: mysqldump –no-data –u username –p* dat ...
- 进程间通信IPC之--无名管道(pipe)和有名管道(fifo)(转)
进程间通信IPC之--无名管道(pipe)和有名管道(fifo) 2012-01-17 22:41:20 分类: C/C++ 每个进程各自有不同的用户地址空间,任何一个进 程的全局变量在另一个进程中 ...
- 在centOS5.9安装mysql
网上的信息实在是太乱了,好多出了错的,我这个是自己亲自配置,其实就简简单单的几步:如果你的系统里有以前遗留的文件,用rm -rf文件名删除掉 1.安装MySQL客服端和服务器端 ...
- DjangoORM执行原生sql
在Django中使用原生Sql主要有以下几种方式: 一:extra:结果集修改器,一种提供额外查询参数的机制 二:raw:执行原始sql并返回模型实例 三:直接执行自定义Sql 这种方式完全不依赖 ...
- 记录关于ubuntu无线上网只能ping通5~7个数据包的问题
问题是这样的,我的笔记本(ubuntu desktop)连接上wifi后,信号很好,但是上网上不了,ping网关也不通,ping外网仅仅只有当笔记本刚刚连接上wifi的时候能ping通5至6个包,然后 ...
- 用IO字节流复制文件-CopyFileByIo
import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import ...