一、实验环境

  本实验是在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的更多相关文章

  1. kolla单节点部署openstack

    virtualbox环境: 双网卡:enp0s3(桥接)   192.168.102.194 enp0s8(桥接)   无ip 块存储  50G 关闭防火墙,selinux. 配置yum源:wget  ...

  2. HyperLedger Fabric 1.4 单机单节点部署(10.2)

    单机单节点指在一台电脑上部署一个排序(Orderer)服务.一个组织(Org1),一个节点(Peer,属于Org1),然后运行官方案例中的example02智能合约例子,实现转财交易和查询功能.单机单 ...

  3. .netcore consul实现服务注册与发现-单节点部署

    原文:.netcore consul实现服务注册与发现-单节点部署 一.Consul的基础介绍     Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分 ...

  4. Kubernetes 二进制部署(一)单节点部署(Master 与 Node 同一机器)

    0. 前言 最近受“新冠肺炎”疫情影响,在家等着,入职暂时延后,在家里办公和学习 尝试通过源码编译二进制的方式在单一节点(Master 与 Node 部署在同一个机器上)上部署一个 k8s 环境,整理 ...

  5. Ubuntu系统上双节点部署OpenStack

    安装和部署双节点OpenStack 介绍: 1.宿主机:Win10操作系统 2.在VMware下创建两台虚拟机: devstack-controller:控制节点 + 网络节点 + 块存储节点 + 计 ...

  6. 恒天云单节点部署指南--OpenStack H版本虚拟机单节点部署解决方案

    本帖是openstack单节点在虚拟机上部署的实践.想要玩玩和学习openstack的小伙伴都看过来,尤其是那些部署openstack失败的小伙伴.本帖可以让你先领略一下openstack的魅力.本I ...

  7. kolla 多节点部署 openstack

    kolla 介绍 简介 kolla 的使命是为 openstack 云平台提供生产级别的.开箱即用的交付能力.kolla 的基本思想是一切皆容器,将所有服务基于 Docker 运行,并且保证一个容器只 ...

  8. Presto0.157版本单节点部署教程

    因为Presto版本的更新速度较快,所以最好按照对应版本的教程进行部署,博主之前看错了版本号,拿0.100版本的教程来部署0.157版本,结果导致部署失败. 官网:https://prestodb.i ...

  9. MongoDB 3.2复制集单节点部署(四)

    MongoDB在单节点中也可以做复制集,但是仅限于测试实验,最大的好处就是部署方便快速,可以随便添加新节点,节省资源.在这里我使用的是MongoDB 3.2版本进行复制集实验(但MongoDB配置文件 ...

随机推荐

  1. 宏使用 Tricks

    人为地定义一些"无意义"的宏(宏名本身有意义),以起到提升代码程序的可读性. 1. IN/OUT 指定参数用于输入还是输出: #define IN #define OUT void ...

  2. Python基础知识记录

    1.去除空格 strip()  删除两边的空格.lstrip() 删除左边的空格.rstrip() 删除右边的空格 2.字符串的连接 s1='abc'  s2='cdf' s3=s1+s2    pr ...

  3. office web app server 文件预览部署&& wopi 集成使用

    对于需要进行office 套件文档预览的时候大部分大家使用的是插件,或者类似的,解决方案,微软已经为我们提供了比较好的解决 方案 office web app server (目前名称是office ...

  4. PHP代码实现 1

    $PHP-SRC/run-test.php 因为如果在同一个进程中执行, 测试就会停止,后面的测试也将无法执行,php中有很多将脚本隔离的方法比如: system(),exec()等函数,这样可以使用 ...

  5. Oracle使用startup与startup force启动的区别

    1. startup 就是正常启动数据库,没什么好说的. 2. startup force 是shutdown abort + startup的组合,即强制关闭数据库+ 正常启动数据库,想快速重启数据 ...

  6. word文档批量合并工具

    #NoEnv ; Recommended for performance and compatibility with future AutoHotkey releases. ; #Warn ; En ...

  7. Java 迭代器 Iterator

    迭代器模式 迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式.这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示. 迭代器模式属于行 ...

  8. MySQL 高性能存储引擎:TokuDB初探

    在安装MariaDB的时候了解到代替InnoDB的TokuDB,看简介非常的棒,这里对ToduDB做一个初步的整理,使用后再做更多的分享. 什么是TokuDB? 在MySQL最流行的支持全事务的引擎为 ...

  9. 【UVALive】4094 WonderTeam(神结论)

    题目 传送门:QWQ 分析 好神的结论啊 看代码吧(Length只有85) 代码 顺手压了压代码      目前代码长度rk1 vjudge #include <iostream> ?:n ...

  10. Windows 上用IntelliJ Idea调试百度大数据分析框架Apache Doris FE

    A. 环境准备 1. 安装jdk1.8+, Intelij IDEA 2. linux上编译好fe前端代码,主要目的是获取自动生成的代码,加入到前段工程里面去用于在idea中编译fe工程.具体编译请参 ...