经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Kubernetes » 查看文章
K8S helm
来源:cnblogs  作者:klvchen  时间:2018/12/7 9:14:08  对本文有异议

Helm 致力于成为 Kubernetes 的包管理工具,可以方便地发现、共享和构建 Kubernetes 应用,它包含几个基本概念:

  • Chart:一个 Helm 包,其中包含了运行一个应用所需要的镜像、依赖和资源定义等,还可能包含 Kubernetes 集群中的服务定义,类似 Homebrew 中的 formula,APT 的 dpkg 或者 Yum 的 rpm 文件;
  • Release: 在 Kubernetes 集群上运行的 Chart 的一个实例。在同一个集群上,一个 Chart 可以安装很多次。每次安装都会创建一个新的 release。例如一个 MySQL Chart,如果想在服务器上运行两个数据库,就可以把这个 Chart 安装两次。每次安装都会生成自己的 Release,会有自己的 Release 名称;
  • Repository:用于发布和存储 Chart 的仓库

Helm 组件
Helm 采用客户端/服务器架构,有如下组件组成:
helm : 客户端,管理本地的 Chart 仓库,管理 Chart, 与 Tiller 服务器交互,发送 Chart, 实例安装,查询,卸载等操作
Tiller : 服务端,接收 helm 发来的 Charts 与 Config,合并生成 release
Repository : Chart 仓库,Helm客户端通过HTTP协议来访问仓库中Chart的索引文件和压缩包

RBAC配置文件示例:
https://github.com/helm/helm/blob/master/docs/rbac.md

官方可用的Chart列表:
https://hub.kubeapps.com

helm常用命令:

  1. release管理:
    install
    delete
    upgrade/rollback
    list
    history:release的历史信息
    status 获取release状态信息

  2. chart管理:
    create
    inspect
    package
    verify

  1. # 删除其他 pods
  2. kubectl delete deployment myapp-deploy
  3. mkdir helm
  4. cd helm/
  5. # 没法下载,去国外的服务器上下载
  6. wget https://storage.googleapis.com/kubernetes-helm/helm-v2.9.1-linux-amd64.tar.gz
  7. tar zxf helm-v2.9.1-linux-amd64.tar.gz
  8. cd linux-amd64
  9. mv helm /usr/bin
  10. # 配置权限
  11. cat tiller-rbac.yaml
  12. apiVersion: v1
  13. kind: ServiceAccount
  14. metadata:
  15. name: tiller
  16. namespace: kube-system
  17. ---
  18. apiVersion: rbac.authorization.k8s.io/v1beta1
  19. kind: ClusterRoleBinding
  20. metadata:
  21. name: tiller
  22. roleRef:
  23. apiGroup: rbac.authorization.k8s.io
  24. kind: ClusterRole
  25. name: cluster-admin
  26. subjects:
  27. - kind: ServiceAccount
  28. name: tiller
  29. namespace: kube-system
  30. kubectl apply -f tiller-rbac.yaml
  31. # 因为 gcr.io/kubernetes-helm/tiller:v2.9.1 这个镜像需要从国外下载,所以我提前导入 node1 和 node2 节点
  32. # 初始化
  33. helm init --service-account tiller
  34. kubectl get pods -n kube-system
  35. # 看到下面 pod 正常运行
  36. tiller-deploy-759cb9df9-jbk2r 1/1 Running 0 1h
  37. # 查看版本信息
  38. helm version
  39. # 查看源
  40. helm repo list
  41. # helm 替换国内的 repo
  42. helm repo remove stable
  43. helm repo add stable https://burdenbear.github.io/kube-charts-mirror/
  44. # 查找
  45. helm search memcached
  46. helm inspect stable/memcached
  47. # 尝试安装 redis
  48. helm install --name redis1 stable/redis
  49. # 因为没有 pv,所以没法成功创建
  50. helm delete redis1
  51. # 修改配置
  52. cd ~/.helm/cache/archive
  53. tar zxf redis-5.1.0.tgz
  54. cp redis/values.yaml ~/helm/
  55. cd ~/helm/
  56. # 修改下面的两个参数,不使用 pv
  57. vi values.yaml
  58. cluster:
  59. enabled: false
  60. persistence:
  61. enabled: false
  62. # 再次安装 redis
  63. helm install --name redis1 -f values.yaml stable/redis
  64. kubectl get pods
  65. # 运行结果:
  66. NAME READY STATUS RESTARTS AGE
  67. redis1-master-0 1/1 Running 0 1m
  68. # 获取 release 状态信息
  69. helm status redis1
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号