openstack搭建及基本配置
节点servera:
配置好yum后
yum -y update 更新yum仓库
安装openstack
yum -y install openstack-packstack
packstack --gen-answer-file=/root/answers.txt 将openstack的配置文件写到当前生成一个answer.txt自定名的文件
vim /root/answers.txt 修改answer.txt文件内的以下几条内容
data:image/s3,"s3://crabby-images/f92e9/f92e997978c66f398be97feeb8b57be948192d44" alt="1.png enter description here"
1、
CONFIG_NTP_SERVERS=172.25.254.254 67行
指定的连接的服务端
data:image/s3,"s3://crabby-images/2e282/2e2827ec4505cfaffc0c019488761c13320830c0" alt="2.png enter description here"
1、
CONFIG_COMPUTE_HOSTS=172.25.0.10 89行
指定本机的IP地址
data:image/s3,"s3://crabby-images/332c8/332c85fe16561e6298d2c1b8efa27fc30066af04" alt="3.png enter description here"
1、
CONFIG_KEYSTONE_ADMIN_PW=redhat 246行
登陆admin用户的密码
data:image/s3,"s3://crabby-images/21487/2148774d64bd9a8587280370adf89bf860bb9878" alt="4.png enter description here"
1、
CONFIG_CINDER_VOLUMES_CREATE=n 282行
关掉cinder volume
data:image/s3,"s3://crabby-images/752f4/752f41ffc64be8f39d72b2aa992365bc5feda97e" alt="5.png enter description here"
1、
CONFIG_NEUTRON_OVS_TUNNEL_IF=eth1 554行行
指定默认的网卡接口名称
data:image/s3,"s3://crabby-images/cf7d3/cf7d3e36d146487d5f30066a8f749ba9dc1c95bc" alt="5a.png enter description here"
1、
CONFIG_HORIZON_SSL=y 560行行行
开启ssl服务
data:image/s3,"s3://crabby-images/cf525/cf525c8624e232a3c2814762643b4a097acb6d8f" alt="6.png enter description here"
1、
CONFIG_SWIFT_INSTALL=y 39行
开启swift服务
data:image/s3,"s3://crabby-images/90055/9005506afaef41cde61b6933f989f15eb689634f" alt="7.png enter description here"
1、
CONFIG_PROVISION_DEMO=n 629行
不用demo
data:image/s3,"s3://crabby-images/4ddcd/4ddcd318a8dbd17ac13063e6f7735d4b8f98ea3d" alt="8.png enter description here"
1、
packstack --answer-file /root/answers.txt 将写好的文件配置openstack
data:image/s3,"s3://crabby-images/a5814/a58145077dbb66c1b3629bd5778e30da5c048e07" alt="9.png enter description here"
配置后的信息
data:image/s3,"s3://crabby-images/b353e/b353e67a291b3648095e4588fea09df89f5c52c4" alt="10.png enter description here"
1-5、
禁止、关闭、屏蔽NetworkManager.service;下次启动、开始network.service
进入到/etc/sysconfig/network-scripts
将ifcfg-eth0复制成ifcfg-br-ex
data:image/s3,"s3://crabby-images/b539a/b539a8efb8ead4b4027c8ec465d7899764aff078" alt="11.png enter description here"
1-2、
编辑ifcfg-eth0后的配置
编辑ifcfg-br-ex后的配置
systemctl restart network
当重启服务没出错时,说明以上所配置的文件没有问题
以下图形化的操作所有带*号标记都必须填
data:image/s3,"s3://crabby-images/add06/add060eb57c51aa99d85b00bbbd3c5f5dc29d278" alt="12.png enter description here"
1-2、
登陆admin用户
data:image/s3,"s3://crabby-images/2d712/2d71257ad6c9ba1d3a942df9a8eb4edd77a3d221" alt="13.png enter description here"
1-3、
在ldentity-projects下创建一个poreject1组,需要的性能配置如下:
虚拟cpu:2
磁盘空间:10G
内存:4296M
实例:2
data:image/s3,"s3://crabby-images/63cde/63cdec395143c1fa66e2a5a33cfab4be7e36c217" alt="14.png enter description here"
data:image/s3,"s3://crabby-images/da397/da397e211e8e71ab12ece38f57c146fd19a49e5b" alt="15.png enter description here"
1-4、
VCPUs 2 #cpu个数
instances 2 #创建多少个虚拟机
Injected File
Injected File Content
Volumes #数据区,硬盘个数
Volunme Snapshost #数据区,硬盘个数
Total Size of Volumes and Snapshost(GB) 10 #硬盘大小
RAM(MB) 4096 #运行内存
Security Groups #安全组,创多少个服务
Security Group Rules #总服务创建多少个条目
Floating IPs #浮动IP
Networks #每个服务的网络
Ports #端口
Routers #路由
Subnets
data:image/s3,"s3://crabby-images/ad33d/ad33d1d31b6c5c6f87ae66dc100ade13e10b952a" alt="16.png enter description here"
data:image/s3,"s3://crabby-images/8c904/8c90409937817cc408a1b5671f83089fe6338a6f" alt="17.png enter description here"
在ldentity-users下创建adm1和usr1,将这2个用户加入到project1这个组;
1-6、
adm1为管理员用户,邮箱为adm1@example.com,密码:redhat
usr1为普通用户,邮箱为usr1@example.com,密码:redhat
data:image/s3,"s3://crabby-images/0eb64/0eb6445c14bc1eb4b85c6eb88d2ceb351d5dffaf" alt="18.png enter description here"
data:image/s3,"s3://crabby-images/7bc6d/7bc6d43d175dd973964eacedb817b6866ede7d35" alt="19.png enter description here"
在Admin-System-Networks-Flavor下创建一个公有的flavor,flavor的配置如下:
1-7、
name:m2.tiny
VCPU:1
Ram:1024MB
Root disk:20GB
Ephemeral disk:2GB
Swap:512MB
data:image/s3,"s3://crabby-images/780d0/780d0863a2ab87688686736ab4e5aa40082e752f" alt="20.png enter description here"
data:image/s3,"s3://crabby-images/a94c2/a94c24dde143b2e4687c086f04d3bec969320665" alt="21.png enter description here"
data:image/s3,"s3://crabby-images/885bc/885bc9031208221500e10bc81c6310cad3bd871b" alt="22.png enter description here"
在Admin-System-Images下添加一个共享镜像,在指定的位置将镜像文件下到本地
1-5、
name:small
image location:http://classroom.example.com/pub/materials/samall.img
format:QCOW2-QEMU Emulator
勾选:Public 将此镜像共享
data:image/s3,"s3://crabby-images/a9d33/a9d334471faead2b38aedd5437888fec60a5e8d3" alt="23.png enter description here"
data:image/s3,"s3://crabby-images/459c3/459c3353a2c39266c611ed431622d1840651ed9b" alt="24.png enter description here"
1、
切换到普通用户usr1下
data:image/s3,"s3://crabby-images/8650d/8650d310e3b1808617c87e1d4642676389fd1c3a" alt="25.png enter description here"
data:image/s3,"s3://crabby-images/1c027/1c027648b477fd799c802d9cc23a763ebf79f624" alt="26.png enter description here"
data:image/s3,"s3://crabby-images/f7b8a/f7b8a1123f5833a0a7ba45ee78f5cc0fc4c3338c" alt="27.png enter description here"
data:image/s3,"s3://crabby-images/5e56c/5e56cc3413be3133bbd8929d70d1fce98bbcdc25" alt="28.png enter description here"
在project创建一个网络分为:内网和外网
1-3、
内网
name:int
子网名:subint
IP地址:192.168.0.0/24
DHCP:开启
data:image/s3,"s3://crabby-images/a59a1/a59a103bbf12834678b8d3f66fd4e8dfbc201526" alt="29.png enter description here"
data:image/s3,"s3://crabby-images/6eb38/6eb38d99fe39f49f401e36d0d733d42d954349c7" alt="30.png enter description here"
data:image/s3,"s3://crabby-images/2c111/2c11156fe17f117e7ba3575cb91e1e8c1a167570" alt="31.png enter description here"
1-3
外网
name:0ext
子网名:subext
IP地址:172.25.0.0/24
static池:172.25.0.29,172.25.0.99
data:image/s3,"s3://crabby-images/7204b/7204b9b1ad7b933b5ef85c6a4dc716db9663ae76" alt="33.png enter description here"
data:image/s3,"s3://crabby-images/c60e0/c60e06302ca630ffad00a4a33e652be71b2b51cf" alt="32.png enter description here"
1、
创建一个路由器
data:image/s3,"s3://crabby-images/0dc50/0dc509222e92d5fac45202181f44362a6ab15f05" alt="34.png enter description here"
1、
登陆到project1组的管理员adm1
data:image/s3,"s3://crabby-images/8eec8/8eec83d4c45bc1dca38931e799155aa8a6339dfd" alt="35.png enter description here"
data:image/s3,"s3://crabby-images/6b5d3/6b5d376abfa8fdd2804ac1a35b649b565f6fdcaf" alt="36.png enter description here"
1-3、
在Admin-Sysm-Networks下,Edlit Network编辑ext,将ext加入到External Network外网
data:image/s3,"s3://crabby-images/d1e82/d1e825b6fa1803802f370def92bd0d40378bbb6c" alt="37.png enter description here"
登陆usr1上
data:image/s3,"s3://crabby-images/44e57/44e570cd15e4d8f36075268629278e38a3aa4557" alt="38.png enter description here"
1-2、
在 Project-Networks-Routers下,以router1添加set gateway,将ext在usr1用户下对应adm1管理员上的外网,将路由条目写入路由表。
data:image/s3,"s3://crabby-images/fc99c/fc99c4ed6acb473346011b4b6e15ca25faaa3fd2" alt="39.png enter description here"
1-2、
点击router1,进入后点击add interface添加一个条目将该条目加入router1,该路由会自动生成一个ID。
data:image/s3,"s3://crabby-images/85634/85634570a51d3b1c1e66efad28154d91a037defa" alt="40.png enter description here"
data:image/s3,"s3://crabby-images/da906/da906e6f6fd50be9c63b5f17eb3f07d0a27ba38c" alt="41.png enter description here"
data:image/s3,"s3://crabby-images/14068/14068ddae219c89f7bc2b40c329ede2a19ef9266" alt="42.png enter description here"
在以project1组创建一个安全组,开放http、https、ssh服务
在Project-Compute-Access&Security-Security Groups下Creale Security Group添加一个安全组
name:sec1
description:sec1
data:image/s3,"s3://crabby-images/02ae9/02ae9318bfe31b27ca3a48c082094dc1382aa64a" alt="43.png enter description here"
data:image/s3,"s3://crabby-images/300fe/300fe6884e095925a33d1a2018792f8158404db3" alt="44.png enter description here"
data:image/s3,"s3://crabby-images/14bd3/14bd3847988610b7f7943a7db4bce5ccf85b4803" alt="45.png enter description here"
data:image/s3,"s3://crabby-images/15fb1/15fb1b5cde6d4fda260b2da98c701bc78fefef21" alt="46.png enter description here"
1-3、
在Project-Compute-Access&Security下点击sec1下的Manage Rules,Add Rule添加策略
http:80端口
https:443端口
ssh:22端口
** 按要求是添加对应的端口,但在添加是只能看到服务名
data:image/s3,"s3://crabby-images/04184/0418418097103ba0ddc78e575a36d13ffa4b0a6b" alt="47.png enter description here"
data:image/s3,"s3://crabby-images/49fc3/49fc39584e7d90339a2fdb8962a4a0b0b636ffd8" alt="48.png enter description here"
1-2、
在Project-Compute-Access&Security-Key Palrs下添加一把钥匙,并将钥匙下载到本地
name:key
data:image/s3,"s3://crabby-images/46559/46559a93091d16f9b297d5cee5e541ea7224ba00" alt="49.png enter description here"
data:image/s3,"s3://crabby-images/6cb0d/6cb0d4004621eea32758b7031130aa6f91674923" alt="50.png enter description here"
1-2、
下载的文件在真机下/tmp下,用命令scp将/tmp/key.pem root@servera.pod0.example.com:/root/.ssh/key下
并给予读写权限chmod 600 key
data:image/s3,"s3://crabby-images/21d53/21d53ef44e17fa4b0c6795b73d6bb707559b899e" alt="51.png enter description here"
data:image/s3,"s3://crabby-images/bf39d/bf39d99177c0a54e3d0a3d403b71a67f1d906d1e" alt="52.png enter description here"
data:image/s3,"s3://crabby-images/76956/76956d65f70dec4e0a68de2cc96452db46a97a86" alt="53.png enter description here"
data:image/s3,"s3://crabby-images/06064/06064795a92a3858f28a325ddd6c6ed275e1f4c0" alt="54.png enter description here"
以M2.tiny创建一个web实例,将上面small镜像、安全策略sec1、key钥匙加入web中实现一个模版
1-5、
在Project-Compute-Instances下,Launch Instance创建一个模版
Instance Name:web
Flavor:m2.tiny
Instance Count:1
Instance Boot Source:Boot from image
Image Name:small(340.3MB)
/
Key Palr:key
Securlty Groups:勾选sec1
/
Selected networks:+int
data:image/s3,"s3://crabby-images/dfc2e/dfc2e95291ebfa7aa6cd149118a6ff3cd62d07c2" alt="55.png enter description here"
data:image/s3,"s3://crabby-images/24adb/24adbb5b7ed9026f578857abe51406dfd6977a16" alt="56.png enter description here"
data:image/s3,"s3://crabby-images/de520/de520b703230d843a66c15b2e086772c27228d86" alt="57.png enter description here"
data:image/s3,"s3://crabby-images/72da3/72da310b948d91437181d329a5588851b49f8e57" alt="58.png enter description here"
将web这个实例增加一个浮动IP,使该IP可以任意分配
1-2、
在Project-Compute-Instances下,点击web右边的Associate Floating IP
/
点击IP Address下的+号,将外网ext的网络172.25.0.29/172.25.0.99这个地址池加入其中
/
在加入后内网会自动分配的一个IP 地址为172.25.0.30
data:image/s3,"s3://crabby-images/7a340/7a340e7a13ed2a24e1c94eb217885bce56bba8c3" alt="59.png enter description here"
data:image/s3,"s3://crabby-images/d50a2/d50a24e30c6a7b7685d3072ba11a4d98d9463238" alt="60.png enter description here"
创建一个storage存储卷
1-2、
在Project-Compute-Volumes-Volumes下,点击Cerate Volume
Volume Name:storage
Size:2 卷的大小2G
data:image/s3,"s3://crabby-images/fb78e/fb78ee2213c4e7cca23c4fa1431c268429dfb4aa" alt="61.png enter description here"
data:image/s3,"s3://crabby-images/a7a10/a7a1024419ffafb3de3a5d8e548ab82f7f651b8b" alt="62.png enter description here"
data:image/s3,"s3://crabby-images/06570/06570839acd370b693ccc4f70229fd7fcbf66a62" alt="63.png enter description here"
创建storage的快照storage-anap,并将storage加入到web实例中
1、
在Project-Compute-Volumes-Volumes下,点击Create Snapshot添加一个快照
Snapshot Name:storage-anap
data:image/s3,"s3://crabby-images/8f572/8f572af1cde7b4bff82b11300d1527880e1df788" alt="64.png enter description here"
data:image/s3,"s3://crabby-images/838d1/838d1630d942636d4384fc05c52dda9bcb6355ba" alt="65.png enter description here"
data:image/s3,"s3://crabby-images/8b276/8b276cc3badf52f3deac9e2ecf45c2c507421268" alt="66.png enter description here"
1、
点击Edit Attachments编辑storage
Attach to Instance:web
data:image/s3,"s3://crabby-images/73df5/73df5a725c3d39ea061f5c67cb4fa2ba8b60b817" alt="67.png enter description here"
data:image/s3,"s3://crabby-images/c486e/c486e338e1e76fb3e07e9eb360f68e68d4ebadd0" alt="68.png enter description here"
创建一个Swift容器,该容器能被adm1管理,将本地/etc下的所有文件压缩,压缩后的文件要与源文件名一样
1-2、
~cd /root/
~tar zcvf etc.tgz /etc/ 将/etc/的文件打包成.tgz
~cp keystonerc_admin keystonerc.adm1 将新的keystonerc_admin修改成keystonerc_adm1
~cat keystonerc_adm1 将文件keystonerc_adm1修改如下
export OS_USERNAME=adm1
export OS_TENANT_NAME=project1
export OS_PASSWORD=redhat
export OS_AUTH_URL=http://172.25.0.10:5000/v2.0/
export OS_REGION_NAME=RegionOne
export PS1=\'[\u@\h \W(keystone_adm1)]$\'
~source keystonerc_adm1
~swift post swift-container
~swift upload swfit-container etc.tgz
1、
data:image/s3,"s3://crabby-images/a1ed3/a1ed37475486876969daa1aa25436472977768bc" alt=""