|
@@ -55,16 +55,9 @@ import com.alibaba.otter.canal.client.adapter.es.core.support.ESBulkRequest;
|
|
public class ESConnection {
|
|
public class ESConnection {
|
|
|
|
|
|
private static final Logger logger = LoggerFactory.getLogger(ESConnection.class);
|
|
private static final Logger logger = LoggerFactory.getLogger(ESConnection.class);
|
|
-
|
|
|
|
- public enum ESClientMode {
|
|
|
|
- TRANSPORT, REST
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
private ESClientMode mode;
|
|
private ESClientMode mode;
|
|
-
|
|
|
|
@SuppressWarnings("deprecation")
|
|
@SuppressWarnings("deprecation")
|
|
private TransportClient transportClient;
|
|
private TransportClient transportClient;
|
|
-
|
|
|
|
private RestHighLevelClient restHighLevelClient;
|
|
private RestHighLevelClient restHighLevelClient;
|
|
|
|
|
|
public ESConnection(String[] hosts, Map<String, String> properties, ESClientMode mode) throws UnknownHostException{
|
|
public ESConnection(String[] hosts, Map<String, String> properties, ESClientMode mode) throws UnknownHostException{
|
|
@@ -86,9 +79,10 @@ public class ESConnection {
|
|
if (StringUtils.isNotEmpty(nameAndPwd) && nameAndPwd.contains(":")) {
|
|
if (StringUtils.isNotEmpty(nameAndPwd) && nameAndPwd.contains(":")) {
|
|
String[] nameAndPwdArr = nameAndPwd.split(":");
|
|
String[] nameAndPwdArr = nameAndPwd.split(":");
|
|
final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
|
|
final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
|
|
- credentialsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(nameAndPwdArr[0],
|
|
|
|
- nameAndPwdArr[1]));
|
|
|
|
- restClientBuilder.setHttpClientConfigCallback(httpClientBuilder -> httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider));
|
|
|
|
|
|
+ credentialsProvider.setCredentials(AuthScope.ANY,
|
|
|
|
+ new UsernamePasswordCredentials(nameAndPwdArr[0], nameAndPwdArr[1]));
|
|
|
|
+ restClientBuilder.setHttpClientConfigCallback(
|
|
|
|
+ httpClientBuilder -> httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider));
|
|
}
|
|
}
|
|
restHighLevelClient = new RestHighLevelClient(restClientBuilder);
|
|
restHighLevelClient = new RestHighLevelClient(restClientBuilder);
|
|
}
|
|
}
|
|
@@ -143,6 +137,78 @@ public class ESConnection {
|
|
return mappingMetaData;
|
|
return mappingMetaData;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ // ------ get/set ------
|
|
|
|
+ public ESClientMode getMode() {
|
|
|
|
+ return mode;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public void setMode(ESClientMode mode) {
|
|
|
|
+ this.mode = mode;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public TransportClient getTransportClient() {
|
|
|
|
+ return transportClient;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public void setTransportClient(TransportClient transportClient) {
|
|
|
|
+ this.transportClient = transportClient;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public RestHighLevelClient getRestHighLevelClient() {
|
|
|
|
+ return restHighLevelClient;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public void setRestHighLevelClient(RestHighLevelClient restHighLevelClient) {
|
|
|
|
+ this.restHighLevelClient = restHighLevelClient;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ private HttpHost createHttpHost(String uriStr) {
|
|
|
|
+ URI uri = URI.create(uriStr);
|
|
|
|
+ if (!org.springframework.util.StringUtils.hasLength(uri.getUserInfo())) {
|
|
|
|
+ return HttpHost.create(uri.toString());
|
|
|
|
+ }
|
|
|
|
+ try {
|
|
|
|
+ return HttpHost.create(new URI(uri
|
|
|
|
+ .getScheme(), null, uri.getHost(), uri.getPort(), uri.getPath(), uri.getQuery(), uri.getFragment())
|
|
|
|
+ .toString());
|
|
|
|
+ } catch (URISyntaxException ex) {
|
|
|
|
+ throw new IllegalStateException(ex);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public enum ESClientMode {
|
|
|
|
+ TRANSPORT, REST
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public static class ES7xBulkResponse implements ESBulkRequest.ESBulkResponse {
|
|
|
|
+
|
|
|
|
+ private BulkResponse bulkResponse;
|
|
|
|
+
|
|
|
|
+ public ES7xBulkResponse(BulkResponse bulkResponse){
|
|
|
|
+ this.bulkResponse = bulkResponse;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean hasFailures() {
|
|
|
|
+ return bulkResponse.hasFailures();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void processFailBulkResponse(String errorMsg) {
|
|
|
|
+ for (BulkItemResponse itemResponse : bulkResponse.getItems()) {
|
|
|
|
+ if (!itemResponse.isFailed()) {
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if (itemResponse.getFailure().getStatus() == RestStatus.NOT_FOUND) {
|
|
|
|
+ logger.error(itemResponse.getFailureMessage());
|
|
|
|
+ } else {
|
|
|
|
+ throw new RuntimeException(errorMsg + itemResponse.getFailureMessage());
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
public class ES7xIndexRequest implements ESBulkRequest.ESIndexRequest {
|
|
public class ES7xIndexRequest implements ESBulkRequest.ESIndexRequest {
|
|
|
|
|
|
private IndexRequestBuilder indexRequestBuilder;
|
|
private IndexRequestBuilder indexRequestBuilder;
|
|
@@ -443,71 +509,4 @@ public class ESConnection {
|
|
this.bulkRequest = bulkRequest;
|
|
this.bulkRequest = bulkRequest;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
-
|
|
|
|
- public static class ES7xBulkResponse implements ESBulkRequest.ESBulkResponse {
|
|
|
|
-
|
|
|
|
- private BulkResponse bulkResponse;
|
|
|
|
-
|
|
|
|
- public ES7xBulkResponse(BulkResponse bulkResponse){
|
|
|
|
- this.bulkResponse = bulkResponse;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- @Override
|
|
|
|
- public boolean hasFailures() {
|
|
|
|
- return bulkResponse.hasFailures();
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- @Override
|
|
|
|
- public void processFailBulkResponse(String errorMsg) {
|
|
|
|
- for (BulkItemResponse itemResponse : bulkResponse.getItems()) {
|
|
|
|
- if (!itemResponse.isFailed()) {
|
|
|
|
- continue;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- if (itemResponse.getFailure().getStatus() == RestStatus.NOT_FOUND) {
|
|
|
|
- logger.error(itemResponse.getFailureMessage());
|
|
|
|
- } else {
|
|
|
|
- throw new RuntimeException(errorMsg + itemResponse.getFailureMessage());
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- // ------ get/set ------
|
|
|
|
- public ESClientMode getMode() {
|
|
|
|
- return mode;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- public void setMode(ESClientMode mode) {
|
|
|
|
- this.mode = mode;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- public TransportClient getTransportClient() {
|
|
|
|
- return transportClient;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- public void setTransportClient(TransportClient transportClient) {
|
|
|
|
- this.transportClient = transportClient;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- public RestHighLevelClient getRestHighLevelClient() {
|
|
|
|
- return restHighLevelClient;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- public void setRestHighLevelClient(RestHighLevelClient restHighLevelClient) {
|
|
|
|
- this.restHighLevelClient = restHighLevelClient;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
- private HttpHost createHttpHost(String uriStr) {
|
|
|
|
- URI uri = URI.create(uriStr);
|
|
|
|
- if (!org.springframework.util.StringUtils.hasLength(uri.getUserInfo())) {
|
|
|
|
- return HttpHost.create(uri.toString());
|
|
|
|
- }
|
|
|
|
- try {
|
|
|
|
- return HttpHost.create(new URI(uri.getScheme(), null, uri.getHost(), uri.getPort(), uri.getPath(),
|
|
|
|
- uri.getQuery(), uri.getFragment()).toString());
|
|
|
|
- } catch (URISyntaxException ex) {
|
|
|
|
- throw new IllegalStateException(ex);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
}
|
|
}
|