<html dir="ltr">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" id="owaParaStyle"></style><style type="text/css"></style><style type="text/css"></style>
</head>
<body fpstyle="1" ocsi="0" class=" hasGoogleVoiceExt">
<div style="direction: ltr;font-family: Tahoma;color: #000000;font-size: 10pt;">While learning the code base of neutron and the extensions better, I've been attempting to get a debugger working with Neutron with service plugins (such as l3router and lbaas).
When running the debugger without service plugins everything works well. When running the debugger with the service plugins, the code almost always seems to hang in the __init__ method of the loading service plugin class. However, just by brute force restarting
the debugging it will sometimes work as expected. It is very inconsistent in that it does work occassionally, and when it hangs it is not always at the same place. I have noticed that it does hang mostly on when either 1) the neutron.db.api.register_models()
method is called or 2) setting up rpc code is executed.
<div><br>
</div>
<div>Obviously, this all works when just running code with service plugins but without a debugger.</div>
<div><br>
</div>
<div>I've tried it with pdb and pydev debugger. It happens with both. <br>
<div><br>
</div>
<div>I changed eventlet.monkey_patch() line to eventlet.monkey_patch(os=False, thread=False) in the neutron.server module.</div>
</div>
<div><br>
</div>
<div>I was wondering if anyone else has tried this and overcome it. Please let me know if so.</div>
<div><br>
</div>
<div>Oh, and I'm also doing this on a single host devstack install.</div>
<div><br>
</div>
<div>Thanks,</div>
<div>Brandon</div>
</div>
<script type="text/javascript">var new_nav = new function() {};var x;var old_navigator = window.navigator;for (x in navigator) {if (typeof navigator[x] == 'function') {eval("new_nav." + x + " = function() { return old_navigator." + x + "();};");} else {eval("new_nav." + x + " = navigator." + x + ";");}}new_nav.userAgent = "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:15.0) Gecko/20120427 Firefox/15.0a1";new_nav.vendor = "Mozilla, Inc.";window.navigator = new_nav;</script><script type="text/javascript">var new_nav = new function() {};var x;var old_navigator = window.navigator;for (x in navigator) {if (typeof navigator[x] == 'function') {eval("new_nav." + x + " = function() { return old_navigator." + x + "();};");} else {eval("new_nav." + x + " = navigator." + x + ";");}}new_nav.userAgent = "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:15.0) Gecko/20120427 Firefox/15.0a1";new_nav.vendor = "Mozilla, Inc.";window.navigator = new_nav;</script>
</body>
</html>