CloudpodsGolang 实现的多云/混合云的云平台

联合创作 · 2023-09-27 11:53

Cloudpods是一个开源的Golang实现的云原生的融合多云/混合云的云平台,也就是一个“云上之云”。Cloudpods不仅可以管理本地的虚拟机和物理机资源,还可以管理多个云平台和云账号。Cloudpods隐藏了这些异构基础设施资源的数据模型和API的差异,对外暴露了一套统一的API,允许用户就像用一个云一样地访问多云。从而大大降低了访问多云的复杂度,提升了管理多云的效率。

谁需要Cloudpods?

  • 将几台物理服务器虚拟化成一个私有云平台
  • 需要一个紧凑而且功能相对完整的物理机全生命周期管理工具
  • 将VMware vSphere虚拟化集群转换为一个可以自服务的私有云平台
  • 在混合云的场景,能够在一个界面访问私有云和公有云
  • 通过一个集中的入口访问分布在多个公有云平台上的多个账号
  • 当前只使用一个云公有云账号但希望将来使用多云的用户

功能

Cloudpods提供了如下的功能:

  • 管理多云资源的功能,可以管理大多数的主流云,包括私有云,例如OpenStack,以及公有云,例如AWS,Azure,GCP,阿里云,华为云和腾讯云等
  • 允许以统一的联邦身份访问各个云平台的原生控制台的SSO
  • 一个可以管理海量KVM虚拟机的轻量级私有云
  • 一个能进行物理机全生命周期管理的裸机云
  • 实现了VMware vSphere虚拟化集群的自助服务和自动化
  • 一套功能丰富、统一一致的RESTAPI和模型访问以上的云资源和功能
  • 一套完整的多租户认证和访问控制体系
  • 自动将镜像转换为不同云平台需要的格式的多云镜像服务

支持的云平台

  • 公有云:
    • AWS
    • Azure
    • Google Cloud Platform
    • 阿里云
    • 华为云
    • 腾讯云
    • UCloud
    • 中国电信云
    • 中国移动云
    • 京东云
  • 私有云:
    • OpenStack
    • ZStack
    • AlibabaCloud Aspara (阿里飞天)
  • 本地基础设施资源:
    • KVM
    • VMWare vSphere vCenter/ESXi
    • Baremetals (IPMI, Redfish API)
    • Object storages (Minio, Ceph, XSky)
    • NAS (Ceph)

支持的云资源

  • Servers: instances, disks, network interfaces, networks, vpcs, storages, hosts, wires, snapshots, snapshot policies, security groups, elastic IPs, SSH keypairs, images
  • Load Balancers: instances, listeners, backend groups, backends, TSL certificates, ACLs
  • Object Storage: buckets, objects
  • NAS: file_systems, access_groups, mount_targets
  • RDS: instances, accounts, backups, databases, parameters, privileges
  • Elastic Cache: instances, accounts, backups, parameters
  • DNS: DNS zones, DNS records
  • VPC: VPCs, VPC peering, inter-VPC network, NAT gateway, DNAT/SNAT rules, route tables, route entries

快速开始

我们可以通过以下简单三步将Cloudpods安装在一台至少8GiB内存和100GB硬盘的Linux主机上(目前CentOS 7和Debian 10经过充分测试)

(下面假设该主机的IP为 10.168.26.216)

1. 准备SSH免密登录

# Generate the local ssh keypair
# (SKIP this stekp if you already have ~/.ssh/id_rsa.pub locally)
$ ssh-keygen
# Copy the generated ~/.ssh/id_rsa.pub public key to the machine to be deployed
$ ssh-copy-id -i ~/.ssh/id_rsa.pub root@10.168.26.216
# Try to login to the machine to be deployed without password,
# should be able to get the hostname of the deployed machine
# without entering the login password
$ ssh root@10.168.26.216 "hostname"

2. 安装git和相关工具

CentOS 7安装git和epel源

yum install -y git epel-release

Debian 10安装git

apt install -y git

3. 安装Cloudpods

通过以下命令开始安装Cloudpods:

# Git clone the ocboot installation tool locally
$ git clone https://github.com/yunionio/ocboot && cd ./ocboot && ./run.py 10.168.26.216

大概10-30分钟后,安装完成。访问 https://10.168.26.216 登入Cloudpods的Web控制台。初始的账号为 admin ,密码为 admin@123

请参考文档 快速开始 获得更详细的安装指导。

 

浏览 9
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报