Compute :Nova 根据需求提供虚拟机服务
主要组件{
nova-api:Nova对外提供的窗口,接受并响应来自用户的Compute API的调用等
nova-compute:是安装到每个物理主机上的服务进程,这个服务接收请求之后执行一批与虚拟机相关的操作,这些操作需要调用底层的Hypervisor完成。
nova-scheduler:用于接收创建虚拟机的请求,并决定在物理主机机上启动该虚拟机的调度器
nova-conductor:处于nova-compute和nova-db之间的一个组件,nova-conductor建立的初衷是基于安全的考虑而避免nova-compute直接访问nova-db的。
nova-network:包含很多数据库表等,记录了虚拟机状态、虚拟机与物理机的对应关系、租户信息等数据内容。
nova-concole:同nova-consoleauth 是Nova提供的控制台服务,允许最终用户通过代理服务器访问虚拟机的控制台。
nova-consoleauth,
nova-cert: 和nova-objectstore 分别提供了x509验证管理服务和在glance中注册镜像的S3接口服务。
nova-objectstore,
nova-db
}
Object Storage : Swift 存储或检索对象,也可以认为它允许存储或检索文件,它以低成本的方式通过RESTFUL API管理大量无结构数据
主要组件{
proxy-server:处于Swift系统内部和外部之间,它负责接收API或Http请求,这些请求包含上传文件、修改元数据、创建容器等。
account-server:仅用于账号管理。
container-server:管理容器与文件夹的映射关系。
object-server:管理存储节点上的实际对象,比如文件等。
}
Identity: Keystone 为所有OpenStack 服务提供身份授权和认证,跟踪用户以及他们的权限,提供一个可服务的API的列表。
Dashboard: Horizon 它为所有OpenStack的服务提供一个模块化的基于Django的界面,通过这个界面,用户和运维人员可以完成大多数操作。
Block Storage: Cinder 提供块级存储服务。由nova-volume 演化而来。
主要组件{
cinder-api:接收来自外部的api请求,并把请求交给cinder-volume执行。
cinder-volume:负责和底层的块存储服务打交道,它响应和读写块设备请求,并把这个请求交给块存储服务,底层不同存储服务提供商都通过driver的方式
实现了volumeprovider,所以具体的读写请求交给地城volumeprovider来实现。
cinder-db,
volumeprovider,
cinder-scheduler:与nova-scheduler 类似,由于底层提供的存储节点很多,cinder-scheduler会试图寻找一个最佳节点创建volume。
}
Network: Neutron 用于提供网络服务,允许用户建立自己的网络并连接各种网络设备接口,
Image Service: Glance 它是OpenStack的镜像服务组件,相对于其他组件来说,这一部分的比较单一,代码量也比较少。主要提供一个虚拟机的镜像存储
查询和检索服务。通过提供一个虚拟磁盘映像的目录和存储库,为Nova的虚拟机提供镜像服务。
主要组件{
glance-api:接收来自外部的API镜像请求,这些请求包括镜像发现,获取及存储。
glance-registry:用户存储、处理和获取镜像元数据。
glance-db:存储元数据
}