首页
/ Oracle Kubernetes Installer输入变量配置详解

Oracle Kubernetes Installer输入变量配置详解

2025-06-19 05:18:31作者:蔡怀权

项目概述

Oracle Kubernetes Installer是一个基于Terraform的工具,用于在Oracle Cloud Infrastructure (OCI)上自动化部署Kubernetes集群。本文将深入解析该工具的核心配置参数,帮助用户根据实际需求定制化Kubernetes集群部署。

基础配置参数

必填OCI认证参数

这些参数是连接OCI API的基础认证信息,必须正确配置才能进行部署:

  • tenancy_ocid: OCI租户的唯一标识符
  • compartment_ocid: 资源将要部署到的隔离区的标识符
  • user_ocid: 执行部署操作的OCI用户标识符
  • fingerprint: 用户公钥指纹
  • private_key_path: 用户私钥文件路径
  • region: 资源部署区域,默认为us-phoenix-1

计算资源配置

实例规格配置

  • etcdShape: etcd节点实例规格,默认为VM.Standard1.1
  • k8sMasterShape: Kubernetes主节点实例规格
  • k8sWorkerShape: Kubernetes工作节点实例规格

负载均衡配置

  • master_oci_lb_enabled: 是否为主节点启用OCI负载均衡器
  • etcdLBShape: etcd集群负载均衡器带宽规格
  • k8sMasterLBShape: Kubernetes主节点负载均衡器带宽规格

可用域分布

可以配置各组件在不同可用域(Availability Domain)中的实例数量:

  • k8sMasterAd1Count: AD1中的主节点数量
  • k8sWorkerAd1Count: AD1中的工作节点数量
  • etcdAd1Count: AD1中的etcd节点数量
  • (类似参数适用于AD2和AD3)

存储卷配置

  • worker_iscsi_volume_create: 是否为工作节点创建iSCSI卷
  • worker_iscsi_volume_size: iSCSI卷大小(GB)
  • worker_iscsi_volume_mount: iSCSI卷挂载路径
  • (类似参数适用于etcd节点)

安全认证配置

TLS证书与SSH密钥

  • ca_cert: PEM编码的CA证书(自动生成)
  • ca_key: PEM编码的CA私钥(自动生成)
  • api_server_private_key: API服务器私钥
  • api_server_cert: API服务器证书
  • ssh_private_key: 实例SSH密钥对
  • ssh_public_key_openssh: OpenSSH格式公钥

网络配置

Flannel网络

  • flannel_network_cidr: Flannel使用的IP范围(CIDR格式)
  • flannel_backend: Flannel后端类型(VXLAN/UDP/host-gw)

网络访问模式

有三种网络访问配置模式:

  1. 公共网络访问(默认)

    • control_plane_subnet_access=public
    • 控制平面实例和负载均衡器部署在公共子网
    • 可直接通过公共IP访问
  2. 私有网络访问

    • control_plane_subnet_access=private
    • 所有资源部署在私有子网
    • 需要配置NAT实例进行出站通信
  3. 混合网络访问

    • 控制平面实例私有,负载均衡器公共
    • 平衡安全性和可访问性

安全组规则

可配置各组件允许访问的CIDR范围:

  • etcd_cluster_ingress: 允许访问etcd集群的IP范围
  • master_https_ingress: 允许访问主节点HTTPS端口的IP范围
  • worker_nodeport_ingress: 允许访问工作节点NodePort的IP范围

软件版本配置

可指定各组件版本:

  • docker_ver: Docker版本
  • etcd_ver: etcd版本
  • k8s_ver: Kubernetes版本
  • k8s_dashboard_ver: Kubernetes Dashboard版本
  • 各组件使用的Oracle Linux镜像名称

高级配置

Docker日志管理

可配置各组件Docker容器的日志轮转策略:

  • etcd_docker_max_log_size: etcd容器日志最大大小
  • etcd_docker_max_log_files: etcd日志保留数量
  • (类似参数适用于主节点和工作节点)

其他配置

  • label_prefix: 资源名称前缀(用于区分不同部署)
  • natInstanceShape: NAT实例规格
  • nat_instance_ad1_enabled: 是否在AD1启用NAT实例

最佳实践建议

  1. 生产环境建议使用私有网络访问模式,增强安全性
  2. 高可用部署应在多个可用域均匀分布实例
  3. 根据工作负载需求选择合适的实例规格
  4. 定期轮换TLS证书和SSH密钥
  5. 合理配置日志轮转策略,避免磁盘空间耗尽

通过合理配置这些参数,您可以构建出符合业务需求、安全可靠的Kubernetes集群环境。

登录后查看全文
热门项目推荐

热门内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K