CloudStack 是一种基于硬件虚拟化原则(传统 IaaS 概念)用来构建公有云和私有云的软件。要在 CloudStack 上部署 Kubernetes, 有几种可能性取决于正在使用的云以及可用的镜像。CloudStack 还提供了一个 vagrant 插件,因此 vagrant 可以使用现有的 shell 创建程序,或新的基于 Salt 的方法来部署 Kubernetes。
CloudStack 的 CoreOS 模板会每夜构建。 CloudStack operators 需要在他们的云中 注册这个模板,然后才能继续执行 Kubernetes 部署的命令。
本指南只用到一个 Ansible playbook,完全自动化,可以使用 CoreOS 镜像在基于 CloudStack 的云上部署 Kubernetes。playbook 会创建 ssh 密钥对、创建安全组和相关规则,最后启动通过 cloud-init 配置的 CoreOS 实例。
sudo apt-get install -y python-pip libssl-dev
sudo pip install cs
sudo pip install sshpubkeys
sudo apt-get install software-properties-common
sudo apt-add-repository ppa:ansible/ansible
sudo apt-get update
sudo apt-get install ansible
在 CloudStack 服务器上,您还必须安装 libselinux-python:
yum install libselinux-python
cs 是 CloudStack API 的 python 模块。
设置所使用的 CloudStack 端点、API 键和 HTTP 方法。
你可以将它们定义为环境变量:CLOUDSTACK_ENDPOINT
、CLOUDSTACK_KEY
、CLOUDSTACK_SECRET
和 CLOUDSTACK_METHOD
。
或者创建一个 ~/.cloudstack.ini
文件:
[cloudstack]
endpoint = <your cloudstack api endpoint>
key = <your api access key>
secret = <your api secret key>
method = post
我们需要使用 http POST 方法将 large userdata 传递给 coreOS 实例。
git clone https://github.com/apachecloudstack/k8s
cd kubernetes-cloudstack
你只需要运行 playbook 即可。
ansible-playbook k8s.yml
可以在 k8s.yml
文件中编辑某些变量。
vars:
ssh_key: k8s
k8s_num_nodes: 2
k8s_security_group_name: k8s
k8s_node_prefix: k8s2
k8s_template: <templatename>
k8s_instance_type: <serviceofferingname>
这将启动一个 Kubernetes 主节点和一些计算节点(默认情况下为 2)。
instance_type
和模板
是特定的,编辑它们可以指定特定于 CloudStack 云的模板和实例类型(即服务提供)。
如果您想修改任何内容,请检查 roles/k8s
中的任务和模板。
一旦副本完成,它将打印出 Kubernetes 主节点的IP:
TASK: [k8s | debug msg='k8s master IP is {{ k8s_master.default_ip }}'] ********
使用创建的密钥和 core 用户 SSH 到它。
ssh -i ~/.ssh/id_rsa_k8s core@<master IP>
您可以列出群集中的计算机:
fleetctl list-machines
MACHINE IP METADATA
a017c422... <node #1 IP> role=node
ad13bf84... <master IP> role=master
e9af8293... <node #2 IP> role=node
IaaS 供应商 | 配置管理 | 操作系统 | 网络 | 文档 | 合规 | 支持级别 |
---|---|---|---|---|---|---|
CloudStack | Ansible | CoreOS | flannel | 文档 | 社区 (@Guiques) |
有关所有解决方案的支持级别信息,请查看解决方案图表。
此页是否对您有帮助?
Thanks for the feedback. If you have a specific, answerable question about how to use Kubernetes, ask it on Stack Overflow. Open an issue in the GitHub repo if you want to report a problem or suggest an improvement.