|
@@ -2,16 +2,26 @@ package com.vcarecity.publish.elastic.service.impl;
|
2
|
2
|
|
3
|
3
|
import com.fasterxml.jackson.core.type.TypeReference;
|
4
|
4
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
5
|
|
-import com.vcarecity.publish.entity.UnitAgencyMergeEntity;
|
|
5
|
+import com.vcarecity.elastic.util.AgencyPathUtil;
|
|
6
|
+import com.vcarecity.elastic.util.SnowFlake;
|
|
7
|
+import com.vcarecity.publish.elastic.entity.UnitAgencyDetailEntity;
|
6
|
8
|
import com.vcarecity.publish.elastic.service.ElasticUpdateService;
|
|
9
|
+import com.vcarecity.publish.entity.UnitAgencyMergeEntity;
|
|
10
|
+import com.vcarecity.publish.sql.service.AgencyService;
|
|
11
|
+import lombok.extern.slf4j.Slf4j;
|
|
12
|
+import org.elasticsearch.action.bulk.BulkRequest;
|
|
13
|
+import org.elasticsearch.action.bulk.BulkResponse;
|
|
14
|
+import org.elasticsearch.action.index.IndexRequest;
|
7
|
15
|
import org.elasticsearch.client.RequestOptions;
|
8
|
16
|
import org.elasticsearch.client.RestHighLevelClient;
|
|
17
|
+import org.elasticsearch.common.xcontent.XContentType;
|
9
|
18
|
import org.elasticsearch.index.query.QueryBuilders;
|
10
|
19
|
import org.elasticsearch.index.reindex.BulkByScrollResponse;
|
11
|
20
|
import org.elasticsearch.index.reindex.DeleteByQueryRequest;
|
12
|
21
|
import org.elasticsearch.index.reindex.UpdateByQueryRequest;
|
13
|
22
|
import org.elasticsearch.script.Script;
|
14
|
23
|
import org.elasticsearch.script.ScriptType;
|
|
24
|
+import org.springframework.cglib.beans.BeanCopier;
|
15
|
25
|
import org.springframework.stereotype.Service;
|
16
|
26
|
|
17
|
27
|
import java.io.IOException;
|
|
@@ -25,6 +35,7 @@ import java.util.Map;
|
25
|
35
|
* @author Kerry on 12/17/19
|
26
|
36
|
*/
|
27
|
37
|
|
|
38
|
+@Slf4j
|
28
|
39
|
@Service
|
29
|
40
|
public class ElasticUpdateServiceImpl implements ElasticUpdateService {
|
30
|
41
|
|
|
@@ -32,11 +43,15 @@ public class ElasticUpdateServiceImpl implements ElasticUpdateService {
|
32
|
43
|
|
33
|
44
|
private final RestHighLevelClient restHighLevelClient;
|
34
|
45
|
private final ObjectMapper objectMapper;
|
|
46
|
+ private final AgencyService agencyService;
|
35
|
47
|
|
36
|
48
|
public ElasticUpdateServiceImpl(RestHighLevelClient restHighLevelClient,
|
37
|
|
- ObjectMapper objectMapper) {
|
|
49
|
+ ObjectMapper objectMapper,
|
|
50
|
+ AgencyService agencyService) {
|
38
|
51
|
this.restHighLevelClient = restHighLevelClient;
|
39
|
52
|
this.objectMapper = objectMapper;
|
|
53
|
+ this.agencyService = agencyService;
|
|
54
|
+
|
40
|
55
|
}
|
41
|
56
|
|
42
|
57
|
|
|
@@ -62,85 +77,135 @@ public class ElasticUpdateServiceImpl implements ElasticUpdateService {
|
62
|
77
|
|
63
|
78
|
}
|
64
|
79
|
|
65
|
|
-
|
66
|
|
- private String getPainlessCode(Map<String, Object> params) {
|
67
|
|
- String[] items = new String[params.size()];
|
68
|
|
- int index = 0;
|
69
|
|
- for (String key : params.keySet()) {
|
70
|
|
- items[index++] = "ctx._source." + key + "=params." + key;
|
71
|
|
- }
|
72
|
|
- return String.join(";", items);
|
73
|
|
- }
|
74
|
|
-
|
75
|
|
-
|
76
|
80
|
@Override
|
77
|
|
- public void updateUnit(List<UnitAgencyMergeEntity> list) throws IOException {
|
|
81
|
+ public void handlerDataChange(String key, List<UnitAgencyMergeEntity> data) throws IOException {
|
78
|
82
|
List<UnitAgencyMergeEntity> updateList = new ArrayList<>();
|
79
|
83
|
List<Long> deleteId = new ArrayList<>();
|
80
|
|
- for (UnitAgencyMergeEntity uae : list) {
|
|
84
|
+ for (UnitAgencyMergeEntity uae : data) {
|
81
|
85
|
if (uae.getIsDeleted() == 1) {
|
82
|
86
|
deleteId.add(uae.getUnitId());
|
83
|
87
|
} else if (uae.getIsDeleted() == 0) {
|
84
|
88
|
updateList.add(uae);
|
85
|
89
|
}
|
86
|
90
|
}
|
87
|
|
- deleteById("unitId", deleteId);
|
|
91
|
+ // 先删除
|
|
92
|
+ deleteByQuery(key, deleteId);
|
88
|
93
|
if (updateList.isEmpty()) {
|
89
|
94
|
return;
|
90
|
95
|
}
|
91
|
|
- for (UnitAgencyMergeEntity entity : updateList) {
|
|
96
|
+ // 更新数据
|
|
97
|
+ List<UnitAgencyMergeEntity> addData = updateDataByQuery(key, updateList);
|
92
|
98
|
|
93
|
|
- Map<String, Object> map = objectMapper.convertValue(entity, new TypeReference<Map<String, Object>>() {
|
|
99
|
+ // 添加数据
|
|
100
|
+ addElasticData(addData);
|
|
101
|
+ }
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+ @Override
|
|
105
|
+ public void deleteByQuery(String key, List<Long> ids) throws IOException {
|
|
106
|
+ if (ids == null || ids.isEmpty()) {
|
|
107
|
+ return;
|
|
108
|
+ }
|
|
109
|
+ for (Long id : ids) {
|
|
110
|
+ DeleteByQueryRequest request = new DeleteByQueryRequest(INDEX);
|
|
111
|
+ request.setQuery(QueryBuilders.termQuery(key, id));
|
|
112
|
+ restHighLevelClient.deleteByQuery(request, RequestOptions.DEFAULT);
|
|
113
|
+ }
|
|
114
|
+ }
|
|
115
|
+
|
|
116
|
+ @Override
|
|
117
|
+ public List<UnitAgencyMergeEntity> updateDataByQuery(String key, List<UnitAgencyMergeEntity> data) throws IOException {
|
|
118
|
+ List<UnitAgencyMergeEntity> addList = new ArrayList<>();
|
|
119
|
+
|
|
120
|
+ for (UnitAgencyMergeEntity item : data) {
|
|
121
|
+
|
|
122
|
+ Map<String, Object> params = objectMapper.convertValue(item, new TypeReference<Map<String, Object>>() {
|
94
|
123
|
@Override
|
95
|
124
|
public Type getType() {
|
96
|
125
|
return super.getType();
|
97
|
126
|
}
|
98
|
127
|
});
|
99
|
128
|
|
100
|
|
- map.remove("unitId");
|
101
|
|
-
|
102
|
129
|
UpdateByQueryRequest request = new UpdateByQueryRequest(INDEX);
|
103
|
|
- request.setQuery(QueryBuilders.termQuery("unitId", entity.getUnitId()));
|
|
130
|
+ request.setQuery(QueryBuilders.termQuery(key, params.get(key)));
|
|
131
|
+
|
|
132
|
+ request.setScript(new Script(ScriptType.INLINE, "painless", getPainlessCode(params), params));
|
|
133
|
+
|
|
134
|
+ BulkByScrollResponse response = restHighLevelClient.updateByQuery(request, RequestOptions.DEFAULT);
|
|
135
|
+
|
|
136
|
+ logger.info("response:{}", response);
|
104
|
137
|
|
|
138
|
+ if (response.getUpdated() != 0L) {
|
|
139
|
+ addList.add(item);
|
|
140
|
+ }
|
105
|
141
|
}
|
|
142
|
+
|
|
143
|
+ return addList;
|
106
|
144
|
}
|
107
|
145
|
|
108
|
146
|
@Override
|
109
|
|
- public void updateAgency(List<UnitAgencyMergeEntity> list) throws IOException {
|
110
|
|
- List<UnitAgencyMergeEntity> updateList = new ArrayList<>();
|
111
|
|
- List<Long> deleteId = new ArrayList<>();
|
112
|
|
- for (UnitAgencyMergeEntity uae : list) {
|
113
|
|
- if (uae.getIsDeleted() == 1) {
|
114
|
|
- deleteId.add(uae.getAgencyId());
|
115
|
|
- } else if (uae.getIsDeleted() == 0) {
|
116
|
|
- updateList.add(uae);
|
117
|
|
- }
|
|
147
|
+ public void addElasticData(List<UnitAgencyMergeEntity> data) throws IOException {
|
|
148
|
+ if (data.isEmpty()) {
|
|
149
|
+ return;
|
118
|
150
|
}
|
119
|
|
- deleteById("agencyId", deleteId);
|
120
|
|
- list.clear();
|
121
|
|
- updateElasticData("agencyId", updateList);
|
122
|
|
- }
|
|
151
|
+ final BeanCopier beanCopier = BeanCopier.create(UnitAgencyMergeEntity.class, UnitAgencyDetailEntity.class, false);
|
|
152
|
+
|
|
153
|
+ List<Map<String, Object>> saveResult = new ArrayList<>(data.size());
|
|
154
|
+
|
|
155
|
+ for (UnitAgencyMergeEntity item : data) {
|
|
156
|
+ List<Integer> agencyIds = AgencyPathUtil.splitAgencyId(item.getAgencyPath());
|
|
157
|
+ List<String> agencyPathDetail = agencyService.getAgencyPathDetail(agencyIds);
|
123
|
158
|
|
|
159
|
+ UnitAgencyDetailEntity target = new UnitAgencyDetailEntity();
|
|
160
|
+ beanCopier.copy(item, target, null);
|
124
|
161
|
|
125
|
|
- private void updateElasticData(String key, List<UnitAgencyMergeEntity> list) throws IOException {
|
126
|
|
- if (list == null || list.isEmpty()) {
|
|
162
|
+ target.setAgencyDetail(String.join("", agencyPathDetail));
|
|
163
|
+
|
|
164
|
+ Map<String, Object> map = objectMapper.convertValue(target, new TypeReference<Map<String, Object>>() {
|
|
165
|
+ @Override
|
|
166
|
+ public Type getType() {
|
|
167
|
+ return super.getType();
|
|
168
|
+ }
|
|
169
|
+ });
|
|
170
|
+ final Map<String, Integer> queryMap = AgencyPathUtil.agencyPathQueryMap(agencyIds);
|
|
171
|
+ map.putAll(queryMap);
|
|
172
|
+
|
|
173
|
+ saveResult.add(map);
|
|
174
|
+
|
|
175
|
+ }
|
|
176
|
+ if (saveResult.isEmpty()) {
|
127
|
177
|
return;
|
128
|
178
|
}
|
129
|
|
- for (UnitAgencyMergeEntity item : list) {
|
130
|
|
- UpdateByQueryRequest request = new UpdateByQueryRequest(INDEX);
|
131
|
|
- request.setQuery(QueryBuilders.termQuery(key, item.getAgencyId()));
|
|
179
|
+ try {
|
|
180
|
+ BulkRequest bulkRequest = new BulkRequest();
|
|
181
|
+
|
|
182
|
+ for (Map<String, Object> val : saveResult) {
|
|
183
|
+ IndexRequest indexRequest = createIndexRequest(INDEX, val);
|
|
184
|
+ bulkRequest.add(indexRequest);
|
|
185
|
+ }
|
|
186
|
+ BulkResponse bulkResponse = restHighLevelClient.bulk(bulkRequest, RequestOptions.DEFAULT);
|
|
187
|
+ logger.info("bulk insert status {}", bulkResponse.status());
|
|
188
|
+ } catch (IOException e) {
|
|
189
|
+ e.printStackTrace();
|
132
|
190
|
}
|
|
191
|
+
|
133
|
192
|
}
|
134
|
193
|
|
135
|
|
- private void deleteById(String key, List<Long> deleteId) throws IOException {
|
136
|
|
- if (deleteId == null || deleteId.isEmpty()) {
|
137
|
|
- return;
|
138
|
|
- }
|
139
|
|
- for (Long id : deleteId) {
|
140
|
|
- DeleteByQueryRequest request = new DeleteByQueryRequest(INDEX);
|
141
|
|
- request.setQuery(QueryBuilders.termQuery(key, id));
|
142
|
|
- restHighLevelClient.deleteByQuery(request, RequestOptions.DEFAULT);
|
143
|
|
- }
|
|
194
|
+
|
|
195
|
+ private IndexRequest createIndexRequest(String index, Map<String, Object> value) {
|
|
196
|
+ IndexRequest indexRequest = new IndexRequest(index);
|
|
197
|
+ indexRequest.id(SnowFlake.nextId() + "");
|
|
198
|
+ indexRequest.source(value, XContentType.JSON);
|
|
199
|
+ return indexRequest;
|
144
|
200
|
}
|
145
|
201
|
|
|
202
|
+
|
|
203
|
+ private String getPainlessCode(Map<String, Object> params) {
|
|
204
|
+ String[] items = new String[params.size()];
|
|
205
|
+ int index = 0;
|
|
206
|
+ for (String key : params.keySet()) {
|
|
207
|
+ items[index++] = "ctx._source." + key + "=params." + key;
|
|
208
|
+ }
|
|
209
|
+ return String.join(";", items);
|
|
210
|
+ }
|
146
|
211
|
}
|