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

[经验分享] eclipse + pydev远程调试OpenStack

[复制链接]
累计签到:2 天
连续签到:1 天
发表于 2016-3-21 09:10:59 | 显示全部楼层 |阅读模式
一、安装eclipse、PyDev插件

官方eclipse下载地址:https://www.eclipse.org/downloads/
这里不详细描述了,先装java运行环境(如果没装,安装eclipse的过程会自动提示要先装jre),再装eclipse就对了。

安装PyDev插件:打开eclipse --> Help --> Install New Software;详情参考这(http://www.pydev.org/manual_101_install.html
wKioL1buWELgJBzEAAFe7b24DYM749.jpg

二、配置Pydev debug

wKioL1buW0eiDklEAACzsGCMUg8427.jpg
wKiom1buW3jjvFffAAEqRJYrOD8592.jpg

wKiom1buXW6DJpDPAACiXMuiE4g651.jpg

wKioL1buXqGyudGiAADPl1oqaaE128.jpg
wKiom1buXg6T5ns_AABou3P4s0w638.jpg

wKioL1buXvCAuZeUAAEk_nPG8_g006.jpg

配置debug server信息
wKiom1buYL7CFf3qAAGn-OYR-VQ680.jpg

三、远程调试OpenStack Nova api(nova stop instance的api调用)

1、确保远程运行nova api服务器有pydevd.py,可以从本地安装eclipse的pydev插件目录下找到(不同环境下目录可能有所不同)
然后拷贝到运行nova api服务器的python路径下
1
2
ices-MacBook-Air:~ iceyao$ ls -l  /Users/iceyao/.p2/pool/plugins/org.python.pydev_4.5.4.201601292234/pysrc/pydevd.py
-rw-r--r--  1 iceyao  staff  60901 Jan 29 20:32 /Users/iceyao/.p2/pool/plugins/org.python.pydev_4.5.4.201601292234/pysrc/pydevd.py




2、其次要保证本地eclipse端也有一份相同代码,如果在不同目录,可以使用修改pydevd_file_utils.py文件来实现;如果代码目录相同,下面这步就跳过
1
2
3
4
5
6
7
8
9
# 不同环境下文件位置可能有所不同
ices-MacBook-Air:~ iceyao$ ls -l  /Users/iceyao/.p2/pool/plugins/org.python.pydev_4.5.4.201601292234/pysrc/pydevd_file_utils.py
-rw-r--r--  1 iceyao  staff  14343 Mar 20 14:50 /Users/iceyao/.p2/pool/plugins/org.python.pydev_4.5.4.201601292234/pysrc/pydevd_file_utils.py

ices-MacBook-Air:~ iceyao$ vim /Users/iceyao/.p2/pool/plugins/org.python.pydev_4.5.4.201601292234/pysrc/pydevd_file_utils.py # 找到PATHS_FROM_ECLIPSE_TO_PYTHON
PATHS_FROM_ECLIPSE_TO_PYTHON = [
  (r'/opt/stack/a/nova',     # 本地路径
   r'/opt/stack/nova')       # 远端python process路径
]




导入本地/opt/stack/a/nova项目
File --> Import --> General --> Existing Projects into Workspace

wKioL1buZ3vD4PYRAADKu5hDBuk793.jpg

wKiom1buZ6jARGwrAAEMugTE53c702.jpg

3、远程运行nova api服务器设置断点
本地eclipse机器开启debug监听
wKiom1buatuD4BvEAACrAVOiwwo636.jpg

wKiom1buaxLhUuj-AAEi3AG6HR4691.jpg

登入远程的devstack环境,进入screen,加上--remote_debug-host 172.16.1.10 --remote_debug-port 12306,重新启动服务

172.16.1.10:本地安装eclipse的机器ip
1
stack@yxb-devstack:/opt/devstack$ /usr/local/bin/nova-api  --remote_debug-host 172.16.1.10 --remote_debug-port 12306 & echo $! >/opt/stack/status/stack/n-api.pid; fg || echo "n-api failed to start" | tee "/opt/stack/status/stack/n-api.failure"




1
2
3
4
5
6
7
8
stack@yxb-devstack:~/nova$ cat nova/cmd/__init__.py   # 上述参数的意义
import eventlet
from nova import debugger
if debugger.enabled():
    # turn off thread patching to enable the remote debugger
    eventlet.monkey_patch(os=False, thread=False) # 加上上述debug参数后,自动eventlet关闭多线程,不然会出现无法捕获到断电调试的代码
else:
    eventlet.monkey_patch(os=False)




设置断点
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
stack@yxb-devstack:~/nova$ vim nova/compute/api.py   
   @check_instance_lock
    @check_instance_host
    @check_instance_cell
    @check_instance_state(vm_state=[vm_states.ACTIVE, vm_states.ERROR])
    def stop(self, context, instance, do_cast=True, clean_shutdown=True):
        """Stop an instance."""
        import pydevd;pydevd.settrace(host='172.16.1.10', port=12306, stdoutToServer=True, stderrToServer=True,suspend=True) # 断点处
        self.force_stop(context, instance, do_cast, clean_shutdown)

stack@yxb-devstack:~/nova$ nova list
+--------------------------------------+------+--------+------------+-------------+--------------------------------+
| ID                                   | Name | Status | Task State | Power State | Networks                       |
+--------------------------------------+------+--------+------------+-------------+--------------------------------+
| c04f9a2f-36b3-4104-8c75-5461491aca97 | test | ACTIVE | -          | Running     | public=2001:db8::3, 172.24.4.3 |
+--------------------------------------+------+--------+------------+-------------+--------------------------------+
stack@yxb-devstack:~/nova$
stack@yxb-devstack:~/nova$ nova stop c04f9a2f-36b3-4104-8c75-5461491aca97   # nova客户端发起请求




本地eclipse机器捕获到,接下来就可以进行调试了
wKioL1bubU-y82CqAANMOpWVTz8148.jpg


运维网声明 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-193570-1-1.html 上篇帖子: OpenStack 系列之Manila install and using the Virtualenv 下篇帖子: openstack resize 中遇到的问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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