草庐IT

云计算HCIP实验-OpenStack搭建

浇、水 2023-08-23 原文

文章目录

前期准备

rhel-server-7.1-x86_64-dvd.iso(必须是7.1)
RHEL7OSP-6.0-2015-02-23.2-x86_64.iso
WinSCP
VMware

1. 环境规划


虚拟机要求(按照物理机16G物理内存标准)
控制节点:内存8G,勾选CPU虚拟化,虚拟网卡(仅主机)
计算节点:内存4G,勾选CPU虚拟化,虚拟网卡(仅主机)
NTP节点:内存1G

controller:

compute:

ntp:

架构:

16G内存建议最小化安装操作系统

2. 绑定静态IP

安装过程中注意网络配置

获取到ip地址后





按照如上条件安装完三台虚拟机

3. IP及主机名规划

修改controller主机的/etc/hosts 文件

[root@controller ~]# vi /etc/hosts 


将/etc/hosts 文件拷贝到另外两台主机上

[root@controller ~]# scp /etc/hosts root@compute:/etc/
[root@controller ~]# scp /etc/hosts root@ntp:/etc/


4. 配置OS YUM源

切换到ntp节点
将光盘在虚拟机上进行挂载
将光盘在操作系统中挂载到临时挂载点 /mnt (目的是为了安装httpd服务)

[root@ntp ~]# mount /dev/cdrom /mnt

[root@ntp ~]# cd /etc/yum.repos.d/
[root@ntp yum.repos.d]# vi dvd.repo

[dvd]
name=dvd
baseurl=file:///mnt/
gpgcheck=0
enabled=1

安装并启动http服务

[root@ntp yum.repos.d]# yum install -y httpd
[root@ntp yum.repos.d]# systemctl start httpd
[root@ntp yum.repos.d]# systemctl enable httpd.service


在http服务路径下创建一个文件夹dvd

[root@ntp html]# mkdir  /var/www/html/dvd
[root@ntp html]# umount  /mnt/
[root@ntp html]# ls  /mnt/
[root@ntp html]# mount /dev/cdrom  /var/www/html/dvd/
[root@ntp html]# ls  /var/www/html/dvd/


但是这时候一旦重启,光盘挂载就会失效,所以我们要将这个光盘路径进行永久挂载,写入开机自启文件 /etc/fstab

[root@ntp html]# vi /etc/fstab

最下面添加这行

/dev/cdrom /var/www/html/dvd iso9660 defaults  0 0

[root@ntp html]# mount -a

尝试其他两个节点进行远程安装,比如在controller节点上进行yum源配置,地址指向ntp
切换到controller节点

[root@controller ~]# vi /etc/yum.repos.d/dvd.repo 
[dvd]
name=dvd
baseurl=http://192.168.52.138/dvd/
gpgcheck=0
enabled=1

5. 关闭防火墙SELinux NetworkManager

[root@controller ~]# systemctl stop firewalld
[root@controller ~]# systemctl disable firewalld
[root@controller ~]# systemctl stop NetworkManager.service 
[root@controller ~]# systemctl disable NetworkManager
[root@controller ~]# setenforce 0
[root@controller ~]# vi /etc/selinux/config 



关闭其它两个虚拟机的防火墙和NetworkManager


测试一下yum是否可以正常使用(开启防火墙的情况下controller访问不了ntp的repo文件)

这是未关闭防火墙的结果

6. 配置OpenStack YUM源

切换到ntp节点
通过WinSCP软件把iso镜像上传到NTP服务器里面
创建临时目录存放iso文件

[root@ntp ~]# mkdir  /isoso

上传iso到临时目录里面


[root@ntp ~]# ls /isoso


把光盘内容进行永久挂载

[root@ntp ~]# cd  /var/www/html/
[root@ntp html]# ls
[root@ntp html]# pwd
[root@ntp html]# mkdir  openstack
[root@ntp html]# ls
[root@ntp html]# vi  /etc/fstab 

在/etc/fstab 中加入这行

/isoso/RHEL7OSP-6.0-2015-02-23.2-x86_64.iso /var/www/html/openstack iso9660 defaults    0 0


全部挂载

[root@ntp html]# mount  -a
[root@ntp html]# df  -Th
[root@ntp html]# ls dvd/
[root@ntp html]# ls openstack/


openstack里面有4个目录,意味着要配置4个路径,加上我们之前配置的os路径,一共配置5个。
切换到controller节点
在controller节点上配置好repo文件

[root@controller ~]# cd /etc/yum.repos.d/
[root@controller yum.repos.d]# vi dvd.repo 
[dvd]
name=dvd
baseurl=http://192.168.52.138/dvd/
gpgcheck=0
enabled=1

[RH7-RHOS-6.0]
name=RH7-RHOS-6.0
baseurl=http://192.168.52.138/openstack/RH7-RHOS-6.0
gpgcheck=0
enabled=1

[RH7-RHOS-6.0-Installer]
name=RH7-RHOS-6.0-Installer
baseurl=http://192.168.52.138/openstack/RH7-RHOS-6.0-Installer
gpgcheck=0
enabled=1

[RHEL7-Errata]
name=RHEL7-Errata
baseurl=http://192.168.52.138/openstack/RHEL7-Errata
gpgcheck=0
enabled=1

[RHEL-7-RHSCL-1.2]
name=RHEL-7-RHSCL-1.2
baseurl=http://192.168.52.138/openstack/RHEL-7-RHSCL-1.2
gpgcheck=0
enabled=1

测试yum是否正常工作

yum repolist all
yum install -y readline*



readline包也正常安装成功
验证,在任意节点上打开一个网页,远程访问,如果可以放到到镜像文件,说明没问题。

[root@controller ~]# firefox http://192.168.171.154/openstack
[root@controller ~]# firefox http://192.168.171.154/dvd


把repo文件复制到compute和ntp节点上

[root@controller ~]# scp /etc/yum.repos.d/dvd.repo root@compute:/etc/yum.repos.d/  
[root@controller ~]# scp /etc/yum.repos.d/dvd.repo root@ntp:/etc/yum.repos.d/

7. 配置NTP服务(服务器端配置)

切换到ntp服务器
确认是否安装chrony包,如果没有/etc/chrony.conf就用yum安装chrony包,其他服务器同理

[root@ntp ~]# yum list all |grep chron
[root@ntp ~]# vi /etc/chrony.conf

安装:

[root@ntp ~]# yum install -y chron*


编辑的内容

#server 0.rhel.pool.ntp.org iburst
#server 1.rhel.pool.ntp.org iburst
#server 2.rhel.pool.ntp.org iburst
#server 3.rhel.pool.ntp.org iburst

allow 192.168.52/24

local stratum 10

改前:

改后:

保存并退出
启动服务

[root@ntp ~]# systemctl restart chronyd.service
[root@ntp ~]# systemctl enable chronyd

查看监听的端口号 :123

[root@ntp ~]# netstat -tulnp |grep :123


8. 配置NTP服务(客户器端配置)

切换至controller和compute
手工随便修改一个时间
然后进行手工同步
同步完成后,检查时间

[root@compute ~]# date -s "2010-01-01 11:00:00"
[root@compute ~]# ntpdate ntp
[root@compute ~]# date



但是每次手工同步都非常的麻烦,所以可以进行配置让它自动同步

[root@compute ~]# vi /etc/chrony.conf 

编辑内容

#server 0.rhel.pool.ntp.org iburst
#server 1.rhel.pool.ntp.org iburst
#server 2.rhel.pool.ntp.org iburst
server ntp iburst

默认是每隔5分钟同步一次。

controller 和 compute 都要做时钟同步

9. 在控制节点上部署PackStack

分别在三个节点上执行更新

[root@controller ~]# yum update -y

安装openstack-packstack

[root@controller ~]# yum install -y openstack-packstack


当安装好之后,就会有packstack这个工具,但是执行packstack --help的时候会报错:

这个错误是因为网卡信息里面没有配置DNS,即使我们用不到,但程序要检查。
我们配置DNS

[root@controller ~]# cd /etc/sysconfig/network-scripts/
[root@controller network-scripts]# vim ifcfg-eno16777736 

–增加一行DNS–

DNS1=192.168.52.1
#重启网卡
[root@controller network-scripts]# service network restart

之后执行 packstack --help

10. 通过PackStack安装OpenStack

[root@controller ~]# packstack --help |grep ans


–gen-answer-file= 一个绝对路径
可以根据模板来生成一个应答文件,文件里面有安装所需要的所有参数,我们直接去更改文件里面的参数,然后执行这个文件就可以进行安装。

[root@controller ~]# packstack --gen-answer-file=/root/answers.txt
#执行上面命令就可以生成一个应答文件,然后修改这个文件:
[root@controller ~]# vim answers.txt
#修改的内容:(插入模式按/查找)
CONFIG_NTP_SERVERS=192.168.52.138
CONFIG_COMPUTE_HOSTS=192.168.52.136,192.168.52.137
CONFIG_KEYSTONE_REGION=WuHan
CONFIG_KEYSTONE_ADMIN_PW=redhat
CONFIG_HORIZON_SSL=y
CONFIG_PROVISION_DEMO=n

参数配置好之后,就可以直接运行(这时候运行可能会报错mariadb)

[root@controller ~]# packstack --answer-file=/root/answers.txt

会报错:依赖关系包的问题

解决方案:删除,重新安装,然后再次执行

[root@controller ~]# yum remove mariadb
[root@controller ~]# yum install -y mariadb mariadb-server
[root@controller ~]# packstack --answer-file=/root/answers.txt

安装成功

访问192.168.52.136/dashboard/出现如下界面

账号:admin
密码:redhat

11. 配置网卡信息OVS

[root@controller ~]# cd /etc/sysconfig/network-scripts/
[root@controller network-scripts]# cp ifcfg-eno16777736 ifcfg-br-ex

首先改br-ex
原始网络配置信息

YPE=Ethernet
BOOTPROTO=none
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
NAME=eno16777736
UUID=172575e6-5ce9-4996-ad28-0cb6bd81fc22
DEVICE=eno16777736
ONBOOT=yes
IPADDR=192.168.52.136
PREFIX=24
GATEWAY=192.168.52.254
DNS1=192.168.52.1
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_PRIVACY=no

把所有IPV4和IPV6开头的都删除掉
开始更改:

TYPE=OVSBridge
BOOTPROTO=none
DEFROUTE=yes
#IPV4_FAILURE_FATAL=no
#IPV6INIT=yes
#IPV6_AUTOCONF=yes
#IPV6_DEFROUTE=yes
#IPV6_FAILURE_FATAL=no
NAME=br-ex
UUID=172575e6-5ce9-4996-ad28-0cb6bd81fc22
DEVICE=br-ex
DEVICETYPE=ovs
ONBOOT=yes
IPADDR=192.168.52.136
PREFIX=24
GATEWAY=192.168.52.254
DNS1=192.168.52.1
#IPV6_PEERDNS=yes
#IPV6_PEERROUTES=yes
#IPV6_PRIVACY=no

然后修改物理网卡信息:

[root@controller network-scripts]# vi ifcfg-eno16777736

原始信息

TYPE=Ethernet
BOOTPROTO=none
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
NAME=eno16777736
UUID=172575e6-5ce9-4996-ad28-0cb6bd81fc22
DEVICE=eno16777736
ONBOOT=yes
IPADDR=192.168.52.136
PREFIX=24
GATEWAY=192.168.52.254
DNS1=192.168.52.1
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_PRIVACY=no
~                 

删除所有IPV4和IPV6,以及IP地址、子网掩码、DNS
之后修改:注意,DEVICETYPE,OVS_BRIDGE需要手工添加

TYPE=OVSPort
BOOTPROTO=none
DEFROUTE=yes
#IPV4_FAILURE_FATAL=no
#IPV6INIT=yes
#IPV6_AUTOCONF=yes
#IPV6_DEFROUTE=yes
#IPV6_FAILURE_FATAL=no
NAME=eno16777736
UUID=172575e6-5ce9-4996-ad28-0cb6bd81fc22
DEVICE=eno16777736
DEVICETYPE=ovs
DEVICEBRIDGE=br-ex
ONBOOT=yes
#IPADDR=192.168.52.136
#PREFIX=24
#GATEWAY=192.168.52.254
#DNS1=192.168.52.1
#IPV6_PEERDNS=yes
#IPV6_PEERROUTES=yes
#IPV6_PRIVACY=no
~                                                                             
~                    

配置好之后,使用命令查看

[root@controller ~]# ovs-vsctl show


重启网卡:

service network restart

有关云计算HCIP实验-OpenStack搭建的更多相关文章

  1. ruby-on-rails - 使用一系列等级计算字母等级 - 2

    这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,

  2. 计算机毕业设计ssm+vue基本微信小程序的小学生兴趣延时班预约小程序 - 2

    项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU

  3. ruby - 如何计算 Liquid 中的变量 +1 - 2

    我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我

  4. ruby - 使用 Ruby,计算 n x m 数组的每一列中有多少个 true 的简单方法是什么? - 2

    给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in

  5. arrays - 计算数组中的匹配元素 - 2

    给定两个大小相等的数组,如何找到不考虑位置的匹配元素的数量?例如:[0,0,5]和[0,5,5]将返回2的匹配项,因为有一个0和一个5共同;[1,0,0,3]和[0,0,1,4]将返回3的匹配项,因为0有两场,1有一场;[1,2,2,3]和[1,2,3,4]将返回3的匹配项。我尝试了很多想法,但它们都变得相当粗糙和令人费解。我猜想有一些不错的Ruby习惯用法,或者可能是一个正则表达式,可以很好地回答这个解决方案。 最佳答案 您可以使用count完成它:a.count{|e|index=b.index(e)andb.delete_at

  6. ruby-on-rails - 如何计算 Ruby/Rails 中 JSON 对象的数量 - 2

    Ruby中如何“一般地”计算以下格式(有根、无根)的JSON对象的数量?一般来说,我的意思是元素可能不同(例如“标题”被称为其他东西)。没有根:{[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]}根包裹:{"posts":[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]} 最佳答案 首先,withoutroot代码不是有效的json格式。它将没有包

  7. ruby - 如何计算自 Ruby 中给定日期以来的周数? - 2

    目标我正在尝试计算自给定日期以来周的距离,而无需跳过任何步骤。我更喜欢用普通的Ruby来做,但ActiveSupport无疑是一个可以接受的选择。我的代码我写了以下内容,这似乎可行,但对我来说似乎还有很长的路要走。require'date'DAYS_IN_WEEK=7.0defweeks_sincedate_stringdate=Date.parsedate_stringdays=Date.today-dateweeks=days/DAYS_IN_WEEKweeks.round2endweeks_since'2015-06-15'#=>32.57ActiveSupport的#weeks

  8. 最新版人脸识别小程序 图片识别 生成二维码签到 地图上选点进行位置签到 计算签到距离 课程会议活动打卡日常考勤 上课签到打卡考勤口令签到 - 2

    技术选型1,前端小程序原生MINA框架cssJavaScriptWxml2,管理后台云开发Cms内容管理系统web网页3,数据后台小程序云开发云函数云开发数据库(基于MongoDB)云存储4,人脸识别算法基于百度智能云实现人脸识别一,用户端效果图预览老规矩我们先来看效果图,如果效果图符合你的需求,就继续往下看,如果不符合你的需求,可以跳过。1-1,登录注册页可以看到登录页有注册入口,注册页如下我们的注册,需要管理员审核,审核通过后才可以正常登录使用小程序1-2,个人中心页登录成功以后,我们会进入个人中心页我们在个人中心页可以注册人脸,因为我们做人脸识别签到,需要先注册人脸才可以进行人脸比对,进

  9. ruby - 如何计算两个字符串共有的字符数? - 2

    如何计算两个字符串之间的字符交集?例如(假设我们有一个名为String.intersection的方法):"abc".intersection("ab")=2"hello".intersection("hallo")=4好的,男孩女孩们,感谢你们的大量反馈。更多示例:"aaa".intersection("a")=1"foo".intersection("bar")=0"abc".intersection("bc")=2"abc".intersection("ac")=2"abba".intersection("aa")=2一些补充说明:维基百科定义intersection如下:Int

  10. python - 如何计算文件中唯一字符的数量? - 2

    给定一个包含各种语言字符的UTF-8文件,我如何计算它包含的唯一字符的数量,同时排除选定数量的符号(例如:“!”、“@”、"#",".")从这个算起? 最佳答案 这是一个bash解决方案。:)bash$perl-CSD-ne'BEGIN{$s{$_}++forsplit//,q(!@#.)}$s{$_}++||$c++forsplit//;END{print"$c\n"}'*.utf8 关于python-如何计算文件中唯一字符的数量?,我们在StackOverflow上找到一个类似的问题

随机推荐