openstack自动化搭建脚本
Openstack平台部署+节点扩容
1)搭建脚本
#!/bin/bash
#openstack私有云平台部署
#脚本使用前提:三台虚拟机openstack(ip地址:192.168.1.10,至少7G内存,50G硬盘),nova01(ip地址:192.168..11至少4G内存,100G硬盘),扩容用nova02(ip地址:192.168..12至少4G内存,100G硬盘);yum源正常;本次部署为精简版安装
source /root/moudle.sh
while :
do
echo "#############################_menu_##################################"
echo "1.openstack服务器环境部署与检查"
echo "2.nova环境部署与检查"
echo "3.openstack服务安装与登录"
echo "4.openstack节点扩容"
echo "5.exit"
echo "#####################################################################"
read -p "请输入您要部署的服务(1|2|3|4|5):" select
if [ "$select" == "" ];then
env_openstack
elif [ "$select" == "" ];then
env_nova
elif [ "$select" == "" ];then
install_openstack
elif [ "$select" == "" ];then
ext_nova
elif [ "$select" == "" ];then
exit
else
echo "I AM SORRY"
sleep
fi
done
2)脚本模块
#!/bin/bash
#函数定义
env_openstack()
{
hostnamectl set-hostname openstack
hostname openstack
sleep
echo "1.主机名已同步" echo "192.168.1.10 openstack
192.168.1.11 nova01
192.168.1.12 nova02
" >> /etc/hosts
sleep
echo "2.域名已同步" sed -i '/search/d' /etc/resolv.conf
sleep
echo "3.域名解析服务器已指定" sed -i '7 s/gateway/192.168.1.254/' /etc/chrony.conf #.254是真机ip
systemctl restart chronyd
sleep
if [ `chronyc sources -v | tail - | awk '{print $1}'` == ^* ];then
echo "4.时间同步成功"
else
echo '##########!!!时间未同步,请检查'
fi echo "[local_repo]
name=CentOS-$releasever - Base
baseurl="ftp://192.168.1.254/centos-1804"
enabled=
gpgcheck=
[extras]
name=extras
baseurl="ftp://192.168.1.254/extras/"
enabled=
gpgcheck=
[openstack1]
name=openstack1
baseurl="ftp://192.168.1.254/openstack/rhel-7-server-openstack-10-rpms"
enabled=
gpgcheck=
[openstack2]
name=openstack2
baseurl="ftp://192.168.1.254/openstack/rhel-7-server-openstack-10-devtools-rpms"
enabled=
gpgcheck=
" > /etc/yum.repos.d/local.repo
sleep
if [ `yum repolist | tail - | awk '{print $2}'` == "10,670" ];then
echo "5.yum源配置成功"
else
echo "##########!!!yum源有问题"
fi yum remove firewalld-* &>/dev/null;yum remove NetworkManager &>/dev/null
sleep
echo "6.已卸载firewalld和NetworkManager"
sleep
if [ `cat /etc/sysconfig/network-scripts/ifcfg-eth0 | awk -F'"' '/ONBOOT/{print $2}'` == "yes" ];then
echo "7.network冲突解决"
else
echo "###########!!!network冲突"
fi
sleep
ping -c 192.168.1.11 &>/dev/null && ping -c 192.168.1.12 &>/dev/null && echo "8.网络畅通" || echo "##########!!!请检查网络"
sleep
echo "环境依赖包安装,请稍等..."
sleep
yum -y install python-setuptools &> /dev/null && echo "9.依赖包安装成功,环境配置完毕,请进行下一步,安装openstack服务"
sleep 1.5
} env_nova()
{
read -p "请输入主机名尾号(01|02):" a
hostnamectl set-hostname nova$a
hostname nova$a
sleep
echo "1.主机名已同步" echo "192.168.1.10 openstack
192.168.1.11 nova01
192.168.1.12 nova02
" >> /etc/hosts
sleep
echo "2.域名已同步" sed -i '/search/d' /etc/resolv.conf
sleep
echo "3.域名解析服务器已指定" sed -i '7 s/gateway/192.168.1.254/' /etc/chrony.conf #.254是真机ip
systemctl restart chronyd
sleep
if [ `chronyc sources -v | tail - | awk '{print $1}'` == "^*" ];then
echo "4.时间同步成功"
else
echo '##########!!!时间未同步,请检查'
fi echo "[local_repo]
name=CentOS-$releasever - Base
baseurl="ftp://192.168.1.254/centos-1804"
enabled=
gpgcheck=
[extras]
name=extras
baseurl="ftp://192.168.1.254/extras/"
enabled=
gpgcheck=
[openstack1]
name=openstack1
baseurl="ftp://192.168.1.254/openstack/rhel-7-server-openstack-10-rpms"
enabled=
gpgcheck=
[openstack2]
name=openstack2
baseurl="ftp://192.168.1.254/openstack/rhel-7-server-openstack-10-devtools-rpms"
enabled=
gpgcheck=
" > /etc/yum.repos.d/local.repo
sleep
if [ `yum repolist | tail - | awk '{print $2}'` == "10,670" ];then
echo "5.yum源配置成功"
else
echo "##########!!!yum源有问题"
fi
yum remove firewalld-* &>/dev/null;yum remove NetworkManager &>/dev/null
sleep
echo "6.已卸载firewalld和NetworkManager"
sleep
if [ `cat /etc/sysconfig/network-scripts/ifcfg-eth0 | awk -F'"' '/ONBOOT/{print $2}'` == "yes" ];then
echo "7.network冲突解决"
else
echo "###########!!!network冲突"
fi
sleep
ping -c 192.168.1.10 &>/dev/null && ping -c 192.168.1.12 &>/dev/null && echo "8.网络畅通" || echo "##########!!!请检查网络" echo "环境依赖包安装,请稍等..."
yum -y install python-setuptools qemu-kvm libvirt-daemon libvirt-daemon-driver-qemu libvirt-client &> /dev/null && echo "9.依赖包安装成功,环境配置完毕,请进行下一步"
sleep 1.5
} install_openstack()
{
yum -y install openstack-packstack
cd /root/
packstack --gen-answer-file=answer.ini
sed -i '42 s/=y/=n/' answer.ini
sed -i '45 s/=y/=n/' answer.ini
sed -i '49 s/=y/=n/' answer.ini
sed -i '53 s/=y/=n/' answer.ini
sed -i '75 s/=/=192.168.1.254/' answer.ini
sed -i '98 s/1.10/1.11/' answer.ini
sed -i '102 s/1.10/1.10,192.168.1.11/' answer.ini
sed -i '333 s/=.*$/=a/' answer.ini
sed -i '840 s/=vx/=flat,vx/' answer.ini
sed -i '910 s/=/=physnet1:br-ex/' answer.ini
sed -i '921 s/=/=br-ex:eth0/' answer.ini
sed -i '1179 s/=y/=n/' answer.ini
echo "开始安装请耐心等待大约30min..."
packstack --answer-file=answer.ini
sed -i '/WSGIProcessGroup apache/a WSGIApplicationGroup %{GLOBAL}' /etc/httpd/conf.d/-horizon-vhost.conf
apachectl graceful
echo "安装成功!欢迎使用,请访问以下网址http://192.168.1.10进行访问,账户密码为您的应答文件设置"
} ext_nova()
{
cd /root/
sed -i '98 s/1.11/1.11,192.168.1.12/' answer.ini
sed -i '102 s/1.11/1.11,192.168.1.12/' answer.ini
echo "开始安装请耐心等待大约30min..."
packstack --answer-file=answer.ini
sed -i '/WSGIProcessGroup apache/a WSGIApplicationGroup %{GLOBAL}' /etc/httpd/conf.d/-horizon-vhost.conf
apachectl graceful
echo "扩容成功!欢迎使用,请访问以下网址http://192.168.1.10进行访问,账户密码>为您的应答文件设置"
}
openstack自动化搭建脚本的更多相关文章
- linux集群自动化搭建(生成密钥对+分发公钥+远程批量执行脚本)
之前介绍过ansible的使用,通过ssh授权批量控制服务器集群 但是生成密钥和分发公钥的时候都是需要确认密码的,这一步也是可以自动化的,利用ssh + expect + scp就可以实现,其实只用这 ...
- python+paramiko库+svn写的自动化部署脚本
第一篇博文 直接开门见山的说了. 这是件什么事?:每次部署都是复制本地的文件粘贴到服务器端,因为路径复杂,所以费时且手工容易出漏洞. 一直在想有什么办法可以解决这种,因为以前在微软的一个牛人同事做过一 ...
- CentOS 下运维自动化 Shell 脚本之 expect
CentOS 下运维自动化 Shell脚本之expect 一.预备知识: 1.在 Terminal 中反斜杠,即 "" 代表转义符,或称逃脱符.("echo -e与pri ...
- linux软件管理之------编译安装nginx服务器并手动编写自动化运行脚本
红帽系列的 linux软件管理分为三类:1. rpm 安装软件.2. yum 安装软件.3. 源码包编译安装.前面两种会在相关专题给出详细讲解.源码包的编译安装是非常关键的,我们知道linux的相关版 ...
- 深入理解Openstack自动化部署
前言 说实话,看到自己在博客园的排名感到惭愧,因为自己最近两年没有持续地在博客园上写技术博客了,有人私下问我是不是荒废了?翻翻15年和16年的博客,真的是少的可怜.一方面的确由于岗位的变化,导致了工作 ...
- python自动化执行脚本
---恢复内容开始--- 1 (1)首先在你的.py文件上加上一行代码注释: #!/usr/local/bin/python2.7 (2)终端下执行: crontab -e 进入后,输入i 进入可编辑 ...
- 设置ssh免密码登录脚本(hadoop自动化部署脚本一)
设置ssh免密码登录脚本(hadoop自动化部署脚本一) 设置ssh免密码登录脚本(飞谷云大数据自动化部署脚本一) 1.#!/bin/sh2.#important note:this script i ...
- openstack一键安装脚本(转载)
#!/bin/sh # openstack pike 单机 一键安装 # 环境 centos 7.4.1708 x86_64 # 更多内容 http://dwz.cn/openstack # Myde ...
- Jenkins持续集成-自动化部署脚本的实现
要实现Jenkins端的持续集成,其实在CI服务配置端很容易,难点呢?就是如何实现自动化的部署.我的脚本设计就是为了解决以下难题: 难点一.如何使得自动化部署脚本更通用 我用的脚本,依赖依赖一个配置文 ...
随机推荐
- os.getcwd()和os.path.realpath(__file__)的区别
https://blog.csdn.net/xiaminli/article/details/74944580 python中split().os.path.split()函数用法
- 其他 - YAML 入门
概述 简单介绍 YAML 语言 背景 很多地方, 都在使用 YAML k8s spring 其他 准备 验证工具 YAML.YML在线格式化校验工具 一个 YAML 转换 JSON 的工具 通常来说, ...
- [HNOI2014] 道路堵塞 - 最短路,线段树
对不起对不起,辣鸡蒟蒻又来用核弹打蚊子了 完全ignore了题目给出的最短路,手工搞出一个最短路,发现对答案没什么影响 所以干脆转化为经典问题:每次询问删掉一条边后的最短路 如果删掉的是非最短路边,那 ...
- echart--自己写的例子
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- spring boot使用freemarker模版整合spring Data JPA
目录结构 第一步:在pom.xml文件中添加依赖 <!--模板依赖--> <dependency> <groupId>org.springframework.boo ...
- OERR: ORA-32004 "obsolete or deprecated parameter(s) specified for %s instance"
Oracle 11gR2通过Memory创建动态参数文件后,通过SPFILE启动,提示 ORA-32004: obsolete or deprecated parameter(s) specified ...
- SSL扫描工具
工具: sslciphercheck sslscan sslciphercheck.exe -h ip -p 443 有些IP会报错:
- vue实现隔行换色,下拉菜单控制隔行换色的颜色
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- SQLServer2008不允许保存更改错误解决办法
SQLServer2008不允许保存更改错误解决办法 今天在运行sql server 2008时候提示不允许保存更改,您所做的更改要求删除并重新创建以下表 的解决办法. 一.启动SQL Server ...
- HTML备忘
a标签事件 a:link {color: #000000} /* 未访问的链接 */ a:visited {color: #d90a81} /* 已访问的链接 */ a:hover {color: # ...