Ubuntu下用devstack单节点部署Openstack
一、实验环境
本实验是在Vmware Workstation下创建的单台Ubuntu服务器版系统中,利用devstack部署的Openstack Pike版。
宿主机:win10 1803 8G内存 256G SSD
虚拟软件:Vmware Workstation 12.5.9
虚拟机系统:Ubuntu Server 16.04.5 LTS
参考博客:
https://blog.csdn.net/pfztab/article/details/78632393
https://www.cnblogs.com/Allvirus/p/7783962.html
https://docs.openstack.org/devstack/latest/guides/multinode-lab.html
1、在宿主机中安装好VMware Workstation 12.5.9
VMware Workstation 12.5.9官网下载链接
2、在VMware中创建Ubuntu服务器版系统
(1)在 http://mirror.pnl.gov/releases/xenial/ 中找到并下载Ubuntu Server 16.04.5镜像。

(2)关于如何在VMware中安装Ubuntu服务器版虚拟机,网上有很多教程,具体可以参考:https://www.cnblogs.com/huozf/p/9780747.html(因为是单节点部署,再加上本身电脑配置不高,所以我分配了4G内存给虚拟机。)
二、环境搭建
1、为root设置密码并使用root登录
使用创建虚拟机时创建的用户登录Ubuntu后为root用户设置密码,以便于后面使用root用户登录和后续操作。
(1) 输入命令:sudo passwd
(2)系统会提示输入当前用户密码
(3)输入你要为root用户设置的密码
(4)再次输入root用户的密码
(5)root用户密码设置好后,输入命令:su root,然后输入刚刚设置的密码,切换到root用户。
2、网络设置
因为是单节点配置,不需要各节点间的通信,再加上物理机为笔记本不经常插网线,所以只给虚拟机分配了一个NAT的网络适配器,既可以访问外网,也可以和物理机通信。为虚拟机设置好固定IP,如果是多节点安装的话,这一步很重要。
① 回到VMware,点击编辑,启动虚拟网络编辑器,选择vmnet8,编辑以下内容(当然也可以按照自己的默认设置来):

② 回到ubuntu输入命令:vim /etc/network/interfaces
③ 在打开的配置文件中输入以下内容:
(该部分内容根据自己的VMware配置的NAT网络将address和gateway进行相应的修改,dns根据自己的网络环境做相应的修改)
auto ens33
iface ens33 inet static
address 10.10.10.10
netmask 255.255.255.0
gateway 10.10.10.2
dns-nameserver 114.114.114.114
3、Linux默认不允许SSH远程登录,修改sshd_config文件以允许root远程登录。
(1)若在创建虚拟机时没有选择安装ssh,输入命令:apt install openssh-server,如果已经安装,自动忽略该步骤。
(2)输入命令:vim /etc/ssh/sshd_config
(3)在打开的配置文件中找到PermitRootLogin,将其对应值改为yes。保存退出。

(4)重启服务:service ssh restart
(5)使用ifconfig命令查看虚拟机IP,使用Xshell或putty等ssh客户端远程登录到虚拟机,方便后面的代码复制操作。
4、修改apt源为国内的源
① 输入命令:vim /etc/apt/sources.list
② 清空并替换为(此处为阿里的源):
deb http://mirrors.aliyun.com/ubuntu/ xenial main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ xenial-proposed main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ xenial main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ xenial-proposed main restricted universe multiverse
③ 保存退出,更新:
apt update
apt upgrade
5、安装并配置pip
(1)输入命令:apt install python-pip
(2)配置pip源
mkdir ~/.pip
vim ~/.pip/pip.conf
在打开的文件中输入以下内容:
[global]
index-url = http://pypi.douban.com/simple/
trusted-host = pypi.douban.com
注:看了很多文档和博客教程,很多都是配置的豆瓣的pip源,我之前也试过,在安装P版的过程中每次都会报依赖不匹配的错误,如下图。后来把pip源注销之后就成功了。
6、设置时间同步
(1)设置时区:dpkg-reconfigure tzdata,选择Asia --> Shanghai --> ok
注:输入date 查看系统时间,是否正确,如果正确,可以忽略下边操作步骤。
(2)apt install ntpdate // 安装时间同步工具
(3)ntpdate cn.pool.ntp.org // 与网络服务器同步时间
(4)date // 查看时间是否已同步
三、安装OpenStack
1、创建stack用户
创建: useradd -s /bin/bash -d /opt/stack -m stack
赋权: echo "stack ALL=(ALL) NOPASSWD: ALL"
>> /etc/sudoers
切换到stack用户:su – stack
重复第二步中的5(2),同样为stack用户配置pip源:
mkdir ~/.pip
vim ~/.pip/pip.conf
在打开的文件中输入以下内容:
[global]
index-url
= http://pypi.douban.com/simple/
trusted-host
= pypi.douban.com
注:如果出现依赖不匹配的错误,这里的pip源同样也要注释掉
2、下载devstack ( stable后面的参数为要下载的版本)
git clone https://git.openstack.org/openstack-dev/devstack
-b stable/pike
3、编辑local.conf文件
(1)进入目录:cd devstack
(2)输入命令:vim local.conf
(3)添加以下内容:
[[local|localrc]] HOST_IP=10.10.10.10
LOGFILE=/opt/stack/logs/stack.sh.log # Credentials
ADMIN_PASSWORD=admin
MYSQL_PASSWORD=$ADMIN_PASSWORD
RABBIT_PASSWORD=$ADMIN_PASSWORD
SERVICE_PASSWORD=$ADMIN_PASSWORD
SERVICE_TOKEN=abcdefghijklmnopqrstuvwxyz # enable neutron-ml2-vlan
disable_service n-net
enable_service q-svc,q-agt,q-dhcp,q-l3,q-meta,q-metering,neutron # Branches
KEYSTONE_BRANCH=stable/pike
NOVA_BRANCH=stable/pike
NEUTRON_BRANCH=stable/pike
SWIFT_BRANCH=stable/pike
GLANCE_BRANCH=stable/pike
CINDER_BRANCH=stable/pike # use TryStack git mirror
GIT_BASE=http://git.trystack.cn
NOVNC_REPO=http://git.trystack.cn/kanaka/noVNC.git
SPICE_REPO=http://git.trystack.cn/git/spice/spice-html5.git # Define images to be automatically downloaded during the DevStack built process.
DOWNLOAD_DEFAULT_IMAGES=False
IMAGE_URLS="http://download.cirros-cloud.net/0.3.4/cirros-0.3.4-x86_64-disk.img"
有关local.conf相关配置可以参考:http://www.chenshake.com/local-conf-devstack-profile-parameter-description/
4、执行命令:./stack.sh
大约一个小时左右出现下面信息,表明安装成功:

Ubuntu下用devstack单节点部署Openstack的更多相关文章
- kolla单节点部署openstack
virtualbox环境: 双网卡:enp0s3(桥接) 192.168.102.194 enp0s8(桥接) 无ip 块存储 50G 关闭防火墙,selinux. 配置yum源:wget ...
- HyperLedger Fabric 1.4 单机单节点部署(10.2)
单机单节点指在一台电脑上部署一个排序(Orderer)服务.一个组织(Org1),一个节点(Peer,属于Org1),然后运行官方案例中的example02智能合约例子,实现转财交易和查询功能.单机单 ...
- .netcore consul实现服务注册与发现-单节点部署
原文:.netcore consul实现服务注册与发现-单节点部署 一.Consul的基础介绍 Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分 ...
- Kubernetes 二进制部署(一)单节点部署(Master 与 Node 同一机器)
0. 前言 最近受“新冠肺炎”疫情影响,在家等着,入职暂时延后,在家里办公和学习 尝试通过源码编译二进制的方式在单一节点(Master 与 Node 部署在同一个机器上)上部署一个 k8s 环境,整理 ...
- Ubuntu系统上双节点部署OpenStack
安装和部署双节点OpenStack 介绍: 1.宿主机:Win10操作系统 2.在VMware下创建两台虚拟机: devstack-controller:控制节点 + 网络节点 + 块存储节点 + 计 ...
- 恒天云单节点部署指南--OpenStack H版本虚拟机单节点部署解决方案
本帖是openstack单节点在虚拟机上部署的实践.想要玩玩和学习openstack的小伙伴都看过来,尤其是那些部署openstack失败的小伙伴.本帖可以让你先领略一下openstack的魅力.本I ...
- kolla 多节点部署 openstack
kolla 介绍 简介 kolla 的使命是为 openstack 云平台提供生产级别的.开箱即用的交付能力.kolla 的基本思想是一切皆容器,将所有服务基于 Docker 运行,并且保证一个容器只 ...
- Presto0.157版本单节点部署教程
因为Presto版本的更新速度较快,所以最好按照对应版本的教程进行部署,博主之前看错了版本号,拿0.100版本的教程来部署0.157版本,结果导致部署失败. 官网:https://prestodb.i ...
- MongoDB 3.2复制集单节点部署(四)
MongoDB在单节点中也可以做复制集,但是仅限于测试实验,最大的好处就是部署方便快速,可以随便添加新节点,节省资源.在这里我使用的是MongoDB 3.2版本进行复制集实验(但MongoDB配置文件 ...
随机推荐
- 宏使用 Tricks
人为地定义一些"无意义"的宏(宏名本身有意义),以起到提升代码程序的可读性. 1. IN/OUT 指定参数用于输入还是输出: #define IN #define OUT void ...
- Python基础知识记录
1.去除空格 strip() 删除两边的空格.lstrip() 删除左边的空格.rstrip() 删除右边的空格 2.字符串的连接 s1='abc' s2='cdf' s3=s1+s2 pr ...
- office web app server 文件预览部署&& wopi 集成使用
对于需要进行office 套件文档预览的时候大部分大家使用的是插件,或者类似的,解决方案,微软已经为我们提供了比较好的解决 方案 office web app server (目前名称是office ...
- PHP代码实现 1
$PHP-SRC/run-test.php 因为如果在同一个进程中执行, 测试就会停止,后面的测试也将无法执行,php中有很多将脚本隔离的方法比如: system(),exec()等函数,这样可以使用 ...
- Oracle使用startup与startup force启动的区别
1. startup 就是正常启动数据库,没什么好说的. 2. startup force 是shutdown abort + startup的组合,即强制关闭数据库+ 正常启动数据库,想快速重启数据 ...
- word文档批量合并工具
#NoEnv ; Recommended for performance and compatibility with future AutoHotkey releases. ; #Warn ; En ...
- Java 迭代器 Iterator
迭代器模式 迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式.这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示. 迭代器模式属于行 ...
- MySQL 高性能存储引擎:TokuDB初探
在安装MariaDB的时候了解到代替InnoDB的TokuDB,看简介非常的棒,这里对ToduDB做一个初步的整理,使用后再做更多的分享. 什么是TokuDB? 在MySQL最流行的支持全事务的引擎为 ...
- 【UVALive】4094 WonderTeam(神结论)
题目 传送门:QWQ 分析 好神的结论啊 看代码吧(Length只有85) 代码 顺手压了压代码 目前代码长度rk1 vjudge #include <iostream> ?:n ...
- Windows 上用IntelliJ Idea调试百度大数据分析框架Apache Doris FE
A. 环境准备 1. 安装jdk1.8+, Intelij IDEA 2. linux上编译好fe前端代码,主要目的是获取自动生成的代码,加入到前段工程里面去用于在idea中编译fe工程.具体编译请参 ...