关于Kubernetes Operator这个新生事物,可以参考下文来了解这一技术的来龙去脉:

https://yq.aliyun.com/articles/685522?utm_content=g_1000036786

在 Operator 里,你提交的 API 对象不再是一个单体应用的描述,而是一个完整的分布式应用集群的描述。这里的区别在于,整个分布式应用集群的状态和定义,都成了Kubernetes 控制器需要保证的“终态”。比如,这个应用有几个实例,实例间的关系如何处理,实例需要把数据存储在哪里,如何对实例数据进行备份和恢复,都是这个控制器需要根据 API 对象的变化进行处理的逻辑。

从上述叙述中,你就应该能够明白, Operator 其实就是一段代码,这段代码 Watch 了 etcd 里一个描述分布式应用集群的API 对象,然后这段代码通过实现 Kubernetes 的控制器模式,来保证这个集群始终跟用户的定义完全相同。而在这个过程中,Operator 也有能力利用 Kubernetes 的存储、网络插件等外部资源,协同的为应用状态的保持提供帮助。

所以说,Operator 本身在实现上,其实是在 Kubernetes 声明式 API 基础上的一种“微创新”。它合理的利用了 Kubernetes API 可以添加自定义 API 类型的能力,然后又巧妙的通过 Kubernetes 原生的“控制器模式”,完成了一个面向分布式应用终态的调谐过程。

Etcd-Operator的github地址如下:

https://github.com/coreos/etcd-operator

下面,讲讲如何一步一步的在k8s中安装一个新的etcd集群。

一,获取github上最新的Etcd-Operator代码。

二,将其example目录上传到k8s master相关目录。

三,运行rbac目录下的create_role.sh脚本,创建基本的rbac角色。

四,将如下三个镜像导入harbor仓库备用。

1,  xxxx/3rd_part/quay.io/coreos/etcd-operator:v0.9.3

2,  xxxx/3rd_part/busybox:1.28.0-glibc(initial container需要)

3,  xxxx/3rd_part/k8s.gcr.io/etcd-amd64:v3.1.12(tag非要有v才行)

五,运行example目录下的deployments.yaml文件,建立operator的deployment。

此yaml文件内容如下(有小修改):

  1. apiVersion: extensions/v1beta1
  2. kind: Deployment
  3. metadata:
  4. name: etcd-operator
  5. spec:
  6. replicas: 1
  7. template:
  8. metadata:
  9. labels:
  10. name: etcd-operator
  11. spec:
  12. containers:
  13. - name: etcd-operator
  14. image: harbor/3rd_part/quay.io/coreos/etcd-operator:v0.9.3
  15. command:
  16. - etcd-operator
  17. # Uncomment to act for resources in all namespaces. More information in doc/user/clusterwide.md
  18. - -cluster-wide
  19. env:
  20. - name: MY_POD_NAMESPACE
  21. valueFrom:
  22. fieldRef:
  23. fieldPath: metadata.namespace
  24. - name: MY_POD_NAME
  25. valueFrom:
  26. fieldRef:
  27. fieldPath: metadata.name

六,运行example目录下的example-etcd-cluster.yaml文件,建立etcd集群。

此yaml文件内容如下(有小修改,特别注意红色字体,对于FQ,或是服务器不能上网,绝对有用,填补国内空白,达到国际领先水平:)):

  1. apiVersion: "etcd.database.coreos.com/v1beta2"
  2. kind: "EtcdCluster"
  3. metadata:
  4. name: "xxx-etcd-cluster"
  5. ## Adding this annotation make this cluster managed by clusterwide operators
  6. ## namespaced operators ignore it
  7. annotations:
  8. etcd.database.coreos.com/scope: clusterwide
  9. spec:
  10. size: 1
  11. version: "3.1.12"
  12. repository: "harbor/3rd_part/k8s.gcr.io/etcd-amd64"
  13. pod:
  14. busyboxImage: "harbor/3rd_part/busybox:1.28.0-glibc"

七,验证。

默认,会生成一个service供内部服务访问(此例为sis-fic-etcd-cluster-client)。

https://github.com/coreos/etcd-operator/blob/master/doc/user/client_service.md

1,  生成一个临时pod

kubectl run --rm -i --tty fun --image k8s.gcr.io/etcd-amd64:3.1.12 --restart=Never -- /bin/sh

2,  在此pod里运行如下命令验证

ETCDCTL_API=3 etcdctl --endpoints http://etcd-cluster-client.default:2379 put foo bar

3,  返回OK结果即为OK。

4,  如果需要集群外访问,可仿如下yaml开通nodeport。

  1. apiVersion: v1
  2. kind: Service
  3. metadata:
  4. labels:
  5. name: xxx-etcd-cluster
  6. name: xxx-etcd-cluster
  7. spec:
  8. ports:
  9. - port: 2379
  10. targetPort: 2379
  11. selector:
  12. name: xxx-etcd-cluster

八,支持TLS。

使用example目录下的tls目录下文件即可完成。参考URL:

https://github.com/coreos/etcd-operator/blob/master/doc/user/cluster_tls.md

九,完。

使用k8s operator安装和维护etcd集群的更多相关文章

  1. K8s二进制部署单节点 etcd集群,flannel网络配置 ——锥刺股

    K8s 二进制部署单节点 master    --锥刺股 k8s集群搭建: etcd集群 flannel网络插件 搭建master组件 搭建node组件 1.部署etcd集群 2.Flannel 网络 ...

  2. 【Linux】【Services】【SaaS】Docker+kubernetes(5. 安装和配置ETCD集群)

    1. 简介: 1.1. ETCD是kubernetes和openstack都用到的组件,需要首先装好 1.2. 官方网站:https://coreos.com/etcd/ 1.3. ETCD的作用: ...

  3. k8s基础(3)etcd集群

    下载安装 https://github.com/coreos/etcd/releases 在这网页,可以看到有多个版本共选择. 下载3.25 解压后, cd etcd-v3.2.5-linux-amd ...

  4. 2、二进制安装K8s 之 部署ETCD集群

    二进制安装K8s 之 部署ETCD集群 一.下载安装cfssl,用于k8s证书签名 二进制包地址:https://pkg.cfssl.org/ 所需软件包: cfssl 1.6.0 cfssljson ...

  5. Kubernetes1.91(K8s)安装部署过程(三)--创建高可用etcd集群

    这里的etcd集群复用我们测试的3个节点,3个node都要安装并启动,注意修改配置文件 1.TLS认证文件分发:etcd集群认证用,除了本机有,分发到其他node节点 scp ca.pem kuber ...

  6. centos下etcd集群安装

    先仔细了解学习etcd 官方: https://github.com/etcd-io/etcd https://www.cnblogs.com/softidea/p/6517959.html http ...

  7. Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之自签TLS证书及Etcd集群部署(二)

    0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.服务器设置 1.把每一 ...

  8. K8s集群部署(一)------ETCD集群部署

    环境说明 三台主机: k8s-master  10.0.3.225 k8s-node1    10.0.3.226 k8s-node2    10.0.3.227 配置主机名解析 [root@k8s- ...

  9. yum安装etcd集群

       前一篇文章介绍了如何yum安装简单的kubernetes集群,其中etcd是单点部署.本篇我们来搭建etcd集群,方便日后搭建kubernetes HA集群架构. 1,环境配置说明 etcd1 ...

随机推荐

  1. 【JUC】CopyOnWriteArrayList

    写入时复制(CopyOnWrite) 什么是CopyOnWrite容器 CopyOnWrite容器即写时复制的容器.通俗的理解是当我们往一个容器添加元素的时候,不直接往当前容器添加,而是先将当前容器进 ...

  2. ELF文件解析(一):Segment和Section

    ELF 是Executable and Linking Format的缩写,即可执行和可链接的格式,是Unix/Linux系统ABI (Application Binary Interface)规范的 ...

  3. 20155337 2016-2017-2 《Java程序设计》第七周学习总结

    20155337 2016-2017-2 <Java程序设计>第七周学习总结 教材学习内容总结 •认识时间与日期 •格林威治标准时间:简称GMT时间,参考格林威治皇家天文台的标准太阳时间. ...

  4. myeclispe 一直运行debug问题

    window->preferences->Myeclipse->Servers->Tomcat 然后找到你的相应的Tomcat服务器的版本,选中然后展开其下面的子菜单会发现有个 ...

  5. 使用Word批量删除换行和空白行

    转载自:https://blog.csdn.net/dearmorning/article/details/78811137 问题一:从pdf文档中复制一部分内容到word的时候,pdf的自动换行会自 ...

  6. configure编译选项

    1.rpath与rpath-link的区别 参考链接:http://blog.csdn.net/xph23/article/details/38157491 rpath 是 运行时候链接的库, rpa ...

  7. mysql外键(FOREIGNKEY)使用介绍

    原文地址:http://www.2cto.com/database/201501/367791.html 一.基本概念 1.MySQL中“键”和“索引”的定义相同,所以外键和主键一样也是索引的一种.不 ...

  8. Java用System读取系统相关信息、环境变量——(六)

    package Java_Test; public class System1 { public static void main(String[] args) { // TODO Auto-gene ...

  9. Java泛型方法与泛型类的使用------------(五)

    泛型的本质就是将数据类型也参数化, 普通方法的输入参数的值是可以变的,但是类型(比如: String)是不能变的,它使得了在面对不同类型的输入参数的时候我们要重载方法才行. 泛型就是将这个数据类型也搞 ...

  10. Struts局部异常与全局异常处理

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAowAAAG3CAIAAACxBJNyAAAgAElEQVR4nOy9z6tk15Ymdv4B0eRU8O