CloudStack+KVM环境搭建

2024-06-24 04:38
文章标签 搭建 环境 kvm cloudstack

本文主要是介绍CloudStack+KVM环境搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 环境准备
          • 配置本地域名解析
          • 关闭selinux
          • 安装ntp服务
      • 安装管理端
          • 安装Mysql数据库
          • 安装服务端RPM:
          • 初始化CloudStack数据库:
          • 初始化cloudstack管理服务器
          • 安装系统虚拟机
      • 安装Agent端
      • 创建Zone(资源域)

本文以4.11.1.0版本为例,使用的hypervisor类型为KVM,操作系统为RedHat7/CentOS7,官方安装文档参考:http://docs.cloudstack.apache.org/projects/cloudstack-installation/en/4.11/qig.html

环境准备

一套基本的CloudStack环境,包括一台CloudStack管理端(cloudstack-management),一个mysql数据库,若干台支持KVM虚拟化的计算节点(cloudstack-agent)以及一台用来做为二级存储的nfs服务器:
这里写图片描述

在实际生产中,mysql数据库和管理端都可能配备多台作为高可用,计算节点一般也是配置较高的物理服务器,但在实验环境,我们可以采用最小化安装模式,把mysql,nfs和管理端安装在同一台虚拟机上,使用一台支持KVM虚拟化的虚拟机(而不用使用真实的物理服务器)用来作为计算节点,关于如何创建支持KVM虚拟化的虚拟机,可以参考文章:《KVM嵌套虚拟化 – 在虚拟机中创建虚拟机》。
本文使用两台虚拟机来搭建我们的环境,nfs,mysql和管理端都装在同一台虚拟机上,cloudstack-agent安装在一台开启了虚拟化支持的虚拟机上,部署架构如下:
这里写图片描述

我们甚至可以把cloudstack-agent也安装在管理端所在的虚拟机上,让这台虚拟机作为计算节点使用,这样整套环境我们只需要一台虚拟机就可以部署完成,喜欢偷懒的同学可以自己试一下,在这里我们还是使用单独的虚拟机来作为计算节点。

我们需要在这两台虚拟机上做以下配置:

配置本地域名解析

在文件/etc/hosts最后加上本机的IP及对应的主机名,如:192.168.122.10 MyHost01

关闭selinux
  1. 修改配置文件/etc/selinux/config,将SELINUX=enforcing改为SELINUX=disabled或SELINUX=permissive
  2. 执行命令:setenforce 0
安装ntp服务
yum -y install ntp
systemctl start ntpd
systemctl enable ntpd

完了以后我们就可以把CloudStack的安装下载下来准备安装,本文基于CloudStack 4.11.1.0 版本,rpm包可以在以下下载链接获取:http://download.cloudstack.org/centos/7/4.11/?C=M;O=A ,下载三个主要的包即可:

cloudstack-management-4.11.1.0-1.el7.centos.x86_64.rpm
cloudstack-common-4.11.1.0-1.el7.centos.x86_64.rpm
cloudstack-agent-4.11.1.0-1.el7.centos.x86_64.rpm

安装管理端

我们首先把管理端搭建起来,计算节点可以在管理端搭建起来后一台一台添加进去,按照管理端我们需要按照以下步骤:

安装Mysql数据库

RedHat 7.2中默认的yum源没有MySql,但有个叫mariadb的数据库,mariadb是mysql数据库的一个分支,我们直接安装默认yum源里的mariadb就好:

yum install mariadb*
systemctl start mariadb.service
systemctl enable mariadb.service

设置Mysql root密码:使用命令 mysql_secure_installation 按照提示设置root密码,第一次使用时root密码为空,直接按回车即可

安装服务端RPM:
yum localinstall cloudstack-management-4.11.1.0-1.el7.centos.x86_64.rpm cloudstack-common-4.11.1.0-1.el7.centos.x86_64.rpm
初始化CloudStack数据库:
cloudstack-setup-databases cloud:cloud@localhost --deploy-as=root:root

参数解析:

  • cloud:cloud@localhost
    • cloud:cloud是cloudstack在mysql数据库中创建的账户和密码
    • localhost是mysql数据库的地址,因为我们装在本机上,所以是localhost,如果mysql数据库在另外一台机器上,则需改为该机器的IP或域名
  • –deploy-as=root:root :这个参数的值root:root填的是数据库的root用户名和密码

执行这个命令会在MySql数据库上创建一个cloud的用户,并使用这个用户创建一个cloud数据库。出现以下信息则表明cluodstack的数据库初始化成功:
这里写图片描述

初始化cloudstack管理服务器

使用以下命令初始化并启动cloudstack的管理服务器:

cloudstack-setup-management

出现以下界面表明管理服务器启动成功:
这里写图片描述

打开浏览器,在地址栏输入[host_ipaddress]:8080/client可以看到CloudStack的UI界面:
这里写图片描述
使用默认账户admin/password登录,第一次登录时会进入引导界面:
这里写图片描述
我们可以选择跳过直接进入CloudStack的主界面,此时由于我们还未添加资源,CloudStack主界面空空如也:
这里写图片描述

安装系统虚拟机

我们还需要把系统虚拟机下载下来并安装到二级存储上去,这样当我们在启用资源域的时候系统虚拟机才能成功被创建。关于二级存储的概念还不太清楚的同学可以参考这篇文章,写得非常详细:CloudStack那些事儿2 : 主存储与二级存储
系统虚拟机的下载链接:http://cloudstack.apt-get.eu/systemvm/4.11/systemvmtemplate-4.11.1-kvm.qcow2.bz2

上文提到的NFS服务器就是作为二级存储使用的,所以我们还需要在本机上搭建一个NFS服务器后才能把系统虚拟机模板传上去。不过不用担心,NFS服务器的搭建非常简单,不会的同学可以参考这篇文章:RedHat7/Centos7 搭建NFS服务器

假设挂载到NFS的目录为/mnt/secondary,那么我们可以使用以下命令将系统虚拟机模板上传到NFS上:

bunzip2 systemvmtemplate-4.11.1-kvm.qcow2.bz2	
/usr/share/cloudstack-common/scripts/storage/secondary/cloud-install-sys-tmplt -m /mnt/secondary -f systemvmtemplate-4.11.1-kvm.qcow2 -h kvm -F

出现类似以下信息则表明系统虚拟机模板已经成功上传到NFS上:
这里写图片描述

安装Agent端

Agent端(即我们的计算节点)在安装cloudstack-agent,还需要安装libvirt和qemu,cloudstack对KVM虚拟化层的操作实际上都是libvirt和qemu来完成的,执行以下命令完成我们Agent端的安装:

yum install libvirt*  qemu*
yum localinstall cloudstack-agent-4.11.1.0-1.el7.centos.x86_64.rpm cloudstack-common-4.11.1.0-1.el7.centos.x86_64.rpm
systemctl start cloudstack-agent
systemctl enable cloudstack-agent

需要注意的是,Agent端所在的机器也需要经过一开始时配置本地域名解析,安装ntp,关闭selinux的配置哦。
完成以上步骤后稍后我们就可以把这个Agent作为计算节点加入到CloudStack的资源域中。

创建Zone(资源域)

关于Zone是什么,可以在这个链接了解一下:https://mp.csdn.net/mdeditor/76368387
在完成了以上步骤以后,我们终于可以来添加我们的第一个Zone了。点击Infrastructure -> Zones->Add Zone,弹出以下页面:
这里写图片描述

有Basic和Advanced两种Zone可以选择,我们选Advanced,然后点Next,进入以下界面:
这里写图片描述
Name随便填一个,DNS可以根据具体的情况填写,关键是下面的Hypervisior在这里我们要选KVM,最下面两个复选框也需要勾选,如下图所示:
这里写图片描述
完事以后点击Next进入下面的页面,这个是为计算节点的不同网络流量配置不同的网卡,因为我们的计算节点只有一张默认网卡,所以我们可以直接点击Next跳过,让所有网络流量都走默认网卡即可:
这里写图片描述

在下面这个页面我们需要为CloudStack配置一个可用的IP范围,用于公共流量(Public traffic),公共流量用于和外网进行通信,我们的IP范围需要至少有2个IP用于公共流量:
这里写图片描述
点击下一步,进入到Pod的配置页面,Name可以随便取一个,下面的网段信息用于配置CloudStack的管理流量(Management traffic),即用于CloudStack各个组件间进行通信,配置一个CloudStack服务端和Agent端都可以访问的可用的IP范围即可:
这里写图片描述

点击下一步,配置一个系统保留VLAN范围,随便填100到200即可:
这里写图片描述

点击下一步,给我们的第一个Cluster取个名字,随便取:
这里写图片描述

点击下一步,添加我们的第一个计算节点,这个Host Name要填我们上面那台作为计算节点的Agent的IP地址,Username和Password填Linux操作系统的用户名和密码:
这里写图片描述

点击下一步,添加一个二级存储,Provider选nfs,Name随便取,Server要填前面我们搭的那个NFS服务器,Path要填我们NFS服务器的共享目录:
这里写图片描述

点击下一步,终于完了,点Launce Zone等待一段时间,等创建完成即可:
这里写图片描述

如果中间有配置错误的地方会提示我们修改,最终出现以下页面表明Zone以及成功创建,点击Yes启用资源域:
这里写图片描述

此时的Infrastructure界面可以看到我们创建的资源都显示在这个界面上:
这里写图片描述

这篇关于CloudStack+KVM环境搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089196

相关文章

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

gradle安装和环境配置全过程

《gradle安装和环境配置全过程》本文介绍了如何安装和配置Gradle环境,包括下载Gradle、配置环境变量、测试Gradle以及在IntelliJIDEA中配置Gradle... 目录gradle安装和环境配置1 下载GRADLE2 环境变量配置3 测试gradle4 设置gradle初始化文件5 i

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推