openstack
环境:
manager: 192.168.122.10 4核8G LVM100G硬盘
nova1: 192.168.122.20 4核4G LVM100G硬盘
nova2: 192.168.122.21 4核4G LVM100G硬盘
虚拟公有IP池范围:192.168.122.50-192.168.122.150
本次采用kvm虚拟机部署,网络使用virio,这样网络效率会快很多。本博yum仓库是自己搭建在本地的ftp上的,时间服务器也是同步本机,本机同步阿里云服务器的,后端镜像也是自己做的对内核部分和软件部分进行了优化,制作后端盘重点XML文件中网卡一栏中Interface中千万不要保留mac address,常识问题我居然还是踩坑了。
首先我使用的我的后端盘进行复用做的这几个系统,之前系统盘是20G,所以首先是对我的磁盘进行扩容。
扩容思路:
热扩容镜像大小限制(虚拟实例正在运行,为了不关机选择热扩容)。
刷新分区大小。
扩容lvm 卷组大小。
扩容lv 逻辑卷大小。
刷新文件系统大小。
开始热扩容镜像大小。
:~$ virsh blockresize --path /var/lib/libvirt/images/os-manager.qcow2 --size 100G os-manager Block device '/var/lib/libvirt/images/os-nova1.qcow2' is resized
- 进入虚拟机刷新分区大小。
:/$ virsh list --all Id Name State ---------------------------------------------------- 4 os-manager running 5 os-nova1 running 6 os-nova2 running :/$ virsh console 5 Connected to domain os-nova1 Escape character is ^] Welcome to vitualhost centos7 centos7 login: root Password: Last login: Sat Nov 9 21:32:14 on ttyS0 [ ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT sr0 11:0 1 1024M 0 rom vda 252:0 0 100G 0 disk ├─vda1 252:1 0 1G 0 part /boot └─vda2 252:2 0 19G 0 part └─centos_centos7-root 253:0 0 19G 0 lvm / [ ~]# growpart /dev/vda 2 CHANGED: partition=2 start=2099200 old: size=39843840 end=41943040 new: size=207615967 end=209715167 [ ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT sr0 11:0 1 1024M 0 rom vda 252:0 0 100G 0 disk ├─vda1 252:1 0 1G 0 part /boot └─vda2 252:2 0 99G 0 part └─centos_centos7-root 253:0 0 19G 0 lvm /
- 扩容lvm卷组大小。
[ ~]# vgs VG #PV #LV #SN Attr VSize VFree centos_centos7 1 1 0 wz--n- <19.00g 0 [ ~]# pvresize /dev/vda2 Physical volume "/dev/vda2" changed 1 physical volume(s) resized / 0 physical volume(s) not resized [ ~]# vgs VG #PV #LV #SN Attr VSize VFree centos_centos7 1 1 0 wz--n- <99.00g 80.00g
- 扩容逻辑卷大小。
[ ~]# lvextend -L +79.9G /dev/centos_centos7/root Rounding size to boundary between physical extents: 79.90 GiB. Size of logical volume centos_centos7/root changed from <19.00 GiB (4863 extents) to <98.90 GiB (25318 extents). Logical volume centos_centos7/root successfully resized. [ ~]# lvs LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert root centos_centos7 -wi-ao---- <98.90g
- 刷新挂载点大小。
[ ~]# xfs_growfs / meta-data=/dev/mapper/centos_centos7-root isize=512 agcount=4, agsize=1244928 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=0 spinodes=0 data = bsize=4096 blocks=4979712, imaxpct=25 = sunit=0 swidth=0 blks naming =version 2 bsize=4096 ascii-ci=0 ftype=1 log =internal bsize=4096 blocks=2560, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0 data blocks changed from 4979712 to 25925632 [ ~]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/centos_centos7-root 99G 1.1G 98G 2% / devtmpfs 2.1G 0 2.1G 0% /dev tmpfs 2.2G 0 2.2G 0% /dev/shm tmpfs 2.2G 8.5M 2.1G 1% /run tmpfs 2.2G 0 2.2G 0% /sys/fs/cgroup /dev/vda1 1014M 130M 885M 13% /boot tmpfs 278M 0 278M 0% /run/user/0
- 设置对应的主机名。
[ ~]# hostnamectl set-hostname os-manager [ ~]# hostnamectl set-hostname os-nova1 [ ~]# hostnamectl set-hostname os-nova2
- 并设置hosts本地解析传到每个主机,保证每个主机都要通过主机名ping通。
[ ~]# vim /etc/hosts 192.168.122.10 os-manager 192.168.122.20 os-nova1 192.168.122.21 os-nova2 [ ~]# scp /etc/hosts :/etc/ [ ~]# scp /etc/hosts :/etc/
- 删掉每台中/etc/resolve DNS域名解析服务中的搜索域。
[ ~]# sed -i '/^search*/ d' /etc/resolv.conf
- 依次检查每台服务的时间同步是否正常。
[ ~]# chronyc sources -v 210 Number of sources = 1 .-- Source mode '^' = server, '=' = peer, '#' = local clock. / .- Source state '*' = current synced, '+' = combined , '-' = not combined, | / '?' = unreachable, 'x' = time may be in error, '~' = time too variable. || .- xxxx [ yyyy ] +/- zzzz || Reachability register (octal) -. | xxxx = adjusted offset, || Log2(Polling interval) --. | | yyyy = measured offset, || \ | | zzzz = estimated error. || | | MS Name/IP address Stratum Poll Reach LastRx Last sample =============================================================================== ^* gateway 3 6 377 6 -568us[ -819us] +/- 2943us
- 配置yum仓库,这里我是挂载到自己的ubuntu上的ftp上的。
:~$ df -h 文件系统 容量 已用 可用 已用% 挂载点 udev 7.8G 0 7.8G 0% /dev tmpfs 1.6G 5.8M 1.6G 1% /run /dev/sda5 492G 29G 438G 7% / tmpfs 7.8G 285M 7.6G 4% /dev/shm tmpfs 5.0M 4.0K 5.0M 1% /run/lock tmpfs 7.8G 0 7.8G 0% /sys/fs/cgroup /dev/sdb1 98M 33M 66M 33% /boot/efi tmpfs 1.6G 60K 1.6G 1% /run/user/1000 tmpfs 1.6G 0 1.6G 0% /run/user/0 /dev/loop0 8.8G 8.8G 0 100% /srv/ftp/CentOS7-1804 /dev/loop1 169M 169M 0 100% /srv/ftp/extras /dev/loop2 3.0G 3.0G 0 100% /srv/ftp/openstack [ ~]# vim /etc/yum.repos.d/local.repo [local] name=local baseurl=ftp://192.168.122.1/CentOS7-1804/ enable=1 gpgcheck=0 [local_extras] name=local_extras baseurl=ftp://192.168.122.1/extras/ enable=1 gpgcheck=0 [local_openstatck_rpms] name=local_ops_rpms baseurl=ftp://192.168.122.1/openstack/rhel-7-server-openstack-10-rpms/ enable=1 gpgcheck=0 [local_openstack_dev] name=local_ops_dev baseurl=ftp://192.168.122.1/openstack/rhel-7-server-openstack-10-devtools-rpms/ enable=1 gpgcheck=0 [ ~]# yum repolist 已加载插件:fastestmirror Loading mirror speeds from cached hostfile local | 3.6 kB 00:00 local_extras | 2.9 kB 00:00 local_openstack_dev | 2.9 kB 00:00 local_openstatck_rpms | 2.9 kB 00:00 (1/2): local_openstack_dev/primary_db | 3.7 kB 00:00 (2/2): local_openstatck_rpms/primary_db | 318 kB 00:00 源标识 源名称 状态 local local 9,911 local_extras local_extras 76 local_openstack_dev local_ops_dev 3 local_openstatck_rpms local_ops_rpms 680 repolist: 10,670 [ ~]# scp /etc/yum.repos.d/local.repo :/etc/yum.repos.d/ [ ~]# scp /etc/yum.repos.d/local.repo :/etc/yum.repos.d/
- 检查firewalld 和 networkmanger 是否被卸载,因为我做后端盘的时候就已经卸载干净包括selinux也都禁用了,所以这里不再检查。一切准备就绪后准备开始安装基础环境,计算节点要装libvirt和python安装工具,管理节点只需要安装python安装工具即可。
[ ~]# yum install -y python-setuptools [ ~]# yum install -y qemu-kvm libvirt-client libvirt-daemon libvirt-daemon-driver-qemu python-setuptools [ ~]# yum install -y qemu-kvm libvirt-client libvirt-daemon libvirt-daemon-driver-qemu python-setuptools
- 在管理主机上安装openstack-packstack生成应答文件进行快速安装。
[ ~]# yum install -y openstack-packstack Error: Package: libselinux-ruby-2.5-12.el7.x86_64 (local) Requires: libselinux(x86-64) = 2.5-12.el7 Installed: libselinux-2.5-14.1.el7.x86_64 (@base) libselinux(x86-64) = 2.5-14.1.el7 Available: libselinux-2.5-12.el7.x86_64 (local) libselinux(x86-64) = 2.5-12.el7 You could try using --skip-broken to work around the problem You could try running: rpm -Va --nofiles --nodigest #因为我这边包被安装了版本较高的libselinux-2.5-14.1.el7.x86_64但是依赖包必须要是 libselinux(x86-64) = 2.5-12.el7,所以需要对安装包进行降级处理,我在ftp上找到需要的包,然后scp到/tmp目录下,对其进行降级安装操作。 :/srv/ftp# scp CentOS7-1804/Packages/libselinux-2.5-12.el7.x86_64.rpm :/tmp [ tmp]# yum downgrade libselinux-2.5-12.el7.x86_64.rpm setools-libs libselinux-python libselinux-utils libsemanage policycoreutils ........................................... #这里看你自己有多少依赖存在问题,你就需要自己看着办我处理依赖问题是花了几分钟的。
- 生成应答文件。
[ ~]# packstack --gen-answer-file=answer.ini Packstack changed given value to required value /root/.ssh/id_rsa.pub
- 修改应答文件。
[ ~]# vim answer.ini CONFIG_SWIFT_INSTALL=n #关闭计费相关模块 CONFIG_CEILOMETER_INSTALL=n #关闭计费相关模块 CONFIG_AODH_INSTALL=n #关闭计费相关模块 CONFIG_GNOCCHI_INSTALL=n #关闭计费相关模块 CONFIG_NTP_SERVERS=192.168.122.1 #时间服务器地址 CONFIG_COMPUTE_HOSTS=192.168.122.20,192.168.122.21 #计算节点地址 CONFIG_NETWORK_HOSTS=192.168.122.10192.168.122.20,192.168.122.21 #加入网络管理地址 CONFIG_KEYSTONE_ADMIN_PW=lqh #管理员密码 CONFIG_NEUTRON_ML2_TYPE_DRIVERS=flat,vxlan #驱动类型 CONFIG_NEUTRON_OVS_BRIDGE_MAPPINGS=physnet1:br-ex #物理网桥的名称 CONFIG_NEUTRON_OVS_BRIDGE_IFACES=br-ex:eth0 #br-ex桥的名称与eth0连接,管理eth0,网桥与哪个物理网卡连接 CONFIG_PROVISION_DEMO=n #是否安装DEMO测试
- 配置完成后现在开始使用应答文件进行安装(过程较长)
[ ~]# packstack --answer-file=answer.ini #输入每台服务器的root密码,如果报错请根据提示进行拍错。 --> Finished Dependency Resolution You could try using --skip-broken to work around the problem You could try running: rpm -Va --nofiles --nodigest stderr: Warning: Permanently added '192.168.122.20' (ECDSA) to the list of known hosts. + trap t ERR + yum install -y puppet hiera openssh-clients tar nc rubygem-json Error: Package: libselinux-ruby-2.5-12.el7.x86_64 (local) Requires: libselinux(x86-64) = 2.5-12.el7 Installed: libselinux-2.5-14.1.el7.x86_64 (@base) libselinux(x86-64) = 2.5-14.1.el7 Available: libselinux-2.5-12.el7.x86_64 (local) libselinux(x86-64) = 2.5-12.el7 ++ t ++ exit 1 Please check log file /var/tmp/packstack/20191110-144950-Wacbht/openstack-setup.log for more information #报错了现在进行解决,上面错的描述的是20服务器在安装libselinux-ruby-2.5-12.el7.x86_64的时候,因为安装了过高的libselinux导致了无法进行安装,现在先将libselinux-2.5-12.el7.x86_64.rpm scp到每台计算节点的tmp目录下去,然后对每一台计算节点其进行降级处理。 [ tmp]# yum downgrade libselinux-2.5-12.el7.x86_64.rpm libselinux-utils libselinux-python libsemanage setools-libs policycoreutils policycoreutils-python libsemanage-python policycoreutils-python [ tmp]# yum downgrade libselinux-2.5-12.el7.x86_64.rpm libselinux-utils libselinux-python libsemanage setools-libs policycoreutils policycoreutils-python libsemanage-python policycoreutils-python #接下来回到管理节点上去使用应答文件对其进行安装,接下来就是漫长的等待时间。 [ ~]# packstack --answer-file=answer.ini ERROR : Error appeared during Puppet run: 192.168.122.10_controller.pp Error: Could not set 'present' on ensure: Cannot allocate memory - fork(2) #我的主节点报错了,看看什么原因,原来是内存不足看看我的配置文件。 :~$ virsh edit os-manager <domain type='kvm'> <name>os-manager</name> <uuid>ac382c26-5c1c-4f4f-a401-24998a8f177a</uuid> <memory unit='KiB'>1572864</memory> <currentMemory unit='KiB'>1572864</currentMemory> <vcpu placement='static'>4</vcpu> <os> #原来是内存只分配了1.5G给它,现在修改配置将其设置为8G。 <domain type='kvm'> <name>os-manager</name> <uuid>ac382c26-5c1c-4f4f-a401-24998a8f177a</uuid> <memory unit='KiB'>8388608</memory> <currentMemory unit='KiB'>8388608</currentMemory> <vcpu placement='static'>4</vcpu> <os> #修改内存后需要重启才能够生效现在对其重启 [ ~]# free -m total used free shared buff/cache available Mem: 7982 372 7345 8 265 7345 Swap: 0 0 0 #继续 [ ~]# packstack --answer-file=answer.ini **** Installation completed successfully ****** Additional information: * File /root/keystonerc_admin has been created on OpenStack client host 192.168.122.10. To use the command line tools you need to source the file. * To access the OpenStack Dashboard browse to http://192.168.122.10/dashboard . Please, find your login credentials stored in the keystonerc_admin in your home directory. * The installation log file is available at: /var/tmp/packstack/20191110-154532-HEiZGv/openstack-setup.log * The generated manifests are available at: /var/tmp/packstack/20191110-154532-HEiZGv/manifests
- 安装部署成功了,但是还需要改一下apache的配置文件才能访问。
[ ~]# sed -i '35a WSGIApplicationGroup %{GLOBAL}' /etc/httpd/conf.d/15-horizon_vhost.conf
- 重新载入配置文件。
[ ~]# apachectl graceful
- 使用浏览登录到openstack的登录页面。默认账号admin,密码在安装应答文件中设置的lqh。
- 登录到主页面可以到相关的项目中,admin项目主要是admin账户创建的项目,services项目主要与安装的各个服务相关联。
- 首先创建一个项目名叫:QIssa
- 可以在配额中设置其最大占用资源大小。
- 创建用户,用户的有两个身份特性,一个是admin作为openstack的管理用户管理项目配额和系统信息等,一个是_member_,menmber用户拥有实例操作、卷快照操作、创建镜像、分配浮动ip、创建网络和路由、管理防火墙设置、查看网络拓扑和项目使用情况等权限。所以我们在创建用户时,设置其管理主项目和角色为menber。
- 创建外部网络。
- 使用QIssa管理员lqh对外部网络进行管理设置子网,和IP地址池。
- 创建内部网络。
- 创建子网,由于暂时未添加路由器先预留网关IP 172.10.0.254 作为路由的IP。
- 内网DHCP池。
- 创建路由连接LAN和WAN网络。
- 创建路由完成后只有WAN接口需要添加内网的LAN接口。
- 查看网络拓扑。
相关推荐
Moolightshadow 2020-07-16
fyggzb 2020-07-05
gokeibi 2020-06-12
zziyuann 2020-06-12
fyggzb 2020-06-12
hhphhp 2020-06-12
fyggzb 2020-06-10
JeremyLiu 2020-06-10
JeremyLiu 2020-06-10
jmppok 2020-06-07
jmppok 2020-06-05
hhphhp 2020-06-01
zziyuann 2020-05-17
gokeibi 2020-05-07
gokeibi 2020-04-26
gokeibi 2020-04-19
gokeibi 2020-04-19