1.是什么?
分布式的數據檢索分析數據庫.
2.干什么?
存儲和檢索數據信息
3.跟其他數據庫的區別.
包含了多庫多表跨字段的聯想查詢.可用于典型的 猜你喜歡 類似的關聯性分析.有一個關聯評估權重和關聯信息的分組功能.是大數據獲取有效數據,進行預測的基礎.這是其他數據庫沒有的特性.
另外其分布式和默認對所有字段索引的屬性使其在PB級別的數據量下也可以快速響應檢索結果
4.如何使用?
java的庫和rest風格的接口
PHP或者非java語言的應用主要是依賴第二種
PHP可以引入官方php庫,其實質主要是curl請求elasticsearch提供的接口.
有兩種請求方式:一種是簡單url,動作和參數都在url中體現,另一種是在body中體現.
5.概念
index? ? 索引\[相當于數據庫\]: 數據存儲的地方??
type? ? 類型\[相當于表\]: 相同結構的數據的集合
document? ? 文檔\[相當于表中的記錄\]: 結構化的數據記錄
6.具體使用
資源地址: 格式 /\_index/\_type/{\_id}? 其中\_id 唯一標識一條文檔
操作方式:
存在:開放的接口是通過head方法請求驗證
curl -i -XHEAD[http://localhost:9200/website/blog/123](http://localhost:9200/website/blog/123)
但建議用查詢GET,替代HEAD
增:
新增es自然生產\_id的文檔記錄
PUT /{index}/{type}/{id}
{
? "field": "value",
? ...[elastic-search](elastic-search.md)
}
響應:es創建\_id的新建索引信息,自動生成的ID有22個字符長,URL-safe, Base64-encoded string universally unique identifiers, 或者叫 UUIDs。
{
? ?"\_index":? ? "website",
? ?"\_type":? ? ?"blog",
? ?"\_id":? ? ? ?"wM0OSFhDQXGZAWDf0-drSA",
? ?"\_version":? 1,
? ?"created":? ?true
}
刪:
刪除指定\_id的文檔
DELETE /website/blog/123
響應
{
? "found" :? ? true, //成功返回200,未找到返回404
? "\_index" :? ?"website",
? "\_type" :? ? "blog",
? "\_id" :? ? ? "123",
? "\_version" : 3, //任何操作都會導致版本增加,這是用來指導集群節點能正確處理和響應的機制.可能有鎖的機制避免并發操作
}
改:
更新指定文檔或寫入自定義\_id的記錄
PUT /website/blog/123????
{
? "title": "My first blog entry",
? "text":? "Just trying this out...",
? "date":? "2014/01/01"
}
響應:文檔索引創建信息
{
? ?"\_index":? ? "website",
? ?"\_type":? ? ?"blog",
? ?"\_id":? ? ? ?"123",
? ?"\_version":? 1,
? ?"created":? ?true
}
查:
根據\_id檢索文檔
GET /website/blog/123?pretty
響應:存儲文檔時的索引信息及元數據
{
? "\_index" :? ?"website",
? "\_type" :? ? "blog",
? "\_id" :? ? ? "123",
? "\_version" : 1,
? "found" :? ? true, //即使沒有找到記錄也會返回數據,此處found會顯示false
? "\_source" :? {
? ? ? "title": "My first blog entry",
? ? ? "text":? "Just trying this out...",
? ? ? "date":? "2014/01/01"
? }
}
清空
query\_string: 指導行為細節的指標
pretty:美化響應輸出
\_source:僅顯示需要響應的元數據字段
op\_type:明確主行為的細節.因為主行為可能有二義,比如PUT通常為更新操作,需要指定文檔\_id,這時設置op\_type=create,行為會被理解為新建一個自定義\_id的文檔.新建成功返回201\[created\]如果已存在,新增失敗返回409\[conflict\]
這里可以直接等于
\_create
version:對指定版本的文檔進行操作
\_update:局部更新文檔.
結構化\[DSL\]查詢
通常查詢必有query?
bool是支持符合查詢的標識,
bool查詢的目的是為了更多的匹配來計算分數.其查詢語句是可以嵌套的.
答案在于分值是如何計算的。bool查詢會運行每個match查詢,將它們的分值相加,然后乘以匹配的查詢子句的數量,最后除以所有查詢子句的數量。相同層次的每個子句都擁有相同的權重。
其分值會被頂層
must? 是一定要
must not是一定不要
should 是不必要,但只要有會增加關聯性評分
term是 == 完全匹配
terms是 in\_array 匹配
match是分詞匹配
字符串類型文檔字段會有兩種查詢類型
keyword? ?未分詞
text? ? 包含分詞
wildcard????模糊匹配 需要通配符\*來代替模糊
#6
elasticsearch 提示Parse Failure \[No mapping found for \[filed\] in order to sort on\]\] 的解決辦法
排序代碼如下:
`{ "sort": [ { "timestamp": { "order": "desc" } } ] }`
修改后:
`{ "sort": [ { "timestamp": { "unmapped_type": "long"} } ] }`
默認匹配評分\_score 較大的排序靠前
| 一級分類 | 二級分類 | 具體類型 |
| --- | --- | --- |
| 核心類型 | 字符串類型 | string,text,keyword |
| 整數類型 | integer,long,short,byte |
| 浮點類型 | double,float,half\_float,scaled\_float |
| 邏輯類型 | boolean |
| 日期類型 | date |
| 范圍類型 | range |
| 二進制類型 | binary |
| 復合類型 | 數組類型 | array |
| 對象類型 | object |
| 嵌套類型 | nested |
| 地理類型 | 地理坐標類型 | geo\_point |
| 地理地圖 | geo\_shape |
| 特殊類型 | IP類型 | ip |
| 范圍類型 | completion |
| 令牌計數類型 | token\_count |
| 附件類型 | attachment |
| 抽取類型 | percolator |
- 常見功能
- 第三方授權登錄
- 郵件發送
- 簡易聊天室
- 獲取各國匯率
- PHP獲取服務器硬件指標
- 數據上報之
- web開發
- 開發規范
- 前端
- 踩坑
- 將footer固定在底部
- bootstrap
- Metronic
- 用到的jquery插件
- bootstrap-hover-dropdown
- jquery.slimscroll
- jquery.blockui
- bootstrap-switch
- js.cookie
- moment
- bootstrap-daterangepicker
- morris
- raphael
- jquery.waypoints
- jquery.counterup
- select2
- 取值和設置默認值
- vue
- axios
- 瀏覽器
- 谷歌瀏覽器
- 谷歌插件
- layui
- layui-表格
- layui-表單
- layui-彈窗
- layui-分頁
- 后端
- 操作系統
- linux
- 用戶管理
- 文件管理
- 目錄管理
- 壓縮和解壓縮
- 進程查看
- 端口查看
- 開機自啟動服務
- 定時任務
- shell腳本
- 殺掉運行超過指定時長指定服務的進程
- 獲取服務器使用狀態
- bash-shell連接socket
- 自定義快捷命令
- centos-踩坑
- 防火墻
- 軟件
- yum
- vim
- screen
- window
- 語言
- PHP
- 配置優化
- 框架
- thinkphp5.1+
- think命令行
- laravel6.+
- 維護模式
- 根據環境讀取不同配置
- laravel6.+采坑
- laravel坑位
- 數據庫事務
- 任務調度
- 文件權限問題
- 增強框架
- larvel:elastic-search
- 圖形驗證碼
- laravel獲取ip
- 函數
- strtotime
- 正則匹配
- 類
- 接口類與抽象類
- 類相關的關鍵字 - abstract
- 類相關的關鍵字 - interface
- PHP有關類的調用方式"->"與"::"的區別
- 擴展
- 問題歸納
- json_encode和json_decode
- 字符串的運算
- curl
- 優化php效率
- 數組相加合并與array_merge
- 時區轉換
- 不常用特性
- php反射
- 包管理器-composer
- GuzzleHttp
- Python
- Go
- 數據庫
- Redis
- 安裝
- 本地化-數據備份
- php-redis操作
- Mysql
- mysql-命令集合
- 設置終端可訪問
- 數據庫設計
- 用戶基礎信息表
- 踩坑集合
- mysql-2002
- mysql-2054
- 優化策略
- mysql-密碼驗證插件
- 一些牛逼的sql查詢
- topN
- 無限級分類
- Memcache
- MongoDb
- 安裝mongo-server
- 安裝php-mongodb擴展
- 在laravel中使用mongoDB
- 客戶端軟件
- Hbase
- Elasticsearch
- elastic-search
- restfulApi操作es
- web服務器
- 1.nginx
- 配置語法規則
- 配置詳解
- rewrite規則
- request_filename
- 2.apache
- 功能設計
- 加密解密
- Base64
- 對亞馬遜SKU加密
- 兼職項目中的加解密
- 騰訊外包時的加密
- 接口設計
- 接口限流設計
- 分庫分表
- 遍歷展示文件目錄結構
- 時區換算
- 文件切割
- 解析xml字符串
- 項目
- 博客后臺管理
- 亞馬遜廣告API
- 官方指引文檔
- 開發人員中心
- 應用商店
- 第三方庫
- 申請API郵件記錄
- 亞馬遜MWS
- 付款報告
- 亂碼
- 亞馬遜管理庫存報告
- 報告
- 商品
- 入庫
- 履行
- 出庫
- 財務
- 訂單
- 異步任務處理
- 集群如何同步代碼
- 基本開發流程
- 文檔管理
- showdoc
- 運行環境
- 開發環境
- vagrant
- windows上配置安裝
- vagrant安裝插件緩慢
- 更換ssh默認端口映射
- 設置x-shell密碼登錄
- 使用市場的box-homestead
- homestead-7: Box 'lc/homestead'
- 常見問題
- 虛擬環境reboot
- 突然無法使用
- phpStudy
- wamp
- 壓測性能
- VPN
- vultr
- 凌空圖床
- 寶塔
- 自動化部署
- 版本管理軟件鉤子
- 線上環境-LNMP
- centos7
- nginx
- mysql
- mysql開機自啟
- mysql-更換默認端口
- datetime字段類型默認值
- php
- php擴展安裝
- redis
- swoole
- gd
- BCMath
- igbinary
- zstd
- 包管理器:composer
- 優化性能
- nodejs
- 更新gcc版本
- 版本控制
- git
- 常用命令
- gitlab
- 版本管理規范
- 使用阿里云創建遠程倉庫
- git自動化部署
- svn
- 忽略指定文件
- 拉取代碼
- 自動化運維
- jekins
- 容器
- 集群
- 架構設計
- 設計原則
- 閱讀參考
- 代碼規劃
- 架構實戰
- 服務治理
- 權限控制設計
- 具體設計
- 計劃
- 疑問知識點
- 讀書筆記
- 高性能Mysql
- TCP-IP詳解-卷一:協議
- 思考
- php如何實現并發執行
- 對接調用設計
- 如何在瀏覽器上實現插件
- 如何設計一個app結合業務告警
- mysql的where查詢沒有用到索引
- 為啥in查詢比循環嵌套sql的查詢還要慢
- 使用git來創建屬于自己的composer包
- 翻頁獲取數據的時候又新增了數據
- 安全思路
- 月報
- PHP ?? 和 ?: 的區別
- PHP異步執行
- redis集群的目標是什么
- 大文件數據處理
- 性能瓶頸分析
- 命令行里輸出帶顏色的字體
- 面試問題合集
- 基礎
- 安全
- 算法
- 冒泡排序
- 快速排序
- 二分法查詢數組指定成員
- 字符查找匹配
- 令牌桶
- 漏桶
- 計數器
- 代理
- 協議
- http
- 狀態碼
- tcp
- udp
- Oauth2.0
- 設計模式
- 單例模式
- 適配器模式
- 工廠模式
- 觀察者模式
- 流程化
- 地址欄輸入網址到返回網頁的流程
- 題目收集
- 工具
- rabbitMq
- rabbitMQ用戶管理
- 生產者
- 消費者
- 支持TP5.*的think-queue
- 消息丟失
- 消費者報錯
- rabbitMQ配置優化
- 磁盤滿載導致服務掛掉
- PHP類庫
- rabbitMQ踩坑
- navicat
- vscode
- phpstorm
- 激活碼
- markdown
- PHP自定義類庫
- 工具類
- 領導力
- 任務分配
- 代碼組織
- 不要重復
- 避免污染
- 接口定義規范
- 小業務需求
- 獲取充值面額組成
- 監控服務器CPU和內存
- shell腳本版本