elasticgraph-health_check 1.1.0 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 800c46cff666b9c7873594e1ab41724861819537cf610bbd787f228f3b239693
4
- data.tar.gz: 807d9181a85371f7d78aa5c930df0723db6e695016e0db465ce39a854014acde
3
+ metadata.gz: f972c0e70a01459cc4df1ef7ac9a5ca3605735a32cd7bcf5c41c255460c13e8d
4
+ data.tar.gz: db9185a8d8a8adf3a751a36d24ba480260eb2bae20c4cf46a5493dcb71dec96f
5
5
  SHA512:
6
- metadata.gz: a1bdb2022acf29ebcf5e17b7170cfe51a53fc16d4741627cec0e13304e3255980d050c6b3c231b57ccee694b5dfaaf4a1c180babbc6e5edc029b306b5eca932d
7
- data.tar.gz: de48c504f8a3b4e52f7411ce19d20abd778759e82a350edc2604dcf40bea4604fa5b18e46d90a3457d5153c2b546de848b395972de92991100fcfeeaee670476
6
+ metadata.gz: 4d7894918d5b1f8f507d6d7423ae4b244dd096d5e587aeb5b10e3697b93da8dfedf2bf202dd796b3bdb4db260ff851bd766201bfb2efcb29407975bcbe13f308
7
+ data.tar.gz: 34e6922b0a896d7f5c5c78731d0ae37b0827719673c598c8ff138151c6184927e2d68a03648abee45ba7c76e7ead3108c5b158da411e788df17474fa44557e4e
@@ -56,7 +56,7 @@ module ElasticGraph
56
56
  end
57
57
 
58
58
  recency_results_by_query, *cluster_healths = execute_in_parallel(
59
- lambda { datastore_msearch(recency_queries_by_type_name.values) },
59
+ lambda { datastore_msearch(recency_queries_by_type_name) },
60
60
  *@config.clusters_to_consider.map do |cluster|
61
61
  lambda { [cluster, @datastore_clients_by_name.fetch(cluster).get_cluster_health] }
62
62
  end
@@ -70,14 +70,18 @@ module ElasticGraph
70
70
 
71
71
  private
72
72
 
73
- def datastore_msearch(queries)
74
- @datastore_search_router.msearch(queries)
73
+ def datastore_msearch(queries_by_type_name)
74
+ opaque_id_parts = ["elasticgraph-health_check"]
75
+ queried_types = queries_by_type_name.keys.sort
76
+ opaque_id_parts << "types=#{queried_types.join(",")}" if queried_types.any?
77
+
78
+ @datastore_search_router.msearch(queries_by_type_name.values, opaque_id_parts: opaque_id_parts)
75
79
  rescue ::GraphQL::ExecutionError => ex
76
80
  # A `GraphQL::ExecutionError` indicates the datastore is not ready to serve GraphQL queries.
77
81
  # Normally the GraphQL execution engine handles this kind of error and returns it in the `errors` of the GraphQL response.
78
82
  # Here we are outside of a GraphQL context and need to handle it ourselves.
79
83
  @logger.warn("HealthChecker getting GraphQL errors when querying the datastore: #{ex.class.name}: #{ex.message}")
80
- queries.to_h { |query| [query, GraphQL::DatastoreResponse::SearchResponse::EMPTY] }
84
+ queries_by_type_name.values.to_h { |query| [query, GraphQL::DatastoreResponse::SearchResponse::EMPTY] }
81
85
  end
82
86
 
83
87
  def build_recency_query_for(type_name, recency_config)
@@ -225,7 +229,7 @@ module ElasticGraph
225
229
  def all_known_clusters
226
230
  @all_known_clusters ||= @indexed_document_types_by_name.flat_map do |_, index_type|
227
231
  index_type.search_index_definitions.flat_map do |index_def|
228
- [index_def.cluster_to_query] + index_def.clusters_to_index_into
232
+ [index_def.cluster_to_query].compact + index_def.clusters_to_index_into
229
233
  end
230
234
  end + @datastore_clients_by_name.keys
231
235
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: elasticgraph-health_check
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.0
4
+ version: 1.2.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Myron Marston
@@ -17,112 +17,112 @@ dependencies:
17
17
  requirements:
18
18
  - - '='
19
19
  - !ruby/object:Gem::Version
20
- version: 1.1.0
20
+ version: 1.2.0
21
21
  type: :runtime
22
22
  prerelease: false
23
23
  version_requirements: !ruby/object:Gem::Requirement
24
24
  requirements:
25
25
  - - '='
26
26
  - !ruby/object:Gem::Version
27
- version: 1.1.0
27
+ version: 1.2.0
28
28
  - !ruby/object:Gem::Dependency
29
29
  name: elasticgraph-graphql
30
30
  requirement: !ruby/object:Gem::Requirement
31
31
  requirements:
32
32
  - - '='
33
33
  - !ruby/object:Gem::Version
34
- version: 1.1.0
34
+ version: 1.2.0
35
35
  type: :runtime
36
36
  prerelease: false
37
37
  version_requirements: !ruby/object:Gem::Requirement
38
38
  requirements:
39
39
  - - '='
40
40
  - !ruby/object:Gem::Version
41
- version: 1.1.0
41
+ version: 1.2.0
42
42
  - !ruby/object:Gem::Dependency
43
43
  name: elasticgraph-support
44
44
  requirement: !ruby/object:Gem::Requirement
45
45
  requirements:
46
46
  - - '='
47
47
  - !ruby/object:Gem::Version
48
- version: 1.1.0
48
+ version: 1.2.0
49
49
  type: :runtime
50
50
  prerelease: false
51
51
  version_requirements: !ruby/object:Gem::Requirement
52
52
  requirements:
53
53
  - - '='
54
54
  - !ruby/object:Gem::Version
55
- version: 1.1.0
55
+ version: 1.2.0
56
56
  - !ruby/object:Gem::Dependency
57
57
  name: elasticgraph-admin
58
58
  requirement: !ruby/object:Gem::Requirement
59
59
  requirements:
60
60
  - - '='
61
61
  - !ruby/object:Gem::Version
62
- version: 1.1.0
62
+ version: 1.2.0
63
63
  type: :development
64
64
  prerelease: false
65
65
  version_requirements: !ruby/object:Gem::Requirement
66
66
  requirements:
67
67
  - - '='
68
68
  - !ruby/object:Gem::Version
69
- version: 1.1.0
69
+ version: 1.2.0
70
70
  - !ruby/object:Gem::Dependency
71
71
  name: elasticgraph-elasticsearch
72
72
  requirement: !ruby/object:Gem::Requirement
73
73
  requirements:
74
74
  - - '='
75
75
  - !ruby/object:Gem::Version
76
- version: 1.1.0
76
+ version: 1.2.0
77
77
  type: :development
78
78
  prerelease: false
79
79
  version_requirements: !ruby/object:Gem::Requirement
80
80
  requirements:
81
81
  - - '='
82
82
  - !ruby/object:Gem::Version
83
- version: 1.1.0
83
+ version: 1.2.0
84
84
  - !ruby/object:Gem::Dependency
85
85
  name: elasticgraph-indexer
86
86
  requirement: !ruby/object:Gem::Requirement
87
87
  requirements:
88
88
  - - '='
89
89
  - !ruby/object:Gem::Version
90
- version: 1.1.0
90
+ version: 1.2.0
91
91
  type: :development
92
92
  prerelease: false
93
93
  version_requirements: !ruby/object:Gem::Requirement
94
94
  requirements:
95
95
  - - '='
96
96
  - !ruby/object:Gem::Version
97
- version: 1.1.0
97
+ version: 1.2.0
98
98
  - !ruby/object:Gem::Dependency
99
99
  name: elasticgraph-opensearch
100
100
  requirement: !ruby/object:Gem::Requirement
101
101
  requirements:
102
102
  - - '='
103
103
  - !ruby/object:Gem::Version
104
- version: 1.1.0
104
+ version: 1.2.0
105
105
  type: :development
106
106
  prerelease: false
107
107
  version_requirements: !ruby/object:Gem::Requirement
108
108
  requirements:
109
109
  - - '='
110
110
  - !ruby/object:Gem::Version
111
- version: 1.1.0
111
+ version: 1.2.0
112
112
  - !ruby/object:Gem::Dependency
113
113
  name: elasticgraph-schema_definition
114
114
  requirement: !ruby/object:Gem::Requirement
115
115
  requirements:
116
116
  - - '='
117
117
  - !ruby/object:Gem::Version
118
- version: 1.1.0
118
+ version: 1.2.0
119
119
  type: :development
120
120
  prerelease: false
121
121
  version_requirements: !ruby/object:Gem::Requirement
122
122
  requirements:
123
123
  - - '='
124
124
  - !ruby/object:Gem::Version
125
- version: 1.1.0
125
+ version: 1.2.0
126
126
  email:
127
127
  - myron@squareup.com
128
128
  executables: []
@@ -142,10 +142,10 @@ licenses:
142
142
  - MIT
143
143
  metadata:
144
144
  bug_tracker_uri: https://github.com/block/elasticgraph/issues
145
- changelog_uri: https://github.com/block/elasticgraph/releases/tag/v1.1.0
146
- documentation_uri: https://block.github.io/elasticgraph/api-docs/v1.1.0/
145
+ changelog_uri: https://github.com/block/elasticgraph/releases/tag/v1.2.0
146
+ documentation_uri: https://block.github.io/elasticgraph/api-docs/v1.2.0/
147
147
  homepage_uri: https://block.github.io/elasticgraph/
148
- source_code_uri: https://github.com/block/elasticgraph/tree/v1.1.0/elasticgraph-health_check
148
+ source_code_uri: https://github.com/block/elasticgraph/tree/v1.2.0/elasticgraph-health_check
149
149
  gem_category: extension
150
150
  rdoc_options: []
151
151
  require_paths:
@@ -164,7 +164,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
164
164
  - !ruby/object:Gem::Version
165
165
  version: '0'
166
166
  requirements: []
167
- rubygems_version: 4.0.3
167
+ rubygems_version: 4.0.6
168
168
  specification_version: 4
169
169
  summary: Provides a health check for high availability ElasticGraph deployments.
170
170
  test_files: []