ed3b12d05c
You run one or more swift-bench-client processes like this: $ swift-bench-client 127.0.0.1 20001 $ swift-bench-client 127.0.0.1 20002 Then you run swift-bench with a new option, --bench-clients (-b), which is specified once for each swift-bench-client: $ swift-bench -b 127.0.0.1:20001 -b 127.0.0.1:20002 You get log lines from each client (interleaved) along with a final report for all clients: 127.0.0.1:20002 swift-bench-server 2012-08-25 22:44:06,148 INFO Auth version: 1.0 127.0.0.1:20001 swift-bench-server 2012-08-25 22:44:06,148 INFO Auth version: 1.0 127.0.0.1:20001 swift-bench-server 2012-08-25 22:44:12,249 INFO 83 PUTS [0 failures], 41.5/s 127.0.0.1:20002 swift-bench-server 2012-08-25 22:44:14,430 INFO 74 PUTS [0 failures], 34.3/s ... 127.0.0.1:20002 swift-bench-server 2012-08-25 22:45:18,942 INFO Auth version: 1.0 127.0.0.1:20002 swift-bench-server 2012-08-25 22:45:20,946 INFO 238 DEL [2 failures], 118.9/s swift-bench 2012-08-25 22:45:27,549 INFO 2000 PUTS **FINAL** [0 failures], 56.8/s swift-bench 2012-08-25 22:45:27,550 INFO 30000 GETS **FINAL** [50 failures], 974.6/s swift-bench 2012-08-25 22:45:27,550 INFO 2000 DEL **FINAL** [20 failures], 237.1/s The concurrency, PUT count, and GET count config settings are divided by the number of bench_clients. In other words, the same volume of work is attempted (vs. not specifying --bench-clients), but it can now span servers and CPU cores. Benchmark containers are created (if use_proxy = yes) and deleted (if delete = yes), with appropriate concurrency, in the initiating swift-bench process, not any of the swift-bench-client processes. Change-Id: Idbf31a23093244ab357a9bf77e6031257774f24a
102 lines
3.8 KiB
Python
102 lines
3.8 KiB
Python
#!/usr/bin/python
|
|
# Copyright (c) 2010-2012 OpenStack, LLC.
|
|
#
|
|
# 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 setuptools import setup, find_packages
|
|
|
|
from swift import __canonical_version__ as version
|
|
|
|
|
|
name = 'swift'
|
|
|
|
|
|
setup(
|
|
name=name,
|
|
version=version,
|
|
description='Swift',
|
|
license='Apache License (2.0)',
|
|
author='OpenStack, LLC.',
|
|
author_email='openstack-admins@lists.launchpad.net',
|
|
url='https://launchpad.net/swift',
|
|
packages=find_packages(exclude=['test', 'bin']),
|
|
test_suite='nose.collector',
|
|
classifiers=[
|
|
'Development Status :: 4 - Beta',
|
|
'License :: OSI Approved :: Apache Software License',
|
|
'Operating System :: POSIX :: Linux',
|
|
'Programming Language :: Python :: 2.6',
|
|
'Environment :: No Input/Output (Daemon)',
|
|
],
|
|
install_requires=[], # removed for better compat
|
|
scripts=[
|
|
'bin/swift-account-audit',
|
|
'bin/swift-account-auditor',
|
|
'bin/swift-account-reaper',
|
|
'bin/swift-account-replicator',
|
|
'bin/swift-account-server',
|
|
'bin/swift-bench',
|
|
'bin/swift-bench-client',
|
|
'bin/swift-container-auditor',
|
|
'bin/swift-container-replicator',
|
|
'bin/swift-container-server',
|
|
'bin/swift-container-sync',
|
|
'bin/swift-container-updater',
|
|
'bin/swift-dispersion-populate',
|
|
'bin/swift-dispersion-report',
|
|
'bin/swift-drive-audit',
|
|
'bin/swift-form-signature',
|
|
'bin/swift-get-nodes',
|
|
'bin/swift-init',
|
|
'bin/swift-object-auditor',
|
|
'bin/swift-object-expirer',
|
|
'bin/swift-object-info',
|
|
'bin/swift-object-replicator',
|
|
'bin/swift-object-server',
|
|
'bin/swift-object-updater',
|
|
'bin/swift-oldies',
|
|
'bin/swift-orphans',
|
|
'bin/swift-proxy-server',
|
|
'bin/swift-recon',
|
|
'bin/swift-recon-cron',
|
|
'bin/swift-ring-builder',
|
|
'bin/swift-temp-url',
|
|
],
|
|
entry_points={
|
|
'paste.app_factory': [
|
|
'proxy=swift.proxy.server:app_factory',
|
|
'object=swift.obj.server:app_factory',
|
|
'container=swift.container.server:app_factory',
|
|
'account=swift.account.server:app_factory',
|
|
],
|
|
'paste.filter_factory': [
|
|
'healthcheck=swift.common.middleware.healthcheck:filter_factory',
|
|
'memcache=swift.common.middleware.memcache:filter_factory',
|
|
'ratelimit=swift.common.middleware.ratelimit:filter_factory',
|
|
'cname_lookup=swift.common.middleware.cname_lookup:filter_factory',
|
|
'catch_errors=swift.common.middleware.catch_errors:filter_factory',
|
|
'domain_remap=swift.common.middleware.domain_remap:filter_factory',
|
|
'staticweb=swift.common.middleware.staticweb:filter_factory',
|
|
'tempauth=swift.common.middleware.tempauth:filter_factory',
|
|
'keystoneauth=swift.common.middleware.keystoneauth:filter_factory',
|
|
'recon=swift.common.middleware.recon:filter_factory',
|
|
'tempurl=swift.common.middleware.tempurl:filter_factory',
|
|
'formpost=swift.common.middleware.formpost:filter_factory',
|
|
'name_check=swift.common.middleware.name_check:filter_factory',
|
|
'proxy_logging=swift.common.middleware.proxy_logging:'
|
|
'filter_factory',
|
|
],
|
|
},
|
|
)
|