当前位置: 首页 > news >正文

网络服务商官方网站品牌网站运营

网络服务商官方网站,品牌网站运营,wordpress网页怎么上传,工业产品设计公司排名标签#xff1a;ElasticSearch8.Kibana8#xff1b; 一、简介 Elasticsearch是一个分布式、RESTful风格的搜索和数据分析引擎#xff0c;适用于各种数据类型#xff0c;数字、文本、地理位置、结构化数据、非结构化数据#xff1b; 在实际的工作中#xff0c;历经过Ela… 标签ElasticSearch8.Kibana8 一、简介 Elasticsearch是一个分布式、RESTful风格的搜索和数据分析引擎适用于各种数据类型数字、文本、地理位置、结构化数据、非结构化数据 在实际的工作中历经过Elasticsearch从6.0到7.0的版本升级而这次SpringBoot3和ES8.0的集成虽然脚本的语法变化很小但是Java客户端的API语法变化很大 二、环境搭建 1、下载安装包 需要注意的是这些安装包的版本要选择对应的不然容易出问题 软件包elasticsearch-8.8.2-darwin-x86_64.tar.gz 分词器工具elasticsearch-analysis-ik-8.8.2.zip 可视化工具kibana-8.8.2-darwin-x86_64.tar.gz2、服务启动 不论是ES还是Kibana在首次启动后会初始化很多配置文件可以根据自己的需要做相关的配置调整比如常见的端口调整资源占用安全校验等 1、启动ES elasticsearch-8.8.2/bin/elasticsearch本地访问localhost:92002、启动Kibana kibana-8.8.2/bin/kibana本地访问http://localhost:5601# 3、查看安装的插件 http://localhost:9200/_cat/plugins - analysis-ik 8.8.2三、工程搭建 1、工程结构 2、依赖管理 在starter-elasticsearch组件中实际上依赖的是elasticsearch-java组件的8.7.1版本 dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-elasticsearch/artifactIdversion${spring-boot.version}/version /dependency3、配置文件 在上面环境搭建的过程中已经禁用了用户和密码的登录验证配置ES服务地址即可 spring:# ElasticSearch配置elasticsearch:uris: localhost:9200四、基础用法 1、实体类 通过Document和Field注解描述ES索引结构的实体类注意这里JsonIgnoreProperties注解解决索引中字段和实体类非一一对应的而引起的JSON解析问题 JsonIgnoreProperties(ignoreUnknown true) Document(indexName contents_index, createIndex false) public class ContentsIndex implements Serializable {private static final long serialVersionUID1L;Field(type FieldType.Integer)private Integer id;Field(type FieldType.Keyword)private String title;Field(type FieldType.Keyword)private String intro;Field(type FieldType.Text)private String content;Field(type FieldType.Integer)private Integer createId;Field(type FieldType.Keyword)private String createName;Field(type FieldType.Date,format DateFormat.date_hour_minute_second)private Date createTime; }2、初始化索引 基于ElasticsearchTemplate类和上述实体类实现索引结构的初始化并且将tb_contents表中的数据同步到索引中最后通过ID查询一条测试数据 Service public class ContentsIndexService {private static final Logger log LoggerFactory.getLogger(ContentsIndexService.class);Resourceprivate ContentsService contentsService ;Resourceprivate ElasticsearchTemplate template ;/*** 初始化索引结构和数据*/public void initIndex (){// 处理索引结构IndexOperations indexOps template.indexOps(ContentsIndex.class);if (indexOps.exists()){boolean delFlag indexOps.delete();log.info(contents_index existsdelete:{},delFlag);indexOps.createMapping(ContentsIndex.class);} else {log.info(contents_index not exists);indexOps.createMapping(ContentsIndex.class);}// 同步数据库表记录ListContents contentsList contentsService.queryAll();if (contentsList.size() 0){ListContentsIndex contentsIndexList new ArrayList() ;contentsList.forEach(contents - {ContentsIndex contentsIndex new ContentsIndex() ;BeanUtils.copyProperties(contents,contentsIndex);contentsIndexList.add(contentsIndex);});template.save(contentsIndexList);}// ID查询ContentsIndex contentsIndex template.get(10,ContentsIndex.class);log.info(contents-index-10:{},contentsIndex);} }3、仓储接口 继承ElasticsearchRepository接口可以对ES这种特定类型的存储库进行通用增删改查操作在测试类中对该接口的方法进行测试 // 1、接口定义 public interface ContentsIndexRepository extends ElasticsearchRepositoryContentsIndex,Long { }// 2、接口测试 public class ContentsIndexRepositoryTest {Autowiredprivate ContentsIndexRepository contentsIndexRepository;Testpublic void testAdd (){// 单个新增contentsIndexRepository.save(buildOne());// 批量新增contentsIndexRepository.saveAll(buildList()) ;}Testpublic void testUpdate (){// 根据ID查询后再更新OptionalContentsIndex contentsOpt contentsIndexRepository.findById(14L);if (contentsOpt.isPresent()){ContentsIndex contentsId contentsOpt.get();System.out.println(id14:contentsId);contentsId.setContent(update-content);contentsId.setCreateTime(new Date());contentsIndexRepository.save(contentsId);}}Testpublic void testQuery (){// 单个ID查询OptionalContentsIndex contentsOpt contentsIndexRepository.findById(1L);if (contentsOpt.isPresent()){ContentsIndex contentsId1 contentsOpt.get();System.out.println(id1:contentsId1);}// 批量ID查询IteratorContentsIndex contentsIterator contentsIndexRepository.findAllById(Arrays.asList(10L,12L)).iterator();while (contentsIterator.hasNext()){ContentsIndex contentsIndex contentsIterator.next();System.out.println(idcontentsIndex.getId():contentsIndex);}}Testpublic void testDelete (){contentsIndexRepository.deleteById(15L);contentsIndexRepository.deleteById(16L);} }4、查询语法 无论是ElasticsearchTemplate类还是ElasticsearchRepository接口都是对ES常用的简单功能进行封装在实际使用时复杂的查询语法还是依赖ElasticsearchClient和原生的API封装 这里主要演示七个查询方法主要涉及ID查询字段匹配组合与范围查询分页与排序分组统计最大值查询和模糊匹配更多的查询API还是要多看文档中的案例才行 public class ElasticsearchClientTest {Autowiredprivate ElasticsearchClient client ;Testpublic void testSearch1 () throws IOException {// ID查询GetResponseContentsIndex resp client.get(getReq -getReq.index(contents_index).id(7), ContentsIndex.class);if (resp.found()){ContentsIndex contentsIndex resp.source() ;System.out.println(contentsIndex-7contentsIndex);}}Testpublic void testSearch2 () throws IOException {// 指定字段匹配SearchResponseContentsIndex resp client.search(searchReq - searchReq.index(contents_index).query(query - query.match(field - field.field(createName).query(张三))),ContentsIndex.class);printResp(resp);}Testpublic void testSearch3 () throws IOException {// 组合查询姓名和时间范围Query byName MatchQuery.of(field - field.field(createName).query(王五))._toQuery();Query byTime RangeQuery.of(field - field.field(createTime).gte(JsonData.of(2023-07-10T00:00:00)).lte(JsonData.of(2023-07-12T00:00:00)))._toQuery();SearchResponseContentsIndex resp client.search(searchReq - searchReq.index(contents_index).query(query - query.bool(boolQuery - boolQuery.must(byName).must(byTime))),ContentsIndex.class);printResp(resp);}Testpublic void testSearch4 () throws IOException {// 排序和分页在14条数据中根据ID倒序排列从第5条往后取4条数据SearchResponseContentsIndex resp client.search(searchReq - searchReq.index(contents_index).from(5).size(4).sort(sort - sort.field(sortField - sortField.field(id).order(SortOrder.Desc))),ContentsIndex.class);printResp(resp);}Testpublic void testSearch5 () throws IOException {// 根据createId分组统计SearchResponseContentsIndex resp client.search(searchReq - searchReq.index(contents_index).aggregations(createIdGroup,agg - agg.terms(term - term.field(createId))),ContentsIndex.class);Aggregate aggregate resp.aggregations().get(createIdGroup);LongTermsAggregate termsAggregate aggregate.lterms();BucketsLongTermsBucket buckets termsAggregate.buckets();for (LongTermsBucket termsBucket : buckets.array()) {System.out.println(termsBucket.key() : termsBucket.docCount());}}Testpublic void testSearch6 () throws IOException {// 查询最大的IDSearchResponseContentsIndex resp client.search(searchReq - searchReq.index(contents_index).aggregations(maxId,agg - agg.max(field - field.field(id))),ContentsIndex.class);for (Map.EntryString, Aggregate entry : resp.aggregations().entrySet()){System.out.println(entry.getKey():entry.getValue().max().value());}}Testpublic void testSearch7 () throws IOException {// 模糊查询title字段允许1个误差Query byContent FuzzyQuery.of(field - field.field(title).value(设计).fuzziness(1))._toQuery();SearchResponseContentsIndex resp client.search(searchReq - searchReq.index(contents_index).query(byContent),ContentsIndex.class);printResp(resp);}private void printResp (SearchResponseContentsIndex resp){TotalHits total resp.hits().total();System.out.println(totaltotal);ListHitContentsIndex hits resp.hits().hits();for (HitContentsIndex hit: hits) {ContentsIndex contentsIndex hit.source();System.out.println(hit.id()contentsIndex);}} }五、参考源码 文档仓库 https://gitee.com/cicadasmile/butte-java-note源码仓库 https://gitee.com/cicadasmile/butte-spring-parent
http://www.w-s-a.com/news/7859/

相关文章:

  • 哈尔滨网站运营服务商制作外贸网站公司
  • 个人网站需要备案宁波网站推广工具
  • 苏州建设银行网站首页wordpress修改密码
  • 网站建设员工技能要求网站制作简单协议
  • 没有ipc备案的网站wordpress isux主题
  • 清远做网站电子商务网站建设需要的语言及特点6
  • 万州那家做网站c语言基础知识入门
  • 齐河网站建设公司价格网站建设包括什么
  • 论坛网站开发费用怎么把文件放到网站的根目录
  • 海南省零售户电商网站官渡区住房和城乡建设局网站
  • 怎么找淘宝客网站最新军事战况
  • 缺乏门户网站建设网页设计与制作项目教程第二版
  • 手机网站横竖屏一般做建设的是什么公司
  • 免费网站建设无广告网站开发 华景新城
  • 湖州网站制作报价西安网站开发有哪些公司
  • google 浏览器开源seo软件
  • 网站空间是什么意思自己怎样建设网站
  • 国外家装设计网站如何做软件开发
  • 凡科建站登录官网当当网网站建设策划书
  • 网站百度屏蔽关键词杭州排名优化公司
  • h5响应式网站模板下载wordpress鼠标指针
  • 摄影作品投稿网站目前最好的引流推广方法
  • 资源站源码永久dede网站搬家 空间转移的方法
  • 网站建设销售的技巧话语it培训机构
  • 自建本地网站服务器wordpress南充房产网最新楼盘最近房价
  • 郑州代做网站天津哪里能做网站
  • 网站如何做排名网站建设项目的工作分解
  • 洛阳网络建站公司网站开发主流语言
  • 广州各区正在进一步优化以下措施seo值是什么意思
  • 滨州建网站公司京东云 wordpress