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自动化搭建脚本的更多相关文章

  1. linux集群自动化搭建(生成密钥对+分发公钥+远程批量执行脚本)

    之前介绍过ansible的使用,通过ssh授权批量控制服务器集群 但是生成密钥和分发公钥的时候都是需要确认密码的,这一步也是可以自动化的,利用ssh + expect + scp就可以实现,其实只用这 ...

  2. python+paramiko库+svn写的自动化部署脚本

    第一篇博文 直接开门见山的说了. 这是件什么事?:每次部署都是复制本地的文件粘贴到服务器端,因为路径复杂,所以费时且手工容易出漏洞. 一直在想有什么办法可以解决这种,因为以前在微软的一个牛人同事做过一 ...

  3. CentOS 下运维自动化 Shell 脚本之 expect

    CentOS 下运维自动化 Shell脚本之expect 一.预备知识: 1.在 Terminal 中反斜杠,即 "" 代表转义符,或称逃脱符.("echo -e与pri ...

  4. linux软件管理之------编译安装nginx服务器并手动编写自动化运行脚本

    红帽系列的 linux软件管理分为三类:1. rpm 安装软件.2. yum 安装软件.3. 源码包编译安装.前面两种会在相关专题给出详细讲解.源码包的编译安装是非常关键的,我们知道linux的相关版 ...

  5. 深入理解Openstack自动化部署

    前言 说实话,看到自己在博客园的排名感到惭愧,因为自己最近两年没有持续地在博客园上写技术博客了,有人私下问我是不是荒废了?翻翻15年和16年的博客,真的是少的可怜.一方面的确由于岗位的变化,导致了工作 ...

  6. python自动化执行脚本

    ---恢复内容开始--- 1 (1)首先在你的.py文件上加上一行代码注释: #!/usr/local/bin/python2.7 (2)终端下执行: crontab -e 进入后,输入i 进入可编辑 ...

  7. 设置ssh免密码登录脚本(hadoop自动化部署脚本一)

    设置ssh免密码登录脚本(hadoop自动化部署脚本一) 设置ssh免密码登录脚本(飞谷云大数据自动化部署脚本一) 1.#!/bin/sh2.#important note:this script i ...

  8. openstack一键安装脚本(转载)

    #!/bin/sh # openstack pike 单机 一键安装 # 环境 centos 7.4.1708 x86_64 # 更多内容 http://dwz.cn/openstack # Myde ...

  9. Jenkins持续集成-自动化部署脚本的实现

    要实现Jenkins端的持续集成,其实在CI服务配置端很容易,难点呢?就是如何实现自动化的部署.我的脚本设计就是为了解决以下难题: 难点一.如何使得自动化部署脚本更通用 我用的脚本,依赖依赖一个配置文 ...

随机推荐

  1. Spring整合MyBatis案例练习笔记

    需求: 用户登录 技术需求: Servlet+Spring+Mybatis+MVC+jsp+css+html+jquery 数据库设计: 用户表 Sql语句设计: select * from t_us ...

  2. python面试的100题(17)

    内存管理与垃圾回收机制 48.哪些操作会导致Python内存溢出,怎么处理? 内存溢出:你申请了10个字节的内存,但写入了大于10个字节的数据会导致内存溢出 内存溢出原因:1.内存中加载的数据量过于庞 ...

  3. Jmeter-Badboy检查点和参数化

    Badboy进行检查点操作 1.复制搜索的内容,点击Tools,选择添加断言Add Assertion for Selection 2.这个时候Step1步骤下就会多一个检查点 3.点击工具栏上的Pl ...

  4. go语言 内置的椭圆数字签名及其验证算法

    package main import ( "crypto/ecdsa" "crypto/elliptic" "crypto/rand" & ...

  5. Python调用cmd命令

    常用的两种方式: 1.python的OS模块. OS模块调用CMD命令有两种方式:os.popen(),os.system(). 都是用当前进程来调用. os.system是无法获取返回值的.当运行结 ...

  6. 用户登录(php)

    <!DOCTYPE HTML><html><head><meta charset="utf-8"><script type=& ...

  7. maven报错Non-resolvable parent POM---pom找不到parent

    没有配置relativePath属性,说明运行的时候使用的是默认的,所以它会在默认的pom父类中查找,而不会到我自己创建的里面进行寻找 参考链接:https://blog.csdn.net/qq_37 ...

  8. django 自定义url转换器

    django内置的url转换器,包括有int.str.uuid等等.但是有时候他们不能满足我们的需求,因此就需要使用自定义url转换器.自定义url转换器的五步:1.定义一个类,直接继承自object ...

  9. jdk动态代理底层实现

    一.代理设计模式 代理设计模式是Java常用的设计模式之一. 特点: 01.委托类和代理类有共同的接口或者父类: 02.代理类负责为委托类处理消息,并将消息转发给委托类: 03.委托类和代理类对象通常 ...

  10. mybatis(六):设计模式 - 单例模式