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

java web开发网站开发浙江网络推广

java web开发网站开发,浙江网络推广,wordpress 主题 html5 左右滑动切换文章,中国互联网协会副理事长目录 ElasticSearch 介绍 安装 安装kibana ES客户端安装 头文件包含和编译时链接库 ES核心概念 索引(Index) 类型(Type) 字段(Field) 映射(mapping) 文档(document) ES对比MySQL Kibana访问ES测试 创建索引库 新增数据 查看并搜索数据 删除索引 ES…

目录

ElasticSearch

介绍

安装

安装kibana

ES客户端安装

 头文件包含和编译时链接库

ES核心概念

索引(Index)

类型(Type)

字段(Field)

映射(mapping)

文档(document)

ES对比MySQL

Kibana访问ES测试

创建索引库

新增数据

查看并搜索数据

删除索引

ES客户端接口介绍

ES二次封装(elasticSearch.hpp)

Json序列化

Json反序列化

创建索引(库)

插入数据

删除数据

数据搜索(查询)

二次封装测试

ES客户端操作句柄获取封装

cpp-httplib

介绍

安装

头文件和链接库

类于接口介绍

HTTP请求类

HTTP应答类

HTTP服务器类

HTTP客户端类

使用样例

websocketpp

Websocket协议介绍

Websocketpp介绍

WebSocketpp安装

类与接口

日志等级

状态码

数据帧类型

消息缓冲区

HTTP请求解析

connect连接后的相关操作(对请求进行响应)

服务器

endpoint(服务端/客户端的管理)

redis

介绍

安装

头文件包含和编译时链接库

接口介绍

Redis++客户端操作句柄获取封装


本章主要是学习和使用本项目中所需使用到的一些框架。

ElasticSearch

介绍

ElasticSearch,简称ES,是一个开源分布式搜索引擎。

它的特点有:分布式、零配置、自动发现、索引自动分片、索引副本机制、restful风格接口、多数据源、自动搜索负载等。

ES是面向文档的,意味着它可以存储整个对象或文档。

它不仅仅是存储,还会索引每个文档的内容,使之可以被搜索。

在ES中,可以对文档进行索引、搜索、排序、过滤。

安装

# 添加仓库秘钥 
wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add -# 添加镜像源仓库 
echo "deb https://artifacts.elastic.co/packages/7.x/apt stable main" | sudo tee /etc/apt/sources.list.d/elasticsearch.list # 更新软件包列表 
sudo apt update # 安装es 
sudo apt-get install elasticsearch=7.17.21 # 启动es 
sudo systemctl start elasticsearch # 安装ik分词器插件 
sudo /usr/share/elasticsearch/bin/elasticsearch-plugin install 
https://get.infini.cloud/elasticsearch/analysis-ik/7.17.21

启动ES报错:

解决办法:

调整ES虚拟内存,虚拟内存默认最大映射数为65530,无法满足ES系统要求, 需要调整为262144以上。

sudo sysctl -w vm.max_map_count=262144

在 /etc/elasticsearch/jvm.options中新增:

再次启动ES:成功。

但是我自己重新弄的时候,一直启动失败,后续查看日志发现:

sudo vim /var/log/elasticsearch/elasticsearch.log

前面下载的分词器,和当前版本不兼容(我的ES升级了,所以不兼容),于是寻找解决方案:删除旧版本分词器,下载与当前elasticsearch匹配的分词器:

sudo rm -rf /usr/share/elasticsearch/plugins/analysis-iksudo /usr/share/elasticsearch/bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.17.25/elasticsearch-analysis-ik-7.17.25.zipsudo systemctl restart elasticsearch.service

此时才完美解决。

验证ES是否安装启动成功:

 curl -X GET "http://localhost:9200/"

设置外网访问,如果新配置完成的话,默认只能在本机进行访问:

 sudo vim /etc/elasticsearch/elasticsearch.yml

此时用浏览器访问 "localhost:9200":

安装kibana

 Kibana 是一个开源的数据可视化工具,专门为 Elasticsearch 设计。它提供了一个用户友好的界面,用于搜索、查看和分析存储在 Elasticsearch 中的数据。Kibana 通常与 Elasticsearch 一起使用,是 Elastic Stack(以前称为 ELK Stack,包括 Elasticsearch、Logstash 和 Kibana)的核心组件之一。

在浏览器上访问:"localhost:5601"

命令安装:

sudo apt install kibana配置 Kibana(可选): 
根据需要配置 Kibana。配置文件通常位于 /etc/kibana/kibana.yml。可能需要
设置如服务器地址、端口、Elasticsearch URL 等。 
sudo vim /etc/kibana/kibana.yml  
例如,你可能需要设置 Elasticsearch 服务的 URL: 大概32行左右 
elasticsearch.host: "http://localhost:9200"

ES客户端安装

sudo apt-get install libmicrohttpd-dev # 克隆代码 
git clone https://github.com/seznam/elasticlient # 切换目录 
cd elasticlient # 更新子模块 
git submodule update --init --recursive # 编译代码 
mkdir build 
cd build 
cmake .. 
make # 安装 
make install # make的时候编译出错,这是子模块googletest没有编译安装 
# 解决: 手动安装子模块
cd ../external/googletest/ 
mkdir cmake && cd cmake/ 
cmake -DCMAKE_INSTALL_PREFIX=/usr .. 
make && sudo make install # 安装好了 再次 cmake即可

 头文件包含和编译时链接库

头文件

#include <cpr/response.h> 
#include <elasticlient/client.h>

库:

-lcpr -lelasticlient

ES核心概念

索引(Index)

一个索引就是一个拥有几分相似特征的文档的集合。

比如说,你可以有一个客户数据 的索引,一个产品目录的索引,还有一个订单数据的索引。

一个索引由一个名字来标 识(必须全部是小写字母的),并且当我们要对应于这个索引中的文档进行索引、搜索、 更新和删除的时候,都要使用到这个名字。

类型(Type)

在一个索引中,你可以定义一种或多种类型。

一个类型是你的索引的一个逻辑上的分 类/分区,其语义完全由你来定。

通常,会为具有一组共同字段的文档定义一个类型。

比如说,我们假设你运营一个博客平台并且将你所有的数据存储到一个索引中。在这 个索引中,你可以为用户数据定义一个类型,为博客数据定义另一个类型,为评论数 据定义另一个类型......

字段(Field)

分类类型备注

字符串

text、keyword

text会被分词生成索引。

keyword不会被分词生成索引,只能精确搜索。

整形integer、long、short、byte
浮点double、float
逻辑booleantrue 或者 false
日期date、date_nanos“2018-01-13” 或 “2018-01-13 12:10:30” 或者时间戳,即1970到现在的秒数/毫秒数
二进制binary二进制通常只存储,不索引。
范围range

映射(mapping)

映射是在处理数据的方式和规则方面做一些限制,如某个字段的数据类型、默认值、 分析器、是否被索引等等。

其它就是处理es里面数据 的一些使用规则设置也叫做映射,按着最优规则处理数据对性能提高很大,因此才需要建立映射,并且需要思考如何建立映射才能对性能更好。

名称数值备注
enabledtrue(默认)、false是否仅作存储,不做搜索和分析。
indextrue(默认)、false是否构建倒排锁芯(决定了是否分词,是否被索引)。
index_option
dynamictrue(默认)、false控制mapping的自动更新。
doc_valuetrue(默认)、false是否开启doc_value,用户聚合和排序分析,分词字段不能使用。
fielddata"fielddata" :  {"format" : "disabled"}

是否为text类型启动fielddata,实现排序和 聚合分析。

针对分词字段,参与排序或聚合时能提高性 能。

不分词字段统一建议使用doc_value。

storetrue、false(默认)

是否单独设置此字段的是否存储,储而从 _source 字段中分离。

只能搜索,不能获取值。

coercetrue(默认)、false

是否开启自动数据类型转换功能。

比如:字符串转数字,浮点转整型

analyzer"analyzer" : "ik"指定分词器,默认分词器是standard analyzer
boost"boost" : 1.23字段级别的分数加权,默认值是1.0
fields

"fields" : {

        "raw" : {

                "type":

                "text",

                "index":

              "not_analyzed",

        }

}

对一个字段提供多种索引模式。

同一个字段的值,一个分词,一个不分词。

data_detectiontrue(默认)、false是否自动识别日期类型

文档(document)

一个文档是一个可被索引的基础信息单元。

比如,你可以拥有某一个客户的文档,某 一个产品的一个文档或者某个订单的一个文档。

文档以JSON(Javascript Object Notation)格式来表示,而JSON是一个到处存在的互联网数据交互格式。

在一个 index/type 里面,你可以存储任意多的文档。

一个文档必须被索引或者赋予一个索引 的type。

ES对比MySQL

MySQLES说明
DatabaseIndex最顶层的逻辑容器。
TableType (ES 7.x之后)存储结构化数据的单元。
RowDocument一条记录。
ColumnField数据字段。
SchemaMapping定义数据结构。
Index(索引)Inverted Index加速查询的数据结构。
SQLQuery DSL查询语言。
Primary Key_id唯一标识符。
分库分表Shard数据分片。
主从复制Replica Shard数据复制和高可用性。
事务版本控制数据一致性机制。
全文搜索核心功能ES 专为全文搜索设计,功能更强大。

Kibana访问ES测试

创建索引库

POST /user/_doc 
{ "settings" : { "analysis" : { "analyzer" : { "ik" : { "tokenizer" : "ik_max_word" } } } }, "mappings" : { "dynamic" : true, "properties" : { "nickname" : { "type" : "text","analyzer" : "ik_max_word" }, "user_id" : { "type" : "keyword", "analyzer" : "standard" }, "phone" : { "type" : "keyword", "analyzer" : "standard" }, "description" : { "type" : "text", "enabled" : false }, "avatar_id" : { "type" : "keyword" ,"enabled" : false } } } 
}

新增数据

POST /user/_doc/_bulk 
{"index":{"_id":"1"}} 
{"user_id" : "USER4b862aaa-2df8654a-7eb4bb65e3507f66","nickname" : "昵称1","phone" : "手机号1","description" : "签名1","avatar_id" : "头像1"} 
{"index":{"_id":"2"}} 
{"user_id" : "USER14eeeaa5-442771b9-0262e455e4663d1d","nickname" : "昵称2","phone" : "手机号2","description" : "签名2","avatar_id" : "头像2"} 
{"index":{"_id":"3"}} 
{"user_id" : "USER484a6734-03a124f0-996c169dd05c1869","nickname" : "昵称3","phone" : "手机号3","description" : "签名3","avatar_id" : "头像3"} 
{"index":{"_id":"4"}} 
{"user_id" : "USER186ade83-4460d4a6-8c08068f83127b5d","nickname" : "昵称4","phone" : "手机号4","des
http://www.dtcms.com/wzjs/221767.html

相关文章:

  • 网站开发 前端修改微信投放广告多少钱
  • 做网站公司怎么赚钱整站优化 快速排名
  • 网站建设 岗位最近发生的热点新闻事件
  • 广告投放网站平台广州做网站的公司哪家好
  • 长春网站建设哪个公司好做网站的网络公司
  • 免费注册网站怎么做链接seo工资一般多少
  • 推荐一个做健身餐的网站南宁优化网站网络服务
  • 电信网站开发语言主要用什么企拓客软件怎么样
  • 网站弹窗怎么做郑州好的seo外包公司
  • div css网站模块百度推广二级代理商
  • 主机做网站工具网络营销环境分析主要包括
  • 免费logo设计自动生成器优化大师百科
  • 泰州建设局网站安监站通报四川seo哪里有
  • 苏州新区网站制作惠州seo优化服务
  • 坪山网站建设哪家公司靠谱重庆森林电影高清在线观看
  • 免费加入微商代理优化seo哪家好
  • 手机网站开发人员工具天津百度seo排名优化
  • 兰州做网站开发百度公司电话是多少
  • 网站建设提供源代码有什么用2023年5月最新疫情
  • 建设机械网站方案设计免费发布外链
  • 哪个网站做的简历比较好宁夏百度推广代理商
  • 建网站报价 优帮云怎么制作链接网页
  • 政府部门网站模板邯郸网站优化公司
  • 网站建设发票 税率安卓手机优化软件哪个好
  • 湘潭什么网站做c1题目企业网站多少钱一年
  • 怎么做网站的icp备案信息seo行业岗位
  • 给别人做网站收8000贵不贵奶茶网络营销策划方案
  • 拓普网站建设自己建网站需要钱吗
  • 有没有小学生做兼职的网站营销型网站的特点
  • 温州做外贸网站设计竞价网站