migrate_3_0.asciidoc 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470
  1. [[breaking-changes-3.0]]
  2. == Breaking changes in 3.0
  3. This section discusses the changes that you need to be aware of when migrating
  4. your application to Elasticsearch 3.0.
  5. * <<breaking_30_search_changes>>
  6. * <<breaking_30_rest_api_changes>>
  7. * <<breaking_30_parent_child_changes>>
  8. * <<breaking_30_settings_changes>>
  9. * <<breaking_30_mapping_changes>>
  10. * <<breaking_30_plugins>>
  11. * <<breaking_30_java_api_changes>>
  12. * <<breaking_30_cache_concurrency>>
  13. * <<breaking_30_non_loopback>>
  14. * <<breaking_30_thread_pool>>
  15. [[breaking_30_search_changes]]
  16. === Search changes
  17. ==== `search_type=count` removed
  18. The `count` search type was deprecated since version 2.0.0 and is now removed.
  19. In order to get the same benefits, you just need to set the value of the `size`
  20. parameter to `0`.
  21. For instance, the following request:
  22. [source,sh]
  23. ---------------
  24. GET /my_index/_search?search_type=count
  25. {
  26. "aggs": {
  27. "my_terms": {
  28. "terms": {
  29. "field": "foo"
  30. }
  31. }
  32. }
  33. }
  34. ---------------
  35. can be replaced with:
  36. [source,sh]
  37. ---------------
  38. GET /my_index/_search
  39. {
  40. "size": 0,
  41. "aggs": {
  42. "my_terms": {
  43. "terms": {
  44. "field": "foo"
  45. }
  46. }
  47. }
  48. }
  49. ---------------
  50. ==== `search_type=scan` removed
  51. The `scan` search type was deprecated since version 2.1.0 and is now removed.
  52. All benefits from this search type can now be achieved by doing a scroll
  53. request that sorts documents in `_doc` order, for instance:
  54. [source,sh]
  55. ---------------
  56. GET /my_index/_search?scroll=2m
  57. {
  58. "sort": [
  59. "_doc"
  60. ]
  61. }
  62. ---------------
  63. Scroll requests sorted by `_doc` have been optimized to more efficiently resume
  64. from where the previous request stopped, so this will have the same performance
  65. characteristics as the former `scan` search type.
  66. [[breaking_30_rest_api_changes]]
  67. === REST API changes
  68. ==== search exists api removed
  69. The search exists api has been removed in favour of using the search api with
  70. `size` set to `0` and `terminate_after` set to `1`.
  71. ==== `/_optimize` endpoint removed
  72. The deprecated `/_optimize` endpoint has been removed. The `/_forcemerge`
  73. endpoint should be used in lieu of optimize.
  74. ==== Deprecated queries removed
  75. The following deprecated queries have been removed:
  76. * `filtered`: use `bool` query instead, which supports `filter` clauses too
  77. * `and`: use `must` clauses in a `bool` query instead
  78. * `or`: use should clauses in a `bool` query instead
  79. * `limit`: use `terminate_after` parameter instead
  80. * `fquery`: obsolete after filters and queries have been merged
  81. * `query`: obsolete after filters and queries have been merged
  82. ==== Unified fuzziness parameter
  83. * Removed support for the deprecated `min_similarity` parameter in `fuzzy query`, in favour of `similarity`.
  84. * Removed support for the deprecated `fuzzy_min_sim` parameter in `query_string` query, in favour of `similarity`.
  85. * Removed support for the deprecated `edit_distance` parameter in completion suggester, in favour of `similarity`.
  86. ==== indices query
  87. Removed support for the deprecated `filter` and `no_match_filter` fields in `indices` query,
  88. in favour of `query` and `no_match_query`.
  89. ==== nested query
  90. Removed support for the deprecated `filter` fields in `nested` query, in favour of `query`.
  91. ==== terms query
  92. Removed support for the deprecated `minimum_should_match` and `disable_coord` in `terms` query, use `bool` query instead.
  93. Removed also support for the deprecated `execution` parameter.
  94. ==== function_score query
  95. Removed support for the top level `filter` element in `function_score` query, replaced by `query`.
  96. ==== highlighters
  97. Removed support for multiple highlighter names, the only supported ones are: `plain`, `fvh` and `postings`.
  98. ==== top level filter
  99. Removed support for the deprecated top level `filter` in the search api, replaced by `post_filter`.
  100. ==== `query_binary` and `filter_binary` removed
  101. Removed support for the undocumented `query_binary` and `filter_binary` sections of a search request.
  102. [[breaking_30_parent_child_changes]]
  103. === Parent/Child changes
  104. The `children` aggregation, parent child inner hits and `has_child` and `has_parent` queries will not work on indices
  105. with `_parent` field mapping created before version `2.0.0`. The data of these indices need to be re-indexed into a new index.
  106. The format of the join between parent and child documents have changed with the `2.0.0` release. The old
  107. format can't read from version `3.0.0` and onwards. The new format allows for a much more efficient and
  108. scalable join between parent and child documents and the join data structures are stored on on disk
  109. data structures as opposed as before the join data structures were stored in the jvm heap space.
  110. ==== `score_type` has been removed
  111. The `score_type` option has been removed from the `has_child` and `has_parent` queries in favour of the `score_mode` option
  112. which does the exact same thing.
  113. ==== `sum` score mode removed
  114. The `sum` score mode has been removed in favour of the `total` mode which does the same and is already available in
  115. previous versions.
  116. ==== `max_children` option
  117. When `max_children` was set to `0` on the `has_child` query then there was no upper limit on how many children documents
  118. are allowed to match. This has changed and `0` now really means to zero child documents are allowed. If no upper limit
  119. is needed then the `max_children` option shouldn't be defined at all on the `has_child` query.
  120. [[breaking_30_settings_changes]]
  121. === Settings changes
  122. ==== Analysis settings
  123. The `index.analysis.analyzer.default_index` analyzer is not supported anymore.
  124. If you wish to change the analyzer to use for indexing, change the
  125. `index.analysis.analyzer.default` analyzer instead.
  126. ==== Ping timeout settings
  127. Previously, there were three settings for the ping timeout: `discovery.zen.initial_ping_timeout`,
  128. `discovery.zen.ping.timeout` and `discovery.zen.ping_timeout`. The former two have been removed and
  129. the only setting key for the ping timeout is now `discovery.zen.ping_timeout`. The default value for
  130. ping timeouts remains at three seconds.
  131. [[breaking_30_mapping_changes]]
  132. === Mapping changes
  133. ==== Transform removed
  134. The `transform` feature from mappings has been removed. It made issues very hard to debug.
  135. [[breaking_30_plugins]]
  136. === Plugin changes
  137. Plugins implementing custom queries need to implement the `fromXContent(QueryParseContext)` method in their
  138. `QueryParser` subclass rather than `parse`. This method will take care of parsing the query from `XContent` format
  139. into an intermediate query representation that can be streamed between the nodes in binary format, effectively the
  140. query object used in the java api. Also, the query parser needs to implement the `getBuilderPrototype` method that
  141. returns a prototype of the `NamedWriteable` query, which allows to deserialize an incoming query by calling
  142. `readFrom(StreamInput)` against it, which will create a new object, see usages of `Writeable`. The `QueryParser`
  143. also needs to declare the generic type of the query that it supports and it's able to parse.
  144. The query object can then transform itself into a lucene query through the new `toQuery(QueryShardContext)` method,
  145. which returns a lucene query to be executed on the data node.
  146. Similarly, plugins implementing custom score functions need to implement the `fromXContent(QueryParseContext)`
  147. method in their `ScoreFunctionParser` subclass rather than `parse`. This method will take care of parsing
  148. the function from `XContent` format into an intermediate function representation that can be streamed between
  149. the nodes in binary format, effectively the function object used in the java api. Also, the query parser needs
  150. to implement the `getBuilderPrototype` method that returns a prototype of the `NamedWriteable` function, which
  151. allows to deserialize an incoming function by calling `readFrom(StreamInput)` against it, which will create a
  152. new object, see usages of `Writeable`. The `ScoreFunctionParser` also needs to declare the generic type of the
  153. function that it supports and it's able to parse. The function object can then transform itself into a lucene
  154. function through the new `toFunction(QueryShardContext)` method, which returns a lucene function to be executed
  155. on the data node.
  156. ==== Cloud AWS plugin changes
  157. Cloud AWS plugin has been split in two plugins:
  158. * {plugins}/discovery-ec2.html[Discovery EC2 plugin]
  159. * {plugins}/repository-s3.html[Repository S3 plugin]
  160. ==== Cloud Azure plugin changes
  161. Cloud Azure plugin has been split in three plugins:
  162. * {plugins}/discovery-azure.html[Discovery Azure plugin]
  163. * {plugins}/repository-azure.html[Repository Azure plugin]
  164. * {plugins}/store-smb.html[Store SMB plugin]
  165. If you were using the `cloud-azure` plugin for snapshot and restore, you had in `elasticsearch.yml`:
  166. [source,yaml]
  167. -----
  168. cloud:
  169. azure:
  170. storage:
  171. account: your_azure_storage_account
  172. key: your_azure_storage_key
  173. -----
  174. You need to give a unique id to the storage details now as you can define multiple storage accounts:
  175. [source,yaml]
  176. -----
  177. cloud:
  178. azure:
  179. storage:
  180. my_account:
  181. account: your_azure_storage_account
  182. key: your_azure_storage_key
  183. -----
  184. ==== Cloud GCE plugin changes
  185. Cloud GCE plugin has been renamed to {plugins}/discovery-gce.html[Discovery GCE plugin].
  186. [[breaking_30_java_api_changes]]
  187. === Java API changes
  188. ==== Count api has been removed
  189. The deprecated count api has been removed from the Java api, use the search api instead and set size to 0.
  190. The following call
  191. [source,java]
  192. -----
  193. client.prepareCount(indices).setQuery(query).get();
  194. -----
  195. can be replaced with
  196. [source,java]
  197. -----
  198. client.prepareSearch(indices).setSource(new SearchSourceBuilder().size(0).query(query)).get();
  199. -----
  200. ==== BoostingQueryBuilder
  201. Removed setters for mandatory positive/negative query. Both arguments now have
  202. to be supplied at construction time already and have to be non-null.
  203. ==== SpanContainingQueryBuilder
  204. Removed setters for mandatory big/little inner span queries. Both arguments now have
  205. to be supplied at construction time already and have to be non-null. Updated
  206. static factory methods in QueryBuilders accordingly.
  207. ==== SpanOrQueryBuilder
  208. Making sure that query contains at least one clause by making initial clause mandatory
  209. in constructor.
  210. ==== SpanNearQueryBuilder
  211. Removed setter for mandatory slop parameter, needs to be set in constructor now. Also
  212. making sure that query contains at least one clause by making initial clause mandatory
  213. in constructor. Updated the static factory methods in QueryBuilders accordingly.
  214. ==== SpanNotQueryBuilder
  215. Removed setter for mandatory include/exclude span query clause, needs to be set in constructor now.
  216. Updated the static factory methods in QueryBuilders and tests accordingly.
  217. ==== SpanWithinQueryBuilder
  218. Removed setters for mandatory big/little inner span queries. Both arguments now have
  219. to be supplied at construction time already and have to be non-null. Updated
  220. static factory methods in QueryBuilders accordingly.
  221. ==== QueryFilterBuilder
  222. Removed the setter `queryName(String queryName)` since this field is not supported
  223. in this type of query. Use `FQueryFilterBuilder.queryName(String queryName)` instead
  224. when in need to wrap a named query as a filter.
  225. ==== WrapperQueryBuilder
  226. Removed `wrapperQueryBuilder(byte[] source, int offset, int length)`. Instead simply
  227. use `wrapperQueryBuilder(byte[] source)`. Updated the static factory methods in
  228. QueryBuilders accordingly.
  229. ==== QueryStringQueryBuilder
  230. Removed ability to pass in boost value using `field(String field)` method in form e.g. `field^2`.
  231. Use the `field(String, float)` method instead.
  232. ==== Operator
  233. Removed the enums called `Operator` from `MatchQueryBuilder`, `QueryStringQueryBuilder`,
  234. `SimpleQueryStringBuilder`, and `CommonTermsQueryBuilder` in favour of using the enum
  235. defined in `org.elasticsearch.index.query.Operator` in an effort to consolidate the
  236. codebase and avoid duplication.
  237. ==== queryName and boost support
  238. Support for `queryName` and `boost` has been streamlined to all of the queries. That is
  239. a breaking change till queries get sent over the network as serialized json rather
  240. than in `Streamable` format. In fact whenever additional fields are added to the json
  241. representation of the query, older nodes might throw error when they find unknown fields.
  242. ==== InnerHitsBuilder
  243. InnerHitsBuilder now has a dedicated addParentChildInnerHits and addNestedInnerHits methods
  244. to differentiate between inner hits for nested vs. parent / child documents. This change
  245. makes the type / path parameter mandatory.
  246. ==== MatchQueryBuilder
  247. Moving MatchQueryBuilder.Type and MatchQueryBuilder.ZeroTermsQuery enum to MatchQuery.Type.
  248. Also reusing new Operator enum.
  249. ==== MoreLikeThisQueryBuilder
  250. Removed `MoreLikeThisQueryBuilder.Item#id(String id)`, `Item#doc(BytesReference doc)`,
  251. `Item#doc(XContentBuilder doc)`. Use provided constructors instead.
  252. Removed `MoreLikeThisQueryBuilder#addLike` in favor of texts and/or items being provided
  253. at construction time. Using arrays there instead of lists now.
  254. Removed `MoreLikeThisQueryBuilder#addUnlike` in favor to using the `unlike` methods
  255. which take arrays as arguments now rather than the lists used before.
  256. The deprecated `docs(Item... docs)`, `ignoreLike(Item... docs)`,
  257. `ignoreLike(String... likeText)`, `addItem(Item... likeItems)` have been removed.
  258. ==== GeoDistanceQueryBuilder
  259. Removing individual setters for lon() and lat() values, both values should be set together
  260. using point(lon, lat).
  261. ==== GeoDistanceRangeQueryBuilder
  262. Removing setters for to(Object ...) and from(Object ...) in favour of the only two allowed input
  263. arguments (String, Number). Removing setter for center point (point(), geohash()) because parameter
  264. is mandatory and should already be set in constructor.
  265. Also removing setters for lt(), lte(), gt(), gte() since they can all be replaced by equivallent
  266. calls to to/from() and inludeLower()/includeUpper().
  267. ==== GeoPolygonQueryBuilder
  268. Require shell of polygon already to be specified in constructor instead of adding it pointwise.
  269. This enables validation, but makes it necessary to remove the addPoint() methods.
  270. ==== MultiMatchQueryBuilder
  271. Moving MultiMatchQueryBuilder.ZeroTermsQuery enum to MatchQuery.ZeroTermsQuery.
  272. Also reusing new Operator enum.
  273. Removed ability to pass in boost value using `field(String field)` method in form e.g. `field^2`.
  274. Use the `field(String, float)` method instead.
  275. ==== MissingQueryBuilder
  276. The two individual setters for existence() and nullValue() were removed in favour of
  277. optional constructor settings in order to better capture and validate their interdependent
  278. settings at construction time.
  279. ==== NotQueryBuilder
  280. The NotQueryBuilder which was deprecated in 2.1.0 is removed. As a replacement use BoolQueryBuilder
  281. with added mustNot() clause. So instead of using `new NotQueryBuilder(filter)` now use
  282. `new BoolQueryBuilder().mustNot(filter)`.
  283. ==== TermsQueryBuilder
  284. Remove the setter for `termsLookup()`, making it only possible to either use a TermsLookup object or
  285. individual values at construction time. Also moving individual settings for the TermsLookup (lookupIndex,
  286. lookupType, lookupId, lookupPath) to the separate TermsLookup class, using constructor only and moving
  287. checks for validation there. Removed `TermsLookupQueryBuilder` in favour of `TermsQueryBuilder`.
  288. ==== FunctionScoreQueryBuilder
  289. `add` methods have been removed, all filters and functions must be provided as constructor arguments by
  290. creating an array of `FunctionScoreQueryBuilder.FilterFunctionBuilder` objects, containing one element
  291. for each filter/function pair.
  292. `scoreMode` and `boostMode` can only be provided using corresponding enum members instead
  293. of string values: see `FilterFunctionScoreQuery.ScoreMode` and `CombineFunction`.
  294. `CombineFunction.MULT` has been renamed to `MULTIPLY`.
  295. ==== IdsQueryBuilder
  296. For simplicity, only one way of adding the ids to the existing list (empty by default) is left: `addIds(String...)`
  297. ==== DocumentAlreadyExistsException removed
  298. `DocumentAlreadyExistsException` is removed and a `VersionConflictException` is thrown instead (with a better
  299. error description). This will influence code that use the `IndexRequest.opType()` or `IndexRequest.create()`
  300. to index a document only if it doesn't already exist.
  301. ==== ShapeBuilders
  302. `InternalLineStringBuilder` is removed in favour of `LineStringBuilder`, `InternalPolygonBuilder` in favour of PolygonBuilder` and `Ring` has been replaced with `LineStringBuilder`. Also the abstract base classes `BaseLineStringBuilder` and `BasePolygonBuilder` haven been merged with their corresponding implementations.
  303. [[breaking_30_cache_concurrency]]
  304. === Cache concurrency level settings removed
  305. Two cache concurrency level settings `indices.requests.cache.concurrency_level` and
  306. `indices.fielddata.cache.concurrency_level` because they no longer apply to the cache implementation used for the
  307. request cache and the field data cache.
  308. [[breaking_30_non_loopback]]
  309. === Remove bind option of `non_loopback`
  310. This setting would arbitrarily pick the first interface not marked as loopback. Instead, specify by address
  311. scope (e.g. `_local_,_site_` for all loopback and private network addresses) or by explicit interface names,
  312. hostnames, or addresses.
  313. [[breaking_30_thread_pool]]
  314. === Forbid changing of thread pool types
  315. Previously, <<modules-threadpool,thread pool types>> could be dynamically adjusted. The thread pool type effectively
  316. controls the backing queue for the thread pool and modifying this is an expert setting with minimal practical benefits
  317. and high risk of being misused. The ability to change the thread pool type for any thread pool has been removed; do note
  318. that it is still possible to adjust relevant thread pool parameters for each of the thread pools (e.g., depending on
  319. the thread pool type, `keep_alive`, `queue_size`, etc.).
  320. === Adding system CPU percent to OS stats
  321. The recent CPU usage (as a percent) has been added to the OS stats reported under the node stats API and the cat nodes
  322. API. The breaking change here is that there is a new object in the "os" object in the node stats response. This object
  323. is called "cpu" and includes "percent" and "load_average" as fields. This moves the "load_average" field that was
  324. previously a top-level field in the "os" object to the "cpu" object. Additionally, the "cpu" field in the cat nodes API
  325. response is output by default.
  326. Finally, the API for org.elasticsearch.monitor.os.OsStats has changed. The `getLoadAverage` method has been removed. The
  327. value for this can now be obtained from `OsStats.Cpu#getLoadAverage`. Additionally, the recent CPU usage can be obtained
  328. from `OsStats.Cpu#getPercent`.