Openstack 环境部署并创建Centos 7 虚拟机教程

系统要求

ubuntu 16.04
一定要注意使用ubuntu 16.04系统,其他系统会出现各种莫名其妙的不兼容问题。。。
另外,磁盘存储空间尽量大些!!!否则,随便生成几个实例就没空间。

更换apt源

修改/etc/apt/sources.lis t文件,改成阿里云

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-proposed main restricted universe multiverse  
deb http://mirrors.aliyun.com/ubuntu/ xenial-backports 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-proposed main restricted universe multiverse  
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse

更新apt-get update

安装python2.7以及pip

apt-get install python python-pip

修改【超级用户】的 pip源:

sudo -i #进入超级用户
vim ~/.pip/pip.conf

内容如下:

[global]
index-url = https://mirrors.aliyun.com/pypi/simple/

[install]
trusted-host = https://mirrors.aliyun.com/pypi/simple/

安装proxychains设置代理

安装的中途,openstack需要去亚马逊下载若干个安装包,考虑到可能需要fq ,现在设置好全局代理来。

安装proxychains

apt-get install proxychains

修改proxychains的脚本源码,因为这个版本的会报错:

vim /usr/bin/proxychains

export LD_PRELOAD=libproxychains.so.3 改成 export LD_PRELOAD=/usr/lib/x86_64-linux-gnu/libproxychains.so.3

开启socks5代理端口

使用ssh或ss客户端开启一个可以fq的代理端口。
例如,如果你有一个主机的ss客户端的本地代理端口为 ip: 1080,那么这个1080也可以被用来作为proxychains的代理端口。
当然,你也可以使用ssh隧道来实现这一点,假设你有一台在【美国】的主机,它的ip为xxx.yyy.zzz.qqq。
那么你可以这样:ssh -D 127.0.0.1:1080 root@xxx.yyy.zzz.qqq ,这样也一样在本机开启一个socks5的本地代理端口。

设置proxychains的配置文件

vim /etc/proxychains.conf

把DNS代理关掉
在这里插入图片描述
同时设置socks5的代理端口
在这里插入图片描述
后面跟的就是你的socks5 端口的所在的ip和端口信息。

拉取devstack代码

sudo apt-get install git proxychains
proxychains git clone https://git.openstack.org/openstack-dev/devstack -b stable/queens

创建stack账户

sudo devstack/tools/create-stack-user.sh

将devstack目录放到/opt/stack中并设置权限

sudo mv devstack /opt/stack

sudo chown -R stack:stack /opt/stack

切换到stack用户

sudo su - stack

同样的给stack账户也设置阿里云的pip源:

sudo su - stack
mkdir ~/.pip/
vim ~/.pip/pip.conf

把阿里云源贴上去:

[global]
index-url = https://mirrors.aliyun.com/pypi/simple/

[install]
trusted-host = https://mirrors.aliyun.com/pypi/simple/

编译安装

配置文件

准备配置文件:

sudo su - stack 
cd devstack
cp samples/local.conf ./
cp samples/local.sh   ./

修改配置文件:

vim local.conf

内容:

  1. 修改密码:全部改成统一的secret
    在这里插入图片描述
  2. 在末尾追加:
    在这里插入图片描述
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

安装

OK,安装:

proxychains ./stack.sh

等就完事了,注意如果安装的特别耗时,注意看看pip源和apt源有没有设置正确并生效。
如果不设置阿里云的pip源,安装会巨慢;
如果不设置代理,在安装某些关键包可能失败。

可能的报错

  1. 安装报错:E: Unable to locate package libsystemd-dev。 方法:使用ubuntu 16.04系统走这个教程。

  2. configure: error: *** POSIX caps library not found 。方法:换16.04 系统安装

  3. Syntax Error: EOF while scanning triple-quoted string literal 。。。。方法:这个问题,一般是在安装pip包的时候,被用户强行中断pip的下载或安装过程,导致包才下载一半。解决方法是根据日志找出正在安装什么pip包,手动清空pip的缓存,然后再使用pip install xxx安装这个包,然后重新执行 proxychains ./stack.sh

  4. df : /mnt/hgfs : Protocol Error,系统中有未正确挂载的hgfs设备,把它卸载掉就行。sudo umount /mnt/hgfs

  5. def _collate(*iterables, key=lambda a: a, reverse=False):
    ^
    SyntaxError: invalid syntax 方法:pip install more_itertools==4.0.0

  6. ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: YES) 方法:不使用proxychains 重启一次stack.sh即可。

  7. More than one SecurityGroup exists with the name ‘default’ .不用管,这个问题不大。

  8. Error: Failed to perform requested operation on instance “vm1”, the instance has an error status: Please try again later [Error: Host ‘ccrfox105’ is not mapped to any cell]. 说主机名没有映射到任何的节点。 解决方法:执行:nova-manage cell_v2 discover_hosts

设置网络

stack.sh执行完毕后,访问dashboard. http://172.16.30.174/dashboard ,IP是刚刚执行stack.sh的主机地址。

添加私有网络

在这里插入图片描述
设置网络名称
在这里插入图片描述
设置子网
在这里插入图片描述

配置路由

点击网络拓扑,选择public的一个路由器。
在这里插入图片描述
添加接口
在这里插入图片描述
选择子网
在这里插入图片描述
选完以后就OK啦,可以看到public和private连在一起了。
在这里插入图片描述

配置安全组

所有的虚拟机的默认安全组在启动的时候都会阻止所有外来的连接。我们需要添加新的安全组。
在这里插入图片描述
输入好名称,然后点击“管理规则”,再点击添加规则。
添加四条规则:
所有TCP的出入连接,所有ICMP的出入连接。在这里插入图片描述

添加Centos镜像

去 http://cloud.centos.org/centos/7/images/ 选择一个想要的centos镜像。
我选择的是 CentOS-7-x86_64-GenericCloud-1907.qcow2c ,它是qemu的镜像。
我们想先把镜像下载到本地,然后通过dashboard上传镜像。
在这里插入图片描述
创建镜像,填好就行。在这里插入图片描述
等待一段时间,上传完毕后,就可以从镜像中创建实例了。

创建Centos 7 实例

在这里插入图片描述

设置个名称

选择创建的镜像源,

在这里插入图片描述
也就是刚刚上传的Centos 7.
在这里插入图片描述

选择配置

在这里插入图片描述

选择所属的网络

在这里插入图片描述

选择安全组

在这里插入图片描述
选择刚刚设置好的TCP/ICMP全通的安全组。

选择密钥对

在此刻配置密钥对,可以在后面首次登陆的时候直接使用ssh私钥登录,而不用输入密码。
点击创建密钥对,然后选择这个新建的密钥对。在创建的同时,dashboard会主动让你下载好私钥文件xxx.pem,这个就是在ssh登录的时候用的。
在这里插入图片描述

OK 创建一波

创建中。。。。
在这里插入图片描述
创建完毕:::
在这里插入图片描述
可以看到,此时新建立的虚拟机只有私有IP 10.0.0.92 ,需要绑定一个外部可以访问的IP,x在这里插入图片描述
选择动作:绑定浮动IP.
在这里插入图片描述
选择外部IP资源池,点击“分配IP”
在这里插入图片描述
可以看到,分配了一个172.24.4.5 的外部IP,点击“关联”。
在这里插入图片描述
此时,就可以看到刚刚的Centos JM虚拟机有两个IP啦。

在这里插入图片描述

对于公有云来说,当外部IP资源池改成他自己的外网IP池的时候,就实现了外网IP的分配了。

登录一波

在执行stack.sh的那个主机,执行ssh登录。
先Ping一下,看网络是否连通:
在这里插入图片描述
发现没毛病,ssh登录一波:
在这里插入图片描述
发现报错,得用centos用户名登录
在这里插入图片描述
再次登录:ssh ceontos@172.24.4.5 -i /home/dk/dk-keys.pem -i 后面跟的就是刚刚设置的密钥对的私钥文件。

在这里插入图片描述

发现登录成功!!!使用ifconfig,可以看到就是Centos JM的私网IP。

参考资料

  1. Ubuntu16安装OpenStack https://www.jianshu.com/p/d4e91feceb05
  2. 优雅安装OpenStack https://zhuanlan.zhihu.com/p/28996062
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenStack 是一款开源的云计算平台,它提供了一系列的服务,包括计算、存储、网络、安全等,可以帮助用户构建自己的私有云环境OpenStack 部署比较复杂,需要涉及到多个组件和配置文件。下面是一份 OpenStack 部署完整教程: 1. 准备环境:为了能够顺利部署 OpenStack,你需要先准备好一组物理机或虚拟机,并且安装好 CentOS 7 操作系统。此外,你还需要确保这些机器之间可以互相通信,建议使用一个专用的管理网络。 2. 安装必要的软件:在所有的节点上安装必要的软件和工具,包括 Python、epel-release、yum-utils、git 等。你可以使用以下命令进行安装: ``` yum install -y python epel-release yum-utils git ``` 3. 安装 MariaDB 数据库:OpenStack 使用 MariaDB 数据库来存储数据,你需要在一个节点上安装 MariaDB,并且创建相应的数据库和用户。你可以使用以下命令进行安装: ``` yum install -y mariadb mariadb-server python2-PyMySQL systemctl enable mariadb systemctl start mariadb mysql_secure_installation ``` 4. 安装 RabbitMQ 消息队列:OpenStack 使用 RabbitMQ 作为消息队列,你需要在一个节点上安装 RabbitMQ。你可以使用以下命令进行安装: ``` yum install -y rabbitmq-server systemctl enable rabbitmq-server systemctl start rabbitmq-server rabbitmqctl add_user openstack RABBIT_PASS rabbitmqctl set_permissions openstack ".*" ".*" ".*" ``` 5. 安装 Memcached 缓存服务:OpenStack 使用 Memcached 缓存服务来提高性能,你需要在所有节点上安装 Memcached。你可以使用以下命令进行安装: ``` yum install -y memcached python-memcached systemctl enable memcached systemctl start memcached ``` 6. 配置 OpenStack 源:在所有节点上配置 OpenStack 源,并且安装相应的软件包。你可以使用以下命令进行配置: ``` yum install -y centos-release-openstack-queens yum-config-manager --enable openstack-queens yum update ``` 7. 配置网络:OpenStack 需要使用 Neutron 网络服务来管理网络,你需要在所有节点上配置网络。具体的配置方法因环境而异,可以参考 OpenStack 的官方文档进行配置。 8. 安装 OpenStack:在所有节点上安装 OpenStack 相关的组件和服务。这个过程比较复杂,需要涉及到多个组件和配置文件。你可以参考 OpenStack 的官方文档进行安装和配置。 9. 验证 OpenStack:在 OpenStack 安装完成后,你需要对其进行验证,确保各个服务都能够正常工作。你可以使用 OpenStack 的 Dashboard 来进行验证,也可以使用命令行工具(如 nova、glance、neutron 等)进行验证。 以上是 OpenStack 部署完整教程的大致步骤,具体的操作方法和步骤因环境而异,需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值