elastic_ar_sync 0.1.8 → 0.1.11
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 +10 -10
- 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: f5cef826fdd4d0f77f18b00c7c00378de1e6ea2f2ca053953d717a94ecf61c6e
|
4
|
+
data.tar.gz: c290bad31fa3e857541df0adadc254d174edd71c056063a91f780979f63dfb1f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 908ba38b2c30820c66b25a2526e329cbfc0299ad2765054d681377d433d6eb4edd0828847a2f7f24dd8f5bd38ccab6268da0d45025b21455f5fc5fcc1b2d6b3f
|
7
|
+
data.tar.gz: 75e1da2032a83e3e1ba2dd5387bff5bd16ecb605f09d0ce3c978f809652abf3517a5f071d9c6721bf9b2c184cb8b3b38c31548f6dfbd1b91dd29234c56e9be80
|
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
|
# ダウンタイムなしでインデックスを切り替える
|
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.11
|
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-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|