PSARC/2014/207 OpenStack Glance Update to Havana
PSARC/2014/208 OpenStack Cinder Update to Havana
PSARC/2014/209 OpenStack Keystone Update to Havana
PSARC/2014/210 OpenStack Nova Update to Havana
18416146 Neutron agents (L3 and DHCP) should cleanup resources when they are disabled
18562372 Failed to create a new project under Horizon
18645763 ZFSSA Cinder Driver support
18686327 evs agent silently ignores user-specified pool allocation ranges
18702697 fibre channel volumes should be supported in the cinder volume driver
18734289 nova won't terminate failed kz deployments
18738371 cinder-volume:setup should account for commented-out zfs_volume_base
18738374 cinder-volume:setup should check for existence of configuration file
18826190 nova-compute fails due to nova.utils.to_bytes
18855698 Update OpenStack to Havana 2013.2.3
18855710 Update python-cinderclient to 1.0.9
18855743 Update python-keystoneclient to 0.8.0
18855754 Update python-neutronclient to 2.3.4
18855764 Update python-novaclient to 2.17.0
18855793 Update python-swiftclient to 2.1.0
18856992 External networks can be deleted even when floating IP addresses are in use
18857784 bake in some more openstack configuration
18884923 Incorrect locale facets in python modules for openstack
18913890 the error in _get_view_and_lun may cause the failure of deleting volumes
18943044 Disable 'Security Groups' tab in Horizon dashboard
18969275 problem in SERVICE/KEYSTONE
#!/usr/bin/python2.6
# Copyright (c) 2013, 2014, Oracle and/or its affiliates. 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.
import errno
import os
import sys
import smf_include
rings = {
"account-reaper": ["account", "container", "object"],
"account-replicator": ["account"],
"container-replicator": ["container"],
"container-sync": ["container", "object"],
"container-updater": ["account"],
"object-expirer": ["object"],
"object-replicator": ["object"],
"object-updater": ["container"],
"proxy-server": ["account", "container", "object"]
}
def start():
# All the Swift services do essentially the same thing, so there's no need
# to have different method executables. Just look at the FMRI and run the
# appropriate executable from /usr/lib/swift.
fmri = os.environ["SMF_FMRI"]
exefile = os.path.basename(fmri.split(":")[1])
exepath = os.path.join("/usr/lib/swift", exefile)
# Try to find a config file that matches the executable name (minus the
# leading "swift-". If that fails, try using the -server config file.
cfgfile = "/etc/swift/%s.conf" % exepath.split("-", 1)[1]
if not os.path.isfile(cfgfile):
cfgfile = "/etc/swift/%s-server.conf" % exepath.split("-")[1]
if not os.path.isfile(cfgfile):
print >> sys.stderr, "Missing configuration file"
smf_include.smf_method_exit(
smf_include.SMF_EXIT_ERR_CONFIG, "missing_config",
"Missing configuration file")
missing_rings = []
for ring in rings.get(exepath.split("-", 1)[1], ()):
ringfile = "/etc/swift/%s.ring.gz" % ring
if not os.path.isfile(ringfile):
missing_rings.append(ringfile)
if missing_rings:
print >> sys.stderr, "Missing ring(s): " + ", ".join(missing_rings)
smf_include.smf_method_exit(
smf_include.SMF_EXIT_ERR_CONFIG, "missing_ring",
"Missing ring(s): " + ", ".join(missing_rings))
# This is the default recon_cache_path (from the config files) as well as
# the default run_dir (from the code).
try:
os.mkdir("/var/run/swift")
except OSError as e:
if e.errno != errno.EEXIST:
raise
smf_include.smf_subprocess("%s %s" % (exepath, cfgfile))
if __name__ == "__main__":
os.putenv("LC_ALL", "C")
smf_include.smf_main()