//使用RestHighLevelClient BulkRequest批量插入数据
@Test
public void createSubBankIndex(){
List details = logDetailMapper.getLogDetails();
//bulkRequest.timeout(“2m”);
DatabaseReader reader = null;
try {
Resource resource = new ClassPathResource(“GeoLite2-City.mmdb”);
InputStream file = resource.getInputStream();
reader = new DatabaseReader.Builder(file).build();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
if(null == reader)
return;
for(int i=0,len=details.size();i<len;){
int sz = len - i > 2000?2000: len - i;
List subBanks = details.subList(i, sz+i);
i += sz;
BulkRequest bulkRequest = new BulkRequest(“log_detail1104”, “log_detail”);
bulkRequest.timeout(TimeValue.timeValueMinutes(2));
IndexRequest indexRequest = new IndexRequest(“log_detail1104”, “log_detail”);
GeoLocation loc = new GeoLocation();
for(LogDetail b:subBanks){
GeoPoint gp = ip2Geo(reader,b.getIpAddress());
loc.setLat(gp.getLat());
loc.setLon(gp.getLon());
b.setLocation(loc);
//indexRequest.timeout(TimeValue.timeValueMinutes(2));
indexRequest.source(JSON.toJSONString(b), XContentType.JSON);
bulkRequest.add(indexRequest);
}
try {
highLevelClient.bulk(bulkRequest, RequestOptions.DEFAULT);
//highLevelClient.index(indexRequest, RequestOptions.DEFAULT);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
//将ip转换为地理位置信息
private GeoPoint ip2Geo(DatabaseReader reader,String ip){
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
最后
由于细节内容实在太多了,为了不影响文章的观赏性,只截出了一部分知识点大致的介绍一下,每个小节点里面都有更细化的内容!
小编准备了一份Java进阶学习路线图(Xmind)以及来年金三银四必备的一份《Java面试必备指南》
OGc3P-1711033100752)]
小编准备了一份Java进阶学习路线图(Xmind)以及来年金三银四必备的一份《Java面试必备指南》
[外链图片转存中…(img-qUw14R8x-1711033100752)]