Revert "Revert "Set default of api_workers to number of CPUs""

This reverts commit 12a564cf03.

We should re-enable this feature on a controlled basis so that we can
flush out any outstanding issue we may have.

Related-bug: #1432189

Change-Id: I2cfd93fdb032b461022b729347390ff8636ccdeb
This commit is contained in:
armando-migliaccio 2015-06-12 08:58:05 -07:00 committed by Armando Migliaccio
parent 87cb6cb0ad
commit ba2c44ef00
3 changed files with 48 additions and 6 deletions

View File

@ -287,10 +287,12 @@
# ========== end of items for VLAN trunking networks ========== # ========== end of items for VLAN trunking networks ==========
# =========== WSGI parameters related to the API server ============== # =========== WSGI parameters related to the API server ==============
# Number of separate worker processes to spawn. The default, 0, runs the # Number of separate worker processes to spawn. A value of 0 runs the
# worker thread in the current process. Greater than 0 launches that number of # worker thread in the current process. Greater than 0 launches that number of
# child processes as workers. The parent process manages them. # child processes as workers. The parent process manages them. If not
# api_workers = 0 # specified, the default value is equal to the number of CPUs available to
# achieve best performance.
# api_workers = <number of CPUs>
# Number of separate RPC worker processes to spawn. The default, 0, runs the # Number of separate RPC worker processes to spawn. The default, 0, runs the
# worker thread in the current process. Greater than 0 launches that number of # worker thread in the current process. Greater than 0 launches that number of

View File

@ -18,6 +18,7 @@ import logging as std_logging
import os import os
import random import random
from oslo_concurrency import processutils
from oslo_config import cfg from oslo_config import cfg
from oslo_log import log as logging from oslo_log import log as logging
from oslo_messaging import server as rpc_server from oslo_messaging import server as rpc_server
@ -40,8 +41,9 @@ service_opts = [
default=40, default=40,
help=_('Seconds between running periodic tasks')), help=_('Seconds between running periodic tasks')),
cfg.IntOpt('api_workers', cfg.IntOpt('api_workers',
default=0, help=_('Number of separate API worker processes for service. '
help=_('Number of separate API worker processes for service')), 'If not specified, the default is equal to the number '
'of CPUs available for best performance.')),
cfg.IntOpt('rpc_workers', cfg.IntOpt('rpc_workers',
default=0, default=0,
help=_('Number of RPC worker processes for service')), help=_('Number of RPC worker processes for service')),
@ -168,6 +170,13 @@ def serve_rpc():
'details.')) 'details.'))
def _get_api_workers():
workers = cfg.CONF.api_workers
if workers is None:
workers = processutils.get_worker_count()
return workers
def _run_wsgi(app_name): def _run_wsgi(app_name):
app = config.load_paste_app(app_name) app = config.load_paste_app(app_name)
if not app: if not app:
@ -175,7 +184,7 @@ def _run_wsgi(app_name):
return return
server = wsgi.Server("Neutron") server = wsgi.Server("Neutron")
server.start(app, cfg.CONF.bind_port, cfg.CONF.bind_host, server.start(app, cfg.CONF.bind_port, cfg.CONF.bind_host,
workers=cfg.CONF.api_workers) workers=_get_api_workers())
# Dump all option values here after all options are parsed # Dump all option values here after all options are parsed
cfg.CONF.log_opt_values(LOG, std_logging.DEBUG) cfg.CONF.log_opt_values(LOG, std_logging.DEBUG)
LOG.info(_LI("Neutron service started, listening on %(host)s:%(port)s"), LOG.info(_LI("Neutron service started, listening on %(host)s:%(port)s"),

View File

@ -0,0 +1,31 @@
# Copyright 2014 Red Hat, Inc.
#
# 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 oslo_concurrency import processutils
from oslo_config import cfg
from neutron import service
from neutron.tests import base
class TestService(base.BaseTestCase):
def test_api_workers_default(self):
self.assertEqual(processutils.get_worker_count(),
service._get_api_workers())
def test_api_workers_from_config(self):
cfg.CONF.set_override('api_workers', 1234)
self.assertEqual(1234,
service._get_api_workers())