Skip to content

Latest commit

 

History

History
367 lines (242 loc) · 19.5 KB

CHANGELOG.md

File metadata and controls

367 lines (242 loc) · 19.5 KB

0.9.1

Bug Fixes

  • #399: 0.9.0 - Unable to run race due to missing JDK9

0.9.0

Enhancements

  • #398: Allow to override plugin variables
  • #387: Require JDK 9 for source builds
  • #384: Provide a specific error message if data file is present but wrong size
  • #383: Abort current benchmark in case of attempted duplicate starts
  • #376: Record indexing throttle time
  • #366: Separate document corpus definition from indices
  • #361: Don't measure every operation
  • #359: Allow to define index settings per index
  • #348: Prefer default data directory when --track-path is given
  • #293: Allow users to explicitly define index management operations

Bug Fixes

  • #396: Rally requires a team repo even if used as a load generator
  • #394: Error in track preparation can hang benchmarks

Doc Changes

  • #397: Add a gentle reminder to update the Rally kernel with the important elasticsearch system configurations
  • #389: Syntax error in elasticsearch_plugins documentation
  • #388: Update rally daemon port requirements
  • #355: Run In Kubernetes

0.8.1

Enhancements

  • #375: Add refresh API

0.8.0

Highlights

  • #310: Introduce track parameters and allow to override them on the command line

Enhancements

  • #371: Introduce put pipeline API
  • #369: Prepare rename from operation-type "index" to "bulk"
  • #363: Allow to retry operations (internally)
  • #362: Make plugin remote URL optional
  • #360: Show ES distribution version upon race start
  • #358: Rally tables should always output the same rows
  • #354: Be more lenient when custom parameter source does not provide a parameter
  • #353: Make a few track properties optional
  • #352: Allow to use a challenge element if there is only one challenge in a track
  • #351 (Breaking): Ensure task names are unique
  • #345: Allow to use an ES distribution for plugins that are built separately
  • #326: Allow to define operations inline

Bug Fixes

  • #356 (Breaking): Set a sane default socket timeout
  • #350 (Breaking): Number of iterations should be treated per client, not "global"

Doc Changes

  • #364: Deprecate --cluster-health

0.7.4

Enhancements

  • #333: Provide a clear error message for non-existing releases
  • #331: Don't demand a compressed representation of the document corpus
  • #226: Provide a Rally package with all dependencies for offline install
  • #217: Add ability to continuously stream metrics

Bug Fixes

  • #344: Client assignment can miss a (small) number of docs
  • #338: Documents are not found if track is referenced via a file
  • #337: Only map numeric HTTP status codes to request meta-data
  • #334: Data partition algorithm failling with parallel indexing tasks

Doc Changes

  • #343: If python is required then python-dev should be as well
  • #231: Simplify usage of Rally for offline-only use

0.7.3

Enhancements

  • #332: Provide more information about errors
  • #330: Provide better error message when Rally reads an incompatible track
  • #329: Allow to skip cluster health check
  • #323: Rally should not demand a local Java install
  • #309: Allow to benchmark plugins from sources
  • #292: Add a "simple track" mode
  • #259: Prepare Rally for Java 9

Bug Fixes

  • #328: Challenge-specific index settings are not applied to index template definitions

0.7.2

Enhancements

  • #322: Add error-type to request meta-data
  • #321: Don't log body when creating a new index
  • #319: Upgrade to thespian 3.8.0
  • #315: Simplify multi-node configuration
  • #313: Allow car mixins
  • #265: Have Rally detect and use more Java versions

Bug Fixes

  • #318: Run tasks indefinitely

0.7.1

Highlights

  • #257: Distribute load-test driver

Bug Fixes

  • #316: KeyError: 'vm_vendor' when running benchmark against single host cluster with 0.7.0

0.7.0

Highlights

  • #71: Allow to benchmark multi-machine clusters
  • #60: Allow benchmarking with plugins

Enhancements

  • #314: Allow to filter executed tasks
  • #312 (Breaking): Move action-and-meta-data to (indexing) type definition
  • #308: Unify implementation of track and team repositories
  • #307: Check Python version on startup and fail if it does not meet requirements
  • #304: Make distribution repositories configurable
  • #296: Verify whether the number of documents in the track is correct
  • #278: relative-time should be reset per task
  • #228: Increased flexibility for termination of parallel tasks

0.6.2

Enhancements

  • #299: Leave the host parsing on elasticsearch-py
  • #227: Enhance flexibility of user tagging
  • #196 (Breaking): Externalize car configuration

Bug Fixes

  • #298: Rally froze at the end of a race, did not produce results

0.6.1

Enhancements

  • #295: Provide number of query hits as metrics metadata
  • #291: Show track size metrics when listing tracks
  • #290: Allow to pass arbitrary request parameters for ES queries
  • #286: Additional metrics for bulk requests
  • #282 (Breaking): Remove list facts subcommand

0.6.0

Highlights

  • #258: Make 'race' self-contained

Enhancements

  • #284 (Breaking): Disallow previously deprecated usage of track properties in meta block
  • #283: Store race results in a format optimized for reporting
  • #279 (Breaking): Separate race and metrics indices
  • #276: Add affected index to meta-data returned by bulk index runner
  • #275: Allow to define per-challenge cluster-settings
  • #267: Provide a progress-indication for downloads
  • #266: Make the gc telemetry device Java 9 compatible
  • #246: Rally should print a warning if there are no measurement samples
  • #223: Allow unlimited number of pages for scroll queries
  • #222: Report number of hits, not just pages, for scroll queries
  • #220 (Breaking): Allow monthly indices for metrics
  • #138 (Breaking): Improve support Elasticsearch 5 as metrics store

Bug Fixes

  • #285: Rally is stuck for benchmarks with a very large number of requests
  • #280: The file-reader parameter source does not seem to pass additional parameters

Doc Changes

  • #288: Clarify usage of remote track repositories in docs
  • #287: Document throughput semantics for each operation
  • #274: Explain summary report output
  • #271: Document how to implement custom runner classes
  • #264: Documentation on settings and warning message when using a documents archive file

0.5.3

Highlights

  • #251: Support for non-deterministic distribution of operations

Enhancements

  • #260: Have bulk parameter source provide the bulk size
  • #249: Saving tournament report
  • #155: Improve document count handling

Bug Fixes

  • #263: Race condition when rolling log files
  • #261: Unable to determine valid external socket address
  • #253: Cannot determine CPU info for POWER8 chips
  • #242: Rally does not detect the distribution version correctly for externally provisioned clusters
  • #235: Allow Python files in a track directory that are unrelated to the track plugin

Doc Changes

  • #256: Document additional decompression options
  • #247: Description of available operation types in the docs
  • #241: Clearly document which Elasticsearch versions are supported

0.5.2

Enhancements

  • #244: Show a nice error message when user tries to run a non-existing challenge on an existing track

Bug Fixes

  • #245: Connection behind a proxy fails. has_internet_connection() returns False

0.5.1

Enhancements

  • #234: Add request error rate to summary report

0.5.0

Highlights

  • #238: Simplify gathering of facts for benchmark results sharing
  • #216: Add possibility to profile load driver internals
  • #184: Allow to benchmark a single-machine cluster remotely

Enhancements

  • #207: Improve response checks in bulk API runner
  • #205: Make track configuration more modular
  • #200: Allow root.dir to be set during configure
  • #199: Let track authors decide on the default challenge
  • #191: Support target-interval for operations

Bug Fixes

  • #225: Final score report blank when metrics store specified
  • #221: Scrolls fail against Elasticsearch master
  • #203: Index time metrics are not aware of laps
  • #202: Bulk index source reads data for all indices

Doc Changes

  • #224: Issue(s) with --user-tags
  • #214: Improve documentation of "parallel"
  • #213: Document how to support --test-mode in a track
  • #208: Add FAQ item to explain latency, service time and their relation to "took"

0.4.0

Breaking changes in 0.4.0

The track format has changed a bit due a more flexible approach in how benchmarks are executed:

  • Operations are defined in the operations section, execution details like number of warmup iterations, warmup time etc. are defined as part of the schedule.
  • Each query needs to be defined as a separate operation and referenced in the schedule
  • You can (and in fact should) specify a warmup-time-period (defined in sections) for bulk index operations. The warmup time period is specified in seconds.

For details please refer to the updated JSON schema for Rally tracks.

Hint: This is just relevant for you, if you have defined your own tracks. We already took care of updating the official Rally tracks.

All changes

0.3.0

Breaking changes in 0.3

We have separated the previously known "track setup" into two parts:

  • Challenges: Which describe what happens during a benchmark (whether to index or search and with which parameters)
  • Cars: Which describe the benchmark candidate settings (e.g. heap size, logging configuration etc.)

This influences the command line interface in a couple of ways:

  • To list all known cars, we have added a new command esrally list cars. To select a challenge, use now --challenge instead of --track-setup and also specify a car now with --car.
  • Tournaments created by older versions of Rally are incompatible
  • Rally must now be invoked with only one challenge and only one car (previously it was possible to specify multiple track setups)

We have also moved tracks to a dedicated repository. This allows you to support tracks for multiple versions of Elasticsearch but also requires that all users have git installed.

All changes

Simplified configuration in 0.3

We have spent a lot of time to simplify first time setup of Rally. For starters, you are not required to setup your own metrics store if you don't need it. However, you are then just able to run individual benchmarks but you cannot compare results or visualize anything in Kibana. If you don't need this, it is recommended that you remove the configuration directory and run esrally configure. Rally will notify you on its first start of this change and guide you through the process.

Please raise a ticket in case of problems.

0.2.1

All changes

0.2.0

Major changes:

All changes

0.1.0

Major changes:

  • Added a JIT profiler. This allows to check warmup times but also in-depth inspection which optimizations were performed by the JIT compiler. If the HotSpot disassembler library is available, the logs will also contain the disassembled JIT compiler output which can be used for low-level analysis. We recommend to use JITWatch for analysis.
  • Added pipeline support. Pipelines allow to define more flexibly which steps Rally executes during a benchmark. One of the use-cases for this is to run a benchmark based on a released build of Elasticsearch rather than building it ourselves.

All changes

0.0.3

Major changes:

  • Migrated the metrics data store from file-based to a dedicated Elasticsearch instance. Graphical reports can be created with Kibana (optional but recommended). It is necessary to setup an Elasticsearch cluster to store metrics data (a single node is sufficient). The cluster will be configured automatically by Rally. For details please see the README.

    Related issues: #8, #21, #46,

All changes