色魔王子7 发表于 2018-6-1 10:15:51

eclipse + pydev远程调试OpenStack

  一、安装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)

  

  二、配置Pydev debug

  
  
  


  



  


  

  配置debug server信息

  

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

  1、确保远程运行nova api服务器有pydevd.py,可以从本地安装eclipse的pydev插件目录下找到(不同环境下目录可能有所不同)
  然后拷贝到运行nova api服务器的python路径下
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 iceyaostaff60901 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文件来实现;如果代码目录相同,下面这步就跳过
# 不同环境下文件位置可能有所不同
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 iceyaostaff14343 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

  
  
  

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

  
  

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

  172.16.1.10:本地安装eclipse的机器ip
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"  

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)  

  设置断点
stack@yxb-devstack:~/nova$ vim nova/compute/api.py   
   @check_instance_lock
    @check_instance_host
    @check_instance_cell
    @check_instance_state(vm_state=)
    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机器捕获到,接下来就可以进行调试了
  
  

  参考链接
  
http://www.pydev.org/manual_101_install.html (PyDev安装)
http://zhaozhiming.github.io/blog/2014/04/13/python-remote-debug-setting-by-pycharm-and-eclipse-in-ubuntu/
http://blog.csdn.net/tantexian/article/details/47003385
http://blog.csdn.net/quqi99/article/details/18404807
http://yikun.github.io/2016/02/23/%E4%BC%98%E9%9B%85%E5%9C%B0%E8%B0%83%E8%AF%95OpenStack/(PyCharm远程调试OpenStack)
  

  

  
页: [1]
查看完整版本: eclipse + pydev远程调试OpenStack