设为首页 收藏本站
查看: 1096|回复: 0

[经验分享] 【N版】openstack——计算服务nova(五)

[复制链接]

尚未签到

发表于 2018-5-31 10:52:30 | 显示全部楼层 |阅读模式
【N版】openstack——计算服务nova(五)

一.openstack之nova计算服务
1.1nova介绍
Nova是openstack最早的两块模块之一,另一个是对象存储swift。在openstack体系中一个叫做计算节点,一个叫做控制节点。这个主要和nova相关,我们把安装为计算节点nova-compute,把除了nova-compute叫做控制节点。nova-compute是创建虚拟机的,只是创建虚拟机,所有的控制都在另一台上。
Nova组件介绍

  •   API:实现了RESTful API功能,是外部访问Nova的唯一途径。
接收外部的请求并通过Message Queue将请求发送给其他的服务组件,同时也兼容EC2 API,所以也可以用EC2的管理工具对nova进行日常管理。

  •   Scheduler:模块在OpenStack中负责决策虚拟机创建在那台主机(计算节点)上。
决策一个虚拟机应该调度到某物理节点,需要分两个步骤:

  •   过滤(Fliter) 首先获取过未过滤的主机列表,根据过滤属性,选择服务条件的计算节点主机。
  •   计算权值(Weight) 经过主机过滤,需要对主机进行权值的计算,根据策略选择相应的某一台主机。
  •    Cert:负责身份认证
  •    Conductor:计算节点访问数据库的中间件
  •    Consoleauth:用于控制台的授权验证
  •    Novncproxy:VNC代理
    1.2安装配置Nova控制节点
    1.2.1修改配置文件
[root@linux-node1 ~]# vim /etc/nova/nova.conf
打开3052 enabled_apis=osapi_compute,metadata注释        <- 只启用计算和元数据API ->
3649 [api_database]
3661 connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api   <- 数据库 ->
4651 [database]
4678connection=mysql+pymysql://nova:nova@192.168.56.11/nova     <- 数据库 ->
default下 transport_url=rabbit://openstack:openstack@192.168.56.11  <- 消息队列 ->
打开14 auth_strategy=keystone注释                  <- 连接keystone ->
5429 [keystone_authtoken]下面添加
5430 auth_uri = http://192.168.56.11:5000
5431 auth_url = http://192.168.56.11:35357
5432 memcached_servers = 192.168.56.11:11211
5433 auth_type = password
5434 project_domain_name = default
5435 user_domain_name = default
5436 project_name = service
5437 username = nova
5438 password = nova
2062 use_neutron=true            <- 启用网络服务支持 ->
3265 firewall_driver =nova.virt.firewall.NoopFirewallDriver
8384 vncserver_listen=0.0.0.0        <- 配置VNC代理使用控制节点的管理接口IP地址 ->
8396 vncserver_proxyclient_address=192.168.56.11
4813 api_servers=http://192.168.56.11:9292  <- 配置镜像服务 API 的位置 ->
打开6705 lock_path=/var/lib/nova/tmp注释    <- 配置锁路径 ->
1.2.2检查配置文件
[root@linux-node1 ~]# grep '^[a-z]' /etc/nova/nova.conf
auth_strategy=keystone
use_neutron=True
enabled_apis=osapi_compute,metadata
firewall_driver = nova.virt.firewall.NoopFirewallDriver
connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api
connection=mysql+pymysql://nova:nova@192.168.56.11/nova
api_servers=http://192.168.56.11:9292
auth_uri = http://192.168.56.11:5000
auth_url = http://192.168.56.11:35357
memcached_servers = 192.168.56.11:11211
auth_type = password
project_domain_name = default
user_domain_name = default
project_name = service
username = nova
password = nova
lock_path=/var/lib/nova/tmp
transport_url=rabbit://openstack:openstack@192.168.56.11
vncserver_listen=0.0.0.0
vncserver_proxyclient_address=192.168.56.11
1.2.3同步数据库
[root@linux-node1 ~]# su -s /bin/sh -c "nova-manageapi_db sync" nova
[root@linux-node1 ~]# su -s /bin/sh -c "nova-managedb sync" nova
1.2.4检查数据库
[root@linux-node1 ~]# mysql -h192.168.56.11 -unova-pnova -e "use nova;show tables;"    <- 如果表存在证明同步成功 ->
1.2.5启动Nova
[root@linux-node1 ~]# systemctl enableopenstack-nova-api.service \
openstack-nova-consoleauth.serviceopenstack-nova-scheduler.service \
openstack-nova-conductor.service openstack-nova-novncproxy.service
[root@linux-node1 ~]# systemctl startopenstack-nova-api.service \
openstack-nova-consoleauth.serviceopenstack-nova-scheduler.service \
openstack-nova-conductor.serviceopenstack-nova-novncproxy.service
1.2.6项目及端点配置
[root@linux-node1 ~]# openstack service create --namenova \
--description "OpenStack Compute" compute              <- 创建nova服务实体 ->
[root@linux-node1 ~]# openstack endpoint create --regionRegionOne \
compute public http://192.168.56.11:8774/v2.1/%\(tenant_id\)s
DSC0000.png
[root@linux-node1 ~]# openstack endpoint create --regionRegionOne \
compute internal http://192.168.56.11:8774/v2.1/%\(tenant_id\)s
DSC0001.png
[root@linux-node1 ~]# openstack endpoint create --regionRegionOne \
compute admin http://192.168.56.11:8774/v2.1/%\(tenant_id\)s
DSC0002.png
<-配置API端点 ->
1.2.7验证Nova
[root@linux-node1 ~]# openstack host list
DSC0003.png
1.3安装配置Nova计算节点
1.3.1修改配置文件
[root@linux-node1 ~]# scp /etc/nova/nova.conf192.168.56.12:/tmp/              <- 将控制节点配置文件发送到计算节点->
[root@linux-node2 ~]# cp /tmp/nova.conf /etc/nova/     <- 替换计算节点配置文件 ->
[root@linux-node2 ~]# vim /etc/nova/nova.conf        <- 编辑配置文件 ->
3661connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api
4678connection=mysql+pymysql://nova:nova@192.168.56.11/nova
<-删除以上两条连接数据库的配置,上文讲过计算节点连接数据库通过conductor->
8394 vncserver_proxyclient_address=192.168.56.12      <- 改为计算节点IP ->
8413 novncproxy_base_url=http://192.168.56.11:6080/vnc_auto.html
8359 enabled=true                 <- 打开注释,允许VNC ->
8375 keymap=en-us                 <- 打开注释,允许键盘 ->
5672 virt_type=kvm                 <- 打开注释,CPU支持虚拟化 ->
注:这一步首先要确定计算节点CPU是否支持虚拟化、支持硬件加速
egrep -c '(vmx|svm)' /proc/cpuinfo 执行此命令来查看,如果返回值为1,或者大于1则不需要修改,如果返回值为0则必须配置libvirt 来使用 QEMU 去代替 KVM
3601transport_url=rabbit://openstack:openstack@192.168.56.11
1.3.2对比配置文件
[root@linux-node2 ~]# diff /tmp/nova.conf/etc/nova/nova.conf
3661d3660
< connection=mysql+pymysql://nova:nova@192.168.56.11/nova_api
4678d4676
<connection=mysql+pymysql://nova:nova@192.168.56.11/nova
5674c5672
< #virt_type=kvm
---
> virt_type=kvm
6469a6468,6477
> url = http://192.168.56.11:9696
> auth_url = http://192.168.56.11:35357
> auth_type = password
> project_domain_name = default
> user_domain_name = default
> region_name = RegionOne
> project_name = service
> username = neutron
> password = neutron
>
8361c8369
< #enabled=true
---
> enabled=true
8377c8385
< #keymap=en-us
---
> keymap=en-us
8396c8404
< vncserver_proxyclient_address=192.168.56.11
---
> vncserver_proxyclient_address=192.168.56.12
8415c8423
<#novncproxy_base_url=http://127.0.0.1:6080/vnc_auto.html
---
>novncproxy_base_url=http://192.168.56.11:6080/vnc_auto.html
1.3.3启动服务
[root@linux-node2~]# systemctl enable libvirtd.service openstack-nova-compute.service
[root@linux-node2~]# systemctl start libvirtd.service openstack-nova-compute.service
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-483385-1-1.html 上篇帖子: 【N版】openstack——镜像服务glance(四) 下篇帖子: 【N版】openstack——网络服务neutron(六)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表