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

谷粒商城 高级篇(一) --------- ElasticSearch 的简介与安装

目录

  • 一、简介
    • 基本概念
  • 二、Docker 安装 Es
  • 三、测试


一、简介

文档:https://www.elastic.co/cn/what-is/elasticsearch

全文搜索属于最常见的需求,开源的 Elasticsearch 是目前全文搜索引擎的首选。它可以快速地储存、搜索和分析海量数据。维基百科、Stack Overflow、Github 都采用它。

在这里插入图片描述
Elastic 的底层是开源库 Lucene。但是,你没法直接用 Lucene,必须自己写代码去调用它的接口。Elastic 是 Lucene 的封装,提供了 REST API 的操作接口,开箱即用。REST API:天然的跨平台。

官方文档:https://www.elastic.co/guide/en/elasticsearch/reference/current/index.html
官方中文:https://www.elastic.co/guide/cn/elasticsearch/guide/current/foreword_id.html

社区中文:

https://es.xiaoleilu.com/index.html
http://doc.codingdict.com/elasticsearch/0/

基本概念

在这里插入图片描述

Index (索引)

作为动词,相当于 MySQL 中的 insert
作为名词,相当于 MySQL 中的 Database

Type (类型)

在 Index (索引) 中,可以定义一个或多个类型。
类似于 MySQL 中的 Table,每一种类型的数据放在一起。

Document (文档)

保存在某个索引 (Index) 下,某种类型 (Type) 的一个数据 (Document) ,文档是JSON格式的,Document 就像是 MySQL 中的某个 Table 里面的内容。

倒排索引机制

在这里插入图片描述

二、Docker 安装 Es

1、下载镜像文件

docker pull elasticsearch:7.4.2 存储和检索数据
docker pull kibana:7.4.2 可视化检索数据

在这里插入图片描述
在这里插入图片描述

2、创建实例

ElasticSearch

mkdir -p /mydata/elasticsearch/config
mkdir -p /mydata/elasticsearch/data
echo "http.host: 0.0.0.0" >> /mydata/elasticsearch/config/elasticsearch.yml
chmod -R 777 /mydata/elasticsearch/  保证权限
docker run --name elasticsearch -p 9200:9200 -p 9300:9300 \
-e "discovery.type=single-node" \
-e ES_JAVA_OPTS="-Xms64m -Xmx512m" \
-v /mydata/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \
-v /mydata/elasticsearch/data:/usr/share/elasticsearch/data \
-v /mydata/elasticsearch/plugins:/usr/share/elasticsearch/plugins \
-d elasticsearch:7.4.2
free -m 可以查看虚拟机内存
docker logs 查看日志
docker ps -a 查看所有容器
docker ps 查看正在运行的容器
docker start 容器ID 开启容器

关于 docker run 与 docker start :

docker run相当于执行了两步操作:将镜像放入容器中 (docker create),然后将容器启动,使之变成运行时容器(docker start)。

docker start 的作用是:重新启动已存在的镜像。也就是说,如果使用这个命令,我们必须事先知道这个容器的ID,或者这个容器的名字,我们可以使用docker ps -a找到这个容器的信息。

以后再外面装好插件重启即可;

特别注意:

-e ES_JAVA_OPTS=“-Xms64m -Xmx256m” \ 测试环境下,设置 ES 的初始内存和最大内存,否则导致过大启动不了 ES

Kibana

docker run --name kibana -e ELASTICSEARCH_HOSTS=http://192.168.38.130:9200 -p 5601:5601 \
-d kibana:7.4.2

http://192.168.38.130:9200 一定改为自己虚拟机的地址

三、测试

浏览器访问虚拟机的 9200 端口,出现下面界面则访问成功
在这里插入图片描述
或者 postman

在这里插入图片描述

访问 Kibana 出现此界面则访问成功
在这里插入图片描述

相关文章:

  • mybatis的sql标签
  • 面试题-参加生日宴会的最多人数
  • 开发运维-常用远程桌面开源软件
  • 【JAVA】SrpingMVC(上)—— 注解请求与响应
  • ZZCMS201910代码审计
  • HTTPDNS
  • ApacheDBUtils的使用
  • 补涨行情的模式如何做?(几天几板模式)
  • 基于Levy飞行策略的改进樽海鞘群算法-附代码
  • 【CSDN高校社区无锡学院】# 新学期,新Flag # 开学季征文活动
  • Linux安装zlib、libpng、freetype给交叉编译工具链使用
  • 深度讲解指针的笔试题目
  • Python 环境安装系统教程——PyCharm
  • 都这麽大了还不快了解防火墙(1)?
  • Code For Better 谷歌开发者之声——谷歌Web工具包(GWT)
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 0基础学习移动端适配
  • CODING 缺陷管理功能正式开始公测
  • JavaScript函数式编程(一)
  • JAVA多线程机制解析-volatilesynchronized
  • mysql 5.6 原生Online DDL解析
  • node学习系列之简单文件上传
  • oschina
  • PAT A1120
  • PHP的类修饰符与访问修饰符
  • Promise初体验
  • 动态魔术使用DBMS_SQL
  • 使用common-codec进行md5加密
  • 我与Jetbrains的这些年
  • 用mpvue开发微信小程序
  • d²y/dx²; 偏导数问题 请问f1 f2是什么意思
  • PostgreSQL之连接数修改
  • #HarmonyOS:基础语法
  • $.ajax()方法详解
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (ibm)Java 语言的 XPath API
  • (二)JAVA使用POI操作excel
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (三)mysql_MYSQL(三)
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • .net core MVC 通过 Filters 过滤器拦截请求及响应内容
  • .net framwork4.6操作MySQL报错Character set ‘utf8mb3‘ is not supported 解决方法
  • .net mvc actionresult 返回字符串_.NET架构师知识普及
  • .net 流——流的类型体系简单介绍
  • .net 微服务 服务保护 自动重试 Polly
  • .NET连接MongoDB数据库实例教程
  • .NET值类型变量“活”在哪?
  • :O)修改linux硬件时间
  • [AIGC] Spring Interceptor 拦截器详解
  • [Big Data - Kafka] kafka学习笔记:知识点整理
  • [C#]C# winform实现imagecaption图像生成描述图文描述生成
  • [CareerCup][Google Interview] 实现一个具有get_min的Queue
  • [Golang]K-V存储引擎的学习 从零实现 (RoseDB mini版本)
  • [IT生活推荐]大家一起来玩游戏喽,来的都进!
  • [java]删除数组中的某一个元素