elastic_ar_sync 0.1.7 → 0.1.10
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 +4 -4
- data/README.md +4 -0
- data/lib/elastic_ar_sync/elastic/syncable.rb +18 -14
- data/lib/elastic_ar_sync/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e470a29ed95eb045b4b06fe68c31deeb92025a223483f4b83bd38096e9df20e2
|
4
|
+
data.tar.gz: 2063fc468899251de4f55219d7714a5bf01c828b9b5fcd850ed2eb24722ef887
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 393a392acb1eeee8eb58c79a4fcfde46fbc3a7cf08904642fed212feba8f58b73caae97472627f0bce9dd59debccc7792975f08310c5ccec28e816322fb138e9
|
7
|
+
data.tar.gz: c557c9d8d4088bb1b1c03f1024dfeaf9e0efe2eaddce14a3e3a1c5b80726a938f45b63a2293c0ebf1cce9357afd4e15f9c0b875b3c2b9a4c20c1224e03dba33d
|
data/README.md
CHANGED
@@ -1,6 +1,10 @@
|
|
1
1
|
# ElasticArSync
|
2
2
|
This repository contains easy set up modules for RDB and elasticsearch index with Active Record.
|
3
3
|
This is based on `gem elasticsearch-rails`.
|
4
|
+
|
5
|
+
日本語での説明はこちら
|
6
|
+
https://ted-tech.hateblo.jp/entry/2020/08/11/103155
|
7
|
+
|
4
8
|
## Usage
|
5
9
|
### Preparation
|
6
10
|
Install `gem sidekiq` and `gem redis-rails` to use Asynchronous processing for your app.
|
@@ -13,27 +13,27 @@ module ElasticArSync
|
|
13
13
|
# after_commitでRDBを操作した時にESのインデックスも同期させる
|
14
14
|
# アプリのサーバーに負荷をかけ無いように非同期で実行させる
|
15
15
|
after_commit on: [:create] do
|
16
|
-
document_sync_create(self.class, id)
|
16
|
+
document_sync_create(self.class.to_s, id)
|
17
17
|
end
|
18
18
|
|
19
19
|
after_commit on: [:update] do
|
20
|
-
document_sync_update(self.class, id)
|
20
|
+
document_sync_update(self.class.to_s, id)
|
21
21
|
end
|
22
22
|
|
23
23
|
after_commit on: [:destroy] do
|
24
|
-
document_sync_delete(self.class, id)
|
24
|
+
document_sync_delete(self.class.to_s, id)
|
25
25
|
end
|
26
26
|
|
27
|
-
def document_sync_create(
|
28
|
-
ElasticArSync::Elastic::Worker::IndexWorker.perform_async(
|
27
|
+
def document_sync_create(klass_str, record_id)
|
28
|
+
ElasticArSync::Elastic::Worker::IndexWorker.perform_async(klass_str, :index, record_id)
|
29
29
|
end
|
30
30
|
|
31
|
-
def document_sync_update(
|
32
|
-
ElasticArSync::Elastic::Worker::IndexWorker.perform_async(
|
31
|
+
def document_sync_update(klass_str, record_id)
|
32
|
+
ElasticArSync::Elastic::Worker::IndexWorker.perform_async(klass_str, :index, record_id)
|
33
33
|
end
|
34
34
|
|
35
|
-
def document_sync_delete(
|
36
|
-
ElasticArSync::Elastic::Worker::IndexWorker.perform_async(
|
35
|
+
def document_sync_delete(klass_str, record_id)
|
36
|
+
ElasticArSync::Elastic::Worker::IndexWorker.perform_async(klass_str, :delete, record_id)
|
37
37
|
end
|
38
38
|
|
39
39
|
def as_indexed_json(_option = {})
|
@@ -60,7 +60,7 @@ module ElasticArSync
|
|
60
60
|
|
61
61
|
# DBの内容をESのインデックスに同期する
|
62
62
|
def import_all_record(target_index: ,batch_size: 100)
|
63
|
-
ElasticArSync::Elastic::Worker::IndexImportWorker.perform_async(self, target_index, batch_size)
|
63
|
+
ElasticArSync::Elastic::Worker::IndexImportWorker.perform_async(self.to_s, target_index, batch_size)
|
64
64
|
end
|
65
65
|
|
66
66
|
# ダウンタイムなしでインデックスを切り替える
|
@@ -103,11 +103,11 @@ module ElasticArSync
|
|
103
103
|
"analyzer": {
|
104
104
|
"normal_ja_analyzer": {
|
105
105
|
"type": "custom",
|
106
|
-
"tokenizer": "
|
106
|
+
"tokenizer": "kuromoji_tokenizer",
|
107
107
|
"mode": "search",
|
108
108
|
"char_filter": [
|
109
|
-
"icu_normalizer",
|
110
|
-
"kuromoji_iteration_mark"
|
109
|
+
"icu_normalizer",
|
110
|
+
"kuromoji_iteration_mark"
|
111
111
|
],
|
112
112
|
"filter": [
|
113
113
|
"kuromoji_baseform",
|
@@ -148,12 +148,16 @@ module ElasticArSync
|
|
148
148
|
end
|
149
149
|
|
150
150
|
def current_index
|
151
|
-
|
151
|
+
__elasticsearch__.client.indices.get_alias(index: index_name).keys.first
|
152
152
|
end
|
153
153
|
|
154
154
|
def current_mapping
|
155
155
|
__elasticsearch__.client.indices.get_mapping[current_index]["mappings"]["_doc"]["properties"]
|
156
156
|
end
|
157
|
+
|
158
|
+
def current_settings
|
159
|
+
__elasticsearch__.client.indices.get_settings[current_index]
|
160
|
+
end
|
157
161
|
end
|
158
162
|
end
|
159
163
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: elastic_ar_sync
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.10
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- KitakatsuTed
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-05-12 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|