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服务配置端很容易,难点呢?就是如何实现自动化的部署.我的脚本设计就是为了解决以下难题: 难点一.如何使得自动化部署脚本更通用 我用的脚本,依赖依赖一个配置文 ...
随机推荐
- zabbix4.2配置监控nginx服务
1.监控原理 通过status模块监控(--with-http_stub_status_module) 2.修改nginx配置(/etc/nginx/conf.d/default.conf) 在被监 ...
- war文件—Web项目部署
war文件是什么? Web存档(war)文件包含Web应用程序的所有内容.它减少了传输文件所需要的时间. war文件的优点 节省时间:war文件将所有文件合并为一个单位. 所以在将文件从客户端传输到 ...
- adb 连接手机
adb kill-server adb start-server 可能会遇到问题华为手机: 有应用遮挡了权限请求界面,设置应用无法验证你的回应 系统导航关闭悬浮球 然后重启adb server ad ...
- adb shell 杀进程以及端口占用,adbserver服务重启失败
linux: adb shell ps |grep netease 杀进程: adb shell kill [PID] //杀死进程 C:\Users\chenquan>adb shell ...
- codeforces 1288C. Two Arrays(dp)
链接:https://codeforces.com/contest/1288/problem/C C. Two Arrays 题意:给定一个数n和一个数m,让构建两个数组a和b满足条件,1.数组中所有 ...
- POJ 1330(LCA/倍增法模板)
链接:http://poj.org/problem?id=1330 题意:q次询问求两个点u,v的LCA 思路:LCA模板题,首先找一下树的根,然后dfs预处理求LCA(u,v) AC代码: #inc ...
- Mysql中判断是否存在
不能像sqlserver一样用if not exists或者exists,应该这样: DECLARE p_count int; set p_count=0; select 1 into p_count ...
- 阿里巴巴手册之-Arrays.asList()数组转集合的问题
转载来源:https://blog.csdn.net/qq_36443497/article/details/79663663?utm_source=blogxgwz9 在使用工具类Arrays.as ...
- Flask-SQLAlchemy笔记(一):通过query语句获取关注用户的帖子
一,预先定义内容 #关联表followers = db.Table('followers', db.Column('follower_id', db.Integer, db.ForeignKey('u ...
- Linux使用mount挂载samba共享文件夹
挂载smb的目录,使用读写644权限 mount -t cifs -o "rw,dir_mode=0644,file_mode=0644,username=username,password ...