Add router L3 agent info to info page
This change tries to lookup the L3 agent location for a router to assist admins in locating where a router resides. Change-Id: I62bedcc587791df3a101b9d81a03ba2540dfa033 Implements: blueprint admin-neutron-l3-agents
This commit is contained in:
parent
caa5e91059
commit
0ee88956cc
@ -1058,6 +1058,12 @@ def list_dhcp_agent_hosting_networks(request, network, **params):
|
|||||||
return [Agent(a) for a in agents['agents']]
|
return [Agent(a) for a in agents['agents']]
|
||||||
|
|
||||||
|
|
||||||
|
def list_l3_agent_hosting_router(request, router, **params):
|
||||||
|
agents = neutronclient(request).list_l3_agent_hosting_routers(router,
|
||||||
|
**params)
|
||||||
|
return [Agent(a) for a in agents['agents']]
|
||||||
|
|
||||||
|
|
||||||
def add_network_to_dhcp_agent(request, dhcp_agent, network_id):
|
def add_network_to_dhcp_agent(request, dhcp_agent, network_id):
|
||||||
body = {'network_id': network_id}
|
body = {'network_id': network_id}
|
||||||
return neutronclient(request).add_network_to_dhcp_agent(dhcp_agent, body)
|
return neutronclient(request).add_network_to_dhcp_agent(dhcp_agent, body)
|
||||||
|
@ -28,6 +28,11 @@ class RouterTests(test.BaseAdminViewTests, r_test.RouterTests):
|
|||||||
INDEX_URL = reverse('horizon:%s:routers:index' % DASHBOARD)
|
INDEX_URL = reverse('horizon:%s:routers:index' % DASHBOARD)
|
||||||
DETAIL_PATH = 'horizon:%s:routers:detail' % DASHBOARD
|
DETAIL_PATH = 'horizon:%s:routers:detail' % DASHBOARD
|
||||||
|
|
||||||
|
def _get_detail(self, router, extraroute=True):
|
||||||
|
res = super(RouterTests, self)._get_detail(router, extraroute,
|
||||||
|
lookup_l3=True)
|
||||||
|
return res
|
||||||
|
|
||||||
@test.create_stubs({api.neutron: ('router_list', 'network_list'),
|
@test.create_stubs({api.neutron: ('router_list', 'network_list'),
|
||||||
api.keystone: ('tenant_list',)})
|
api.keystone: ('tenant_list',)})
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
|
@ -71,7 +71,17 @@ class DetailView(r_views.DetailView):
|
|||||||
context = super(DetailView, self).get_context_data(**kwargs)
|
context = super(DetailView, self).get_context_data(**kwargs)
|
||||||
table = rtbl.RoutersTable(self.request)
|
table = rtbl.RoutersTable(self.request)
|
||||||
context["url"] = self.failure_url
|
context["url"] = self.failure_url
|
||||||
context["actions"] = table.render_row_actions(context["router"])
|
router = context["router"]
|
||||||
|
# try to lookup the l3 agent location so we know where to troubleshoot
|
||||||
|
try:
|
||||||
|
agents = api.neutron.list_l3_agent_hosting_router(self.request,
|
||||||
|
router.id)
|
||||||
|
router.l3_host_agents = agents
|
||||||
|
except Exception:
|
||||||
|
exceptions.handle(self.request,
|
||||||
|
_('The L3 agent information could not '
|
||||||
|
'be located.'))
|
||||||
|
context["actions"] = table.render_row_actions(router)
|
||||||
return context
|
return context
|
||||||
|
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ from django.utils.translation import ugettext_lazy as _
|
|||||||
|
|
||||||
from horizon import tabs
|
from horizon import tabs
|
||||||
|
|
||||||
|
from openstack_dashboard import api
|
||||||
from openstack_dashboard.dashboards.project.routers.extensions.extraroutes\
|
from openstack_dashboard.dashboards.project.routers.extensions.extraroutes\
|
||||||
import tabs as er_tabs
|
import tabs as er_tabs
|
||||||
from openstack_dashboard.dashboards.project.routers.extensions.routerrules\
|
from openstack_dashboard.dashboards.project.routers.extensions.routerrules\
|
||||||
@ -29,7 +30,10 @@ class OverviewTab(tabs.Tab):
|
|||||||
template_name = "project/routers/_detail_overview.html"
|
template_name = "project/routers/_detail_overview.html"
|
||||||
|
|
||||||
def get_context_data(self, request):
|
def get_context_data(self, request):
|
||||||
return {"router": self.tab_group.kwargs['router']}
|
return {"router": self.tab_group.kwargs['router'],
|
||||||
|
'ha_supported': api.neutron.
|
||||||
|
get_feature_permission(self.request, "l3-ha", "get")
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
class InterfacesTab(tabs.TableTab):
|
class InterfacesTab(tabs.TableTab):
|
||||||
|
@ -20,6 +20,33 @@
|
|||||||
<dt>{% trans "High Availability Mode" %}</dt>
|
<dt>{% trans "High Availability Mode" %}</dt>
|
||||||
<dd>{{ router.ha|yesno|capfirst }}</dd>
|
<dd>{{ router.ha|yesno|capfirst }}</dd>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
{% if router.l3_host_agents %}
|
||||||
|
<dt>{% trans "L3 Agent" %}</dt>
|
||||||
|
<dd>
|
||||||
|
<table class="table table-striped table-hover">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th><strong>{% trans "Host" %}</strong></th>
|
||||||
|
<th><strong>{% trans "ID" %}</strong></th>
|
||||||
|
{% if ha_supported %}
|
||||||
|
<th><strong>{% trans "High Availability Status" %}</strong></th>
|
||||||
|
{% endif %}
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for agent in router.l3_host_agents %}
|
||||||
|
<tr>
|
||||||
|
<td>{{ agent.host }}</td>
|
||||||
|
<td><a href="{% url 'horizon:admin:routers:l3_agent_list' l3_agent_id=agent.id %}">{{ agent.id }}</a></td>
|
||||||
|
{% if ha_supported %}
|
||||||
|
<td>{{ agent.ha_state|default:_("None") }}</td>
|
||||||
|
{% endif %}
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</dd>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
{% if router.external_gateway_info %}
|
{% if router.external_gateway_info %}
|
||||||
</dl>
|
</dl>
|
||||||
|
@ -30,9 +30,10 @@ from openstack_dashboard.usage import quotas
|
|||||||
class RouterMixin(object):
|
class RouterMixin(object):
|
||||||
@test.create_stubs({
|
@test.create_stubs({
|
||||||
api.neutron: ('router_get', 'port_list',
|
api.neutron: ('router_get', 'port_list',
|
||||||
'network_get', 'is_extension_supported'),
|
'network_get', 'is_extension_supported',
|
||||||
|
'list_l3_agent_hosting_router'),
|
||||||
})
|
})
|
||||||
def _get_detail(self, router, extraroute=True):
|
def _get_detail(self, router, extraroute=True, lookup_l3=False):
|
||||||
api.neutron.is_extension_supported(IsA(http.HttpRequest), 'extraroute')\
|
api.neutron.is_extension_supported(IsA(http.HttpRequest), 'extraroute')\
|
||||||
.MultipleTimes().AndReturn(extraroute)
|
.MultipleTimes().AndReturn(extraroute)
|
||||||
api.neutron.router_get(IsA(http.HttpRequest), router.id)\
|
api.neutron.router_get(IsA(http.HttpRequest), router.id)\
|
||||||
@ -41,6 +42,10 @@ class RouterMixin(object):
|
|||||||
device_id=router.id)\
|
device_id=router.id)\
|
||||||
.AndReturn([self.ports.first()])
|
.AndReturn([self.ports.first()])
|
||||||
self._mock_external_network_get(router)
|
self._mock_external_network_get(router)
|
||||||
|
if lookup_l3:
|
||||||
|
agent = self.agents.list()[1]
|
||||||
|
api.neutron.list_l3_agent_hosting_router(IsA(http.HttpRequest), router.id)\
|
||||||
|
.AndReturn([agent])
|
||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
|
|
||||||
res = self.client.get(reverse('horizon:%s'
|
res = self.client.get(reverse('horizon:%s'
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- >
|
||||||
|
[`blueprint admin-neutron-l3-agent <https://blueprints.launchpad.net/horizon/+spec/admin-neutron-l3-agent>`_]
|
||||||
|
Add support for managing neutron L3 agent hosts. The admin screen for system information now provides
|
||||||
|
links / views to see what routers reside on what hosts. In addition, the admin view of routers
|
||||||
|
now also provides a list of where the router is hosted and the link to see what other routers are sharing
|
||||||
|
the same host.
|
Loading…
x
Reference in New Issue
Block a user