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

[经验分享] Openstack Nova 二次开发之Nova

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2018-6-2 08:36:42 | 显示全部楼层 |阅读模式
主要是讲如何启动openstack nova-extend services,该服务用于Openstack 二次扩展及部分需求开发,例如 ,节点巡检,动态迁移(基于FUSE 文件系统实现,分布式系统,如MooseFS),文件注入,Nova 服务的自身修复,instances IO 控制,instances CPU 隔离技术实现等其他需求开发


第一章:如何create openstack nova-extend service

   a) 创建python-extend 文件
        cp -fr /usr/bin/python /usr/bin/python-extend
        用于启动openstack nova-extend 服务,Python 服务启动nova-extend ,socket 模块不能正常果子,具体原因在于协程分装,无法使用socket,threading等模块属性

  b)创建启动程序python-extend 文件,保留在/usr/bin/
#!/usr/bin/python-extend
# PBR Generated from 'console_scripts'
import sys
from nova.cmd.extend import main
if __name__ == "__main__":
    sys.exit(main())   c) 创建from  nova.cmd.extend import main 程序,调用nova.services.py
# vim: tabstop=4 shiftwidth=4 softtabstop=4
#    Copyright 2012 IBM Corp.
#
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
#    not use this file except in compliance with the License. You may obtain
#    a copy of the License at
#
#         http://www.apache.org/licenses/LICENSE-2.0
#
#    Unless required by applicable law or agreed to in writing, software
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
#    License for the specific language governing permissions and limitations
#    under the License.
"""Starter script for Nova Extend."""
import sys
from oslo.config import cfg
from nova import config
from nova import objects
from nova.openstack.common import log as logging
from nova import service
from nova import utils
CONF = cfg.CONF
CONF.import_opt('topic', 'nova.extend.api', group='extend')
def main():
    objects.register_all()
    config.parse_args(sys.argv)
    logging.setup("nova")
    utils.monkey_patch()
    server = service.Service.create(binary='nova-extend',
                                    topic=CONF.extend.topic,
                                    manager=CONF.extend.manager)
    service.serve(server, workers=CONF.extend.workers)
    service.wait()   d) /etc/nova.conf 配置
extend_manager=nova.extend.manager.ExtendManager
    e) 创建openstack-nova-extend 启动服务脚步
#!/bin/sh
#
# openstack-nova-extend  OpenStack Nova Compute DB Access service
#
# chkconfig:   - 98 02
# description: Implementation of an S3-like storage server based on local files.
### BEGIN INIT INFO
# Provides:
# Required-Start: $remote_fs $network $syslog
# Required-Stop: $remote_fs $syslog
# Default-Stop: 0 1 6
# Short-Description: OpenStack Nova Compute DB Access service
# Description: Service to handle database access for compute nodes
### END INIT INFO
. /etc/rc.d/init.d/functions
suffix=extend
prog=openstack-nova-$suffix
exec="/usr/bin/nova-$suffix"
config="/etc/nova/nova.conf"
pidfile="/var/run/nova/nova-$suffix.pid"
logfile="/var/log/nova/$suffix.log"
[ -e /etc/sysconfig/$prog ] && . /etc/sysconfig/$prog
lockfile=/var/lock/subsys/$prog
start() {
    [ -x $exec ] || exit 5
    [ -f $config ] || exit 6
    echo -n $"Starting $prog: "
    daemon --user nova --pidfile $pidfile "$exec --logfile $logfile &>/dev/null & echo \$! > $pidfile"
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}
stop() {
    echo -n $"Stopping $prog: "
    killproc -p $pidfile $prog
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}
restart() {
    stop
    start
}
reload() {
    restart
}
force_reload() {
    restart
}
rh_status() {
    status -p $pidfile $prog
}
rh_status_q() {
    rh_status >/dev/null 2>&1
}
case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
        restart
        ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"
        exit 2
esac
exit $?f) 启动openstack-nova-extend服务

[root@athController cmd]# service openstack-nova-extend restart
[root@athController cmd]# tar -xzf /var/log/nova/extend.log
2014-08-04 23:18:58.325 47419 INFO nova.openstack.common.service [-] Caught SIGTERM, exiting
2014-08-04 23:19:00.151 45666 INFO nova.openstack.common.periodic_task [-] Skipping periodic task _periodic_update_dns because its interval is negative
2014-08-04 23:19:00.183 45666 AUDIT nova.service [-] Starting extend node (version 2013.2.1-1.el6)
2014-08-04 23:19:00.513 45666 INFO nova.openstack.common.rpc.common [req-d6b00731-baaa-47fa-bfa2-75f9ec4ef568 None None] Connected to AMQP server on 192.168.8.180:5672g) openstack-nova-extend 消息队列信息
[root@athController cmd]# rabbitmqctl list_queues|grep extend
extend 0
extend.athCloud.8.180.abs.com.cn 0
extend_fanout_6dbb351ab48445cfaadc9de37e87d68f 0
extend_fanout_e870b14296354eddba09389319a9c590 0h) nova-manager service list 查看nova-extend服务状态
[root@athController cmd]# nova-manage service list
Binary           Host                                 Zone             Status     State Updated_At
nova-conductor   athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:20
nova-consoleauth athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:19
nova-cert        athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:20
nova-scheduler   athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:18
nova-network     athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:11
nova-compute     athController.8.180.abs.com.cn  nova             enabled    :-)   2014-08-04 15:22:10
nova-console     athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:17
nova-extend      athController.8.180.abs.com.cn  internal         enabled    :-)   2014-08-04 15:22:10    i) 总结
    openstack开发其实并不是很难,只要了解nova-compute,nova-api启动过程,参照文档基本都能实现
    到此openstack Nova extend 服务启动实现完毕,下一章节将会在下周一撰写openstack nova-extend nova.extend.manager 功能实现,谢谢大家,如有不明白的地方请留言,我会在中午时间一一帮助大家解答,欢迎点评
    写的不好的地方还希望大牛们指点,共同学习

运维网声明 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-505984-1-1.html 上篇帖子: 加速OpenStack云落地——UnitedStack发布UOS 2.0 下篇帖子: OpenStack Rabbit 集群实现
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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