summaryrefslogtreecommitdiffstats
path: root/nova/api
diff options
context:
space:
mode:
authorMark McLoughlin <markmc@redhat.com>2011-09-05 07:10:52 +0100
committerMark McLoughlin <markmc@redhat.com>2011-10-13 08:46:23 +0100
commitd503dd6de4f45f149dfa295fd3137f4944ed7f66 (patch)
treecd929ab692b44c1e30f436fe1f9af0a049749a0c /nova/api
parent8010ab4e31a1487375d4d01b18a0f56434fba15d (diff)
downloadnova-d503dd6de4f45f149dfa295fd3137f4944ed7f66.tar.gz
nova-d503dd6de4f45f149dfa295fd3137f4944ed7f66.tar.xz
nova-d503dd6de4f45f149dfa295fd3137f4944ed7f66.zip
Add INPUT chain rule for EC2 metadata requests (lp:856385)
On Fedora, the default policy for the INPUT chain in the filter table is DROP. This means that EC2 metadata requests from guests get dropped. Add this rule to let it through: $> sudo iptables -t filter -A nova-network-INPUT \ -s 0.0.0.0/0 -d $ec2_dmz_host \ -m tcp -p tcp --dport $ec2_port -j ACCEPT It makes no sense to have nova-network add an iptables rule for the EC2 metadata service, since they may not actually be on the same host. Instead, nova-api should add it directly. In order to do that, we add a manager class for API services and allow the EC2 manager use the network driver to add the rule. Change-Id: I7c1f973c662a6d290e555b6a2ce8fc301f27b543
Diffstat (limited to 'nova/api')
-rw-r--r--nova/api/manager.py42
1 files changed, 42 insertions, 0 deletions
diff --git a/nova/api/manager.py b/nova/api/manager.py
new file mode 100644
index 000000000..b3fcf9352
--- /dev/null
+++ b/nova/api/manager.py
@@ -0,0 +1,42 @@
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+# Copyright 2010 United States Government as represented by the
+# Administrator of the National Aeronautics and Space Administration.
+# All Rights Reserved.
+#
+# 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.
+
+from nova import flags
+from nova import manager
+from nova import utils
+
+FLAGS = flags.FLAGS
+
+
+class EC2Manager(manager.Manager):
+ """EC2 API manager.
+
+ This class manages the EC2 API service initialization. Currently, it
+ just adds an iptables filter rule for the metadata service.
+ """
+ def __init__(self, *args, **kwargs):
+ super(EC2Manager, self).__init__(*args, **kwargs)
+ self.network_driver = utils.import_object(FLAGS.network_driver)
+
+ def init_host(self):
+ """Perform any initialization.
+
+ Currently, we only add an iptables filter rule for the metadta
+ service.
+ """
+ self.network_driver.metadata_accept()