408 lines
12 KiB
Ruby
408 lines
12 KiB
Ruby
#
|
|
# Cookbook Name:: openstack-network
|
|
# Recipe:: common
|
|
#
|
|
# Copyright 2013, AT&T
|
|
# Copyright 2013, SUSE Linux GmbH
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
require "uri"
|
|
|
|
class ::Chef::Recipe
|
|
include ::Openstack
|
|
end
|
|
|
|
platform_options = node["openstack"]["network"]["platform"]
|
|
|
|
driver_name = node["openstack"]["network"]["interface_driver"].split('.').last.downcase
|
|
main_plugin = node["openstack"]["network"]["interface_driver_map"][driver_name]
|
|
core_plugin = node["openstack"]["network"]["core_plugin"]
|
|
|
|
if node["openstack"]["network"]["syslog"]["use"]
|
|
include_recipe "openstack-common::logging"
|
|
end
|
|
|
|
platform_options["nova_network_packages"].each do |pkg|
|
|
package pkg do
|
|
action :purge
|
|
end
|
|
end
|
|
|
|
platform_options["quantum_packages"].each do |pkg|
|
|
package pkg do
|
|
action :install
|
|
end
|
|
end
|
|
|
|
directory "/etc/quantum/plugins" do
|
|
recursive true
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00700
|
|
action :create
|
|
end
|
|
|
|
directory "/var/cache/quantum" do
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00700
|
|
action :create
|
|
end
|
|
|
|
directory ::File.dirname node["openstack"]["network"]["api"]["auth"]["cache_dir"] do
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00700
|
|
|
|
only_if { node["openstack"]["auth"]["strategy"] == "pki" }
|
|
end
|
|
|
|
# This will copy recursively all the files in
|
|
# /files/default/etc/quantum/rootwrap.d
|
|
remote_directory "/etc/quantum/rootwrap.d" do
|
|
source "etc/quantum/rootwrap.d"
|
|
files_owner node["openstack"]["network"]["platform"]["user"]
|
|
files_group node["openstack"]["network"]["platform"]["group"]
|
|
files_mode 00700
|
|
end
|
|
|
|
template "/etc/quantum/rootwrap.conf" do
|
|
source "rootwrap.conf.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
end
|
|
|
|
template "/etc/quantum/policy.json" do
|
|
source "policy.json.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
# Added by Sam, CentOS think Qpid as it's default queue, it will auto add qpid
|
|
# configuration at /etc/quantum/quantum.conf when invoke /usr/bin/quantum-xxx-setup,
|
|
# because these scripts was hard coded a line as below:
|
|
# "openstack-config --set ${Q_CONF} DEFAULT
|
|
# rpc_backend quantum.openstack.common.rpc.impl_qpid"
|
|
# It should be a bug of redhat OS
|
|
execute "delete_auto_qpid" do
|
|
command %Q|sed -i "s/^rpc_backend = quantum.openstack.common.rpc.impl_qpid//g" /etc/quantum/quantum.conf|
|
|
only_if {
|
|
(node['openstack']['mq']['service_type'] == "rabbitmq") and
|
|
platform?(%w{fedora centos redhat})
|
|
}
|
|
action :nothing
|
|
end
|
|
|
|
rabbit_server_role = node["openstack"]["network"]["rabbit_server_chef_role"]
|
|
if node["openstack"]["network"]["rabbit"]["ha"]
|
|
rabbit_hosts = rabbit_servers
|
|
end
|
|
rabbit_pass = user_password node['openstack']['mq']['password']
|
|
|
|
identity_endpoint = endpoint "identity-api"
|
|
auth_uri = ::URI.decode identity_endpoint.to_s
|
|
|
|
db_user = node['openstack']['db']['network']['username']
|
|
db_pass = db_password node['openstack']['db']['network']['password']
|
|
sql_connection = db_uri("network", db_user, db_pass)
|
|
|
|
api_endpoint = endpoint "network-api"
|
|
service_pass = service_password node['openstack']['identity']['network']['password']
|
|
service_tenant_name = node['openstack']['identity']['network']['tenant']
|
|
service_user = node['openstack']['identity']['network']['username']
|
|
|
|
if node["openstack"]["network"]["api"]["bind_interface"].nil?
|
|
bind_address = api_endpoint.host
|
|
bind_port = api_endpoint.port
|
|
else
|
|
bind_address = address_for node["openstack"]["network"]["api"]["bind_interface"]
|
|
#bind_address = node['openstack']['endpoints']['network-api']['host']
|
|
bind_port = node["openstack"]["network"]["api"]["bind_port"]
|
|
end
|
|
|
|
# retrieve the local interface for tunnels
|
|
if node["openstack"]["network"]["openvswitch"]["local_ip_interface"].nil?
|
|
local_ip = localhost
|
|
else
|
|
local_ip = node["openstack"]["network"]["openvswitch"]["local_ip"]
|
|
end
|
|
|
|
platform_options["quantum_client_packages"].each do |pkg|
|
|
package pkg do
|
|
action :upgrade
|
|
options platform_options["package_overrides"]
|
|
end
|
|
end
|
|
|
|
# all recipes include common.rb, and some servers
|
|
# may just be running a subset of agents (like l3_agent)
|
|
# and not the api server components, so we ignore restart
|
|
# failures here as there may be no quantum-server process
|
|
service "quantum-server" do
|
|
service_name platform_options["quantum_server_service"]
|
|
supports :status => true, :restart => true
|
|
ignore_failure true
|
|
|
|
action :nothing
|
|
end
|
|
|
|
template "/etc/quantum/quantum.conf" do
|
|
source "quantum.conf.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:bind_address => bind_address,
|
|
:bind_port => bind_port,
|
|
:rabbit_hosts => rabbit_hosts,
|
|
:rabbit_pass => rabbit_pass,
|
|
:core_plugin => core_plugin,
|
|
:identity_endpoint => identity_endpoint,
|
|
:service_tenant_name => service_tenant_name,
|
|
:service_user => service_user,
|
|
:service_pass => service_pass
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
|
|
template "/etc/quantum/api-paste.ini" do
|
|
source "api-paste.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
"identity_endpoint" => identity_endpoint,
|
|
"service_tenant_name" => service_tenant_name,
|
|
"service_user" => service_user,
|
|
"service_pass" => service_pass
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
directory "/etc/quantum/plugins/#{main_plugin}" do
|
|
recursive true
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00700
|
|
end
|
|
|
|
# For several plugins, the plugin configuration
|
|
# is required by both the quantum-server and
|
|
# ancillary services that may be on different
|
|
# physical servers like the l3 agent, so we assume
|
|
# the plugin configuration is a "common" file
|
|
|
|
template_file = nil
|
|
|
|
case main_plugin
|
|
when "bigswitch"
|
|
|
|
template_file = "/etc/quantum/plugins/bigswitch/restproxy.ini"
|
|
template "/etc/quantum/plugins/bigswitch/restproxy.ini" do
|
|
source "plugins/bigswitch/restproxy.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "brocade"
|
|
|
|
template_file = "/etc/quantum/plugins/brocade/brocade.ini"
|
|
template "/etc/quantum/plugins/brocade/brocade.ini" do
|
|
source "plugins/brocade/brocade.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "cisco"
|
|
|
|
template_file = "/etc/quantum/plugins/cisco/cisco_plugins.ini"
|
|
template "/etc/quantum/plugins/cisco/cisco_plugins.ini" do
|
|
source "plugins/cisco/cisco_plugins.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "hyperv"
|
|
|
|
template_file = "/etc/quantum/plugins/hyperv/hyperv_quantum_plugin.ini.erb"
|
|
template "/etc/quantum/plugins/hyperv/hyperv_quantum_plugin.ini.erb" do
|
|
source "plugins/hyperv/hyperv_quantum_plugin.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "linuxbridge"
|
|
|
|
template_file = "/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini"
|
|
template "/etc/quantum/plugins/linuxbridge/linuxbridge_conf.ini" do
|
|
source "plugins/linuxbridge/linuxbridge_conf.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "midonet"
|
|
|
|
template_file = "/etc/quantum/plugins/metaplugin/metaplugin.ini"
|
|
template "/etc/quantum/plugins/metaplugin/metaplugin.ini" do
|
|
source "plugins/metaplugin/metaplugin.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "nec"
|
|
|
|
template_file = "/etc/quantum/plugins/nec/nec.ini"
|
|
template "/etc/quantum/plugins/nec/nec.ini" do
|
|
source "plugins/nec/nec.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "nicira"
|
|
|
|
template_file = "/etc/quantum/plugins/nicira/nvp.ini"
|
|
template "/etc/quantum/plugins/nicira/nvp.ini" do
|
|
source "plugins/nicira/nvp.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "openvswitch"
|
|
|
|
template_file = "/etc/quantum/plugins/openvswitch/ovs_quantum_plugin.ini"
|
|
|
|
service "quantum-plugin-openvswitch-agent" do
|
|
service_name platform_options["quantum_openvswitch_agent_service"]
|
|
action :nothing
|
|
end
|
|
|
|
template "/etc/quantum/plugins/openvswitch/ovs_quantum_plugin.ini" do
|
|
source "plugins/openvswitch/ovs_quantum_plugin.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection,
|
|
:local_ip => local_ip
|
|
)
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
if node.run_list.expand(node.chef_environment).recipes.include?("openstack-network::openvswitch")
|
|
notifies :restart, "service[quantum-plugin-openvswitch-agent]", :delayed
|
|
end
|
|
end
|
|
|
|
|
|
when "plumgrid"
|
|
|
|
template_file = "/etc/quantum/plugins/plumgrid/plumgrid.ini"
|
|
template "/etc/quantum/plugins/plumgrid/plumgrid.ini" do
|
|
source "plugins/plumgrid/plumgrid.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
when "ryu"
|
|
|
|
template_file = "/etc/quantum/plugins/ryu/ryu.ini"
|
|
template "/etc/quantum/plugins/ryu/ryu.ini" do
|
|
source "plugins/ryu/ryu.ini.erb"
|
|
owner node["openstack"]["network"]["platform"]["user"]
|
|
group node["openstack"]["network"]["platform"]["group"]
|
|
mode 00644
|
|
variables(
|
|
:sql_connection => sql_connection
|
|
)
|
|
|
|
notifies :restart, "service[quantum-server]", :delayed
|
|
end
|
|
|
|
end
|
|
|
|
|
|
template "/etc/default/quantum-server" do
|
|
source "quantum-server.erb"
|
|
owner "root"
|
|
group "root"
|
|
mode 00644
|
|
variables(
|
|
:plugin_config => template_file
|
|
)
|
|
only_if {
|
|
node.run_list.expand(node.chef_environment).recipes.include?("openstack-network::server")
|
|
platform?(%w{ubuntu debian})
|
|
}
|
|
end
|