Elasticsearch从入门到精通

news2025/1/20 18:33:46

Elasticsearch简介

应用开发中一个比较常见的功能是搜索,传统应用的解决方案:数据库的模糊查询。

模糊查询存在的问题:

  • 海量数据下效率低下
  • 功能不够丰富:不够智能、不能高亮

Elasticsearch 是一个分布式RESTful 风格的搜索和数据分析引擎。能够在海量的结构化和非结构化的数据中进行快速搜索,帮助我们完成诸如 订单搜索、商品推荐、日志分析、性能监控 等功能。

和Elasticsearch类似的产品还有Apache组织开源的Solr ,Solr和Elasticsearch都是基于Lucene这个Java类库二次开发而成的框架。Solr在功能性、传统搜索应用方面的表现更好,Elasticsearch则在新兴的实时搜索表现更佳。Solr的发展一直都比较平稳,近些年来呈现渐渐的下降趋势,而Elasticsearch则呈现明显上升的趋势。

Elasticsearch的特点:

  • Elasticsearch是基于Lucene(Java全文检索工具)的开发的搜索引擎
  • Elasticsearch支持分布式多用户访问,可以轻松的扩展到上百台服务器
  • Elasticsearch是近实时的不是实时的搜索引擎,简单说插入一条新数据后并不能保证立刻搜索到,但保证在1s内一定可以搜索到
  • Elasticsearch通过简单的RESTful API来隐藏Lucene的复杂性,使得全文检索变得简单
  • Elasticsearch使用JSON格式存储数据

接下来就来讲解一下Elasticsearch的安装使用

Elasticsearch安装

  1. 安装elasticsearch首先需要安装jdk环境
    (如何安装jdk可以查阅博主之前的文章的前三步Tomcat的安装及配置)
  2. 修改配置文件limits.conf
    vi /etc/security/limits.conf
在最后一行添加下面内容
* soft nofile 65536
* hard nofile 65536
* soft nproc  4096
* hard nproc  4096
  1. 修改sysctl.conf
    vi /etc/sysctl.conf
最后一行添加
vm.max_map_count=262144

运行该命令让sysctl生效
sysctl -p

  1. 把es安装包上传到opt文件夹里面进行解压
    下载链接:https://pan.baidu.com/s/1_fnyYhUkM-m3QPIQK6xcEg
    提取码:iw14
tar -zxvf elasticsearch-6.4.1.tar.gz
  1. 修改es的配置文件允许远程访问
[root@localhost config]# vi elasticsearch.yml 
将55行
#network.host: 192.168.0.1 
改为:
network.host: 0.0.0.0 

注意去除前面的#

  1. 尝试启动es:在这里插入图片描述
    es不能使用root用户启动。我们需要添加其他用户。

  2. 添加es用户,修改es文件夹的所属用户为es,elasticsearch不能使用root用户启动。
    在这里插入图片描述
    在这里插入图片描述
    所以我们需要通过linux的权限命令对文件夹进行修改所属用户。

  3. 使用es用户登录到linux里面,启动es

在这里插入图片描述

Elasticsearch使用操作

REST 回顾

REST(Resource Representational State Transfer)资源在网络传输中以某种表现形式进行状态转移。

REST风格的URI:

  • 面向资源
  • 通过HTTP的请求方式对资源进行操作

HTTP请求方式:

  • GET 对资源的查询
  • POST 对资源的新增或者更新
  • PUT 对资源的更新或者新增
  • DELETE 对资源的删除

RESTful API操作Elasticsearch

Elasticsearch数据相关的概念:

  • 文档:json格式的数据,类似关系型数据库的一行数据。每个文档都会有唯一的id,可以由es生成,也可以由程序员指定
  • 字段:每一个文档中的数据字段就相当于关系型数据库中一行的列
  • 类型:Elasticsearch中保存数据的容器,类似于MySQL中的表
  • 索引:保存有类型,类似于mysql的数据库。
序号Elasticsearchmysql
1索引
2类型
3文档
4字段

为方便大家前期对Elasticsearch的数据有一个大体的认识,可以类比关系型数据库的一些概念,但注意2者之间有本质差别不可等价齐观。(ES里一个索引只能有一个类型,而mysql里面一个库里面可以有许多表)

在这里再给大家推荐一个操作es的软件postman(博主在这里提供的是破解版,仅供个人学习使用,另外不要更新软件否则可能会收费)
下载链接:https://pan.baidu.com/s/1f-n7KqjOdISYyDEYnWbI2Q
提取码:0nsi

创建和删除索引
  1. 创建索引和类型:
    PUT /索引名
{
	"mappings":{
		"类型名":{
			"properties":{
				"字段名":{
					"type":"字段类型"
				},
				"字段名":{
					"type":"字段类型"
				}
			}
		}
	}
}

字段类型:

字符串:keyword,text
数值类型:long,integer,short,byte,double,float
布尔:boolean
日期:date
二进制:binary

案例:
PUT http://192.168.240.137:9200/bookshop

{
    "mappings":{
        "book":{
            "properties":{
                "name":{
                    "type":"keyword"
                },
                "price":{
                    "type":"double"
                },
                "date":{
                    "type":"date"
                }
            }
        }
    }
}

在这里插入图片描述

  1. 查看索引
    GET /索引名/_mappings
    案例:
    GET http://192.168.240.137:9200/bookshop/_mappings
    结果:
{
    "bookshop": {
        "mappings": {
            "book": {
                "properties": {
                    "date": {
                        "type": "date"
                    },
                    "name": {
                        "type": "keyword"
                    },
                    "price": {
                        "type": "double"
                    }
                }
            }
        }
    }
}

在这里插入图片描述

  1. 删除索引
    DELETE /索引名
    案例:
    DELETE http://192.168.240.137:9200/bookshop
{
	"acknowledged": true
}

在这里插入图片描述

补充一下:
删除所有索引
DELETE http://192.168.240.137:9200/*

  1. 查询当前所有的索引
    GET http://192.168.240.137:9200/_cat/indices?v

在这里插入图片描述

添加(修改)和删除文档
  1. 添加文档
    POST http://192.168.240.137:9200/bookshop/book/1
{
    "name":"西游记",
    "price":10,
    "date":"2012-12-12"
}

在这里插入图片描述

其中id也可以不添加,系统会自动给我们创建一个id值。补充一下,如果索引和文档不存在,系统也会自动给我们创建。如果字段不存在,系统也会自动添加。

由es分配id

POST http://192.168.240.137:9200/bookshop/book

{
    "name":"水浒传",
    "price":10,
    "date":"2012-10-10"
}

在这里插入图片描述

#指定文档的id

POST http://192.168.240.137:9200/bookshop/book/2

{
    "name":"三国演义",
    "price":10,
    "date":"2023-11-12"
}

在这里插入图片描述

  1. 查询文档
    GET /索引/类型/id值
    案例:
    示例:
    查看全部
    GET http://192.168.240.137:9200/bookshop/book/_search
    在这里插入图片描述
    查看id为1的数据
    GET http://192.168.240.137:9200/bookshop/book/1
    在这里插入图片描述

  2. 删除文档
    DELETE /索引/类型/id
    案例:
    DELETE http://192.168.240.137:9200/bookshop/book/Ut8URIwBjRBsHr8AOytd

在这里插入图片描述

  1. 更新(修改)文档
    POST /索引/类型/id
    POST http://192.168.240.137:9200/bookshop/book/2
{
    "name":"三国",
    "price":10,
    "date":"2023-11-12",
    "product_address":"made in China"
}

在这里插入图片描述
这里的更新(修改)会直接覆盖掉原来的,如果字段不存在,会新建。

批量操作
批量写 _bulk

Bulk API支持在一次请求中,可以对任意的索引执行多种不同的写操作。
PUT /_bulk

{操作类型以及操作的索引 类型 文档id信息}
{操作用到的数据}

注意最后必须添加一个空行

案例:
PUT http://192.168.146.40:9200/_bulk

{"index":{"_index":"dangdang","_type":"book","_id":"1"}}
{"bookName":"红楼梦","author":"曹雪芹","price":19800.0}
{"update":{"_index":"dangdang","_type":"book","_id":"1"}}
{"doc":{"price":"1980.0"}}
{"create":{"_index":"dangdang","_type":"book","_id":"2"}}
{"bookName":"水浒传","author":"施耐庵"}
{"delete":{"_index":"dangdang","_type":"book","_id":"3"}}

注意

  • json数据不能主动换行,必须写成一行
  • 多个json间必须要换行
  • 在文件中json串最后一行下方必须再有一个空行

扩展:
如果在URI路径上指定了索引和类型,那么操作时json串中的条件可以省略对应的值,上面的操作也可以写成如下所示:
PUT http://192.168.146.40:9200/dangdang/book/_bulk

{"index":{"_id":"1"}}
{"bookName":"红楼梦","author":"曹雪芹","price":19800.0}
{"index":{"_id":"1"}}
{"doc":{"price":"1980.0"}}
{"create":{"_id":"2"}}
{"bookName":"水浒传","author":"施耐庵"}
{"delete":{"_id":"3"}}

操作中单条操作的失败,不会影响其它操作。返回结果中包含了每一条操作的结果(成功或者失败)。

批量读 _mget

可以一次性的查询多个数据,减少网络连接产生的开销,提高性能。

GET /_mget

{
	"docs":[
		{索引 类型 等信息},
		...
	]
}     

案例:
GET http://192.168.146.40:9200/_mget

{
	"docs":[
        {
            "_index":"dangdang",
            "_type":"book",
            "_id":1
        },
        {
            "_index":"dangdang",
            "_type":"book",
            "_id":2
        }
	]
}  

如果在URI路径上指定了索引和类型,那么操作时json串中的条件可以省略对应的值,上面的操作也可以写成如下所示:
GET http://192.168.146.40:9200/dangdang/book/_mget

{
	"docs":[
		{"_id":1},
		{"_id":2}
	]
}

Elasticsearch高级检索DSL检索

不安装其他插件的情况下,es默认是不支持中文的分词查询的
准备测试数据:
添加索引并设置类型
PUT /ems

{ 
    "mappings":{ 
        "emp":{ 
            "properties":{ 
                "name":{ 
                	"type":"text" 
                }, 
                "age":{ 
               	 	"type":"integer" 
                }, 
                "bir":{ 
               	 	"type":"date",
                    "format": "yyyy-MM-dd HH:mm:ss || yyyy-MM-dd || yyyy/MM/dd HH:mm:ss|| yyyy/MM/dd ||epoch_millis"
                }, 
                "content":{ 
                	"type":"text" 
                }, 
                "address":{ 
               		 "type":"keyword" 
                } 
            }
        } 
    }
}

PUT /ems/emp/_bulk

{"index":{"_id":1}}
{"name":"小黑","age":23,"bir":"2012-12-12","content":"为开发团队选择一款优秀的MVC框架是件难难事,在众多可行的方案中决择需要很高的经验和水平","address":"北京"}
{"index":{"_id":2}}
{"name":"王小黑","age":24,"bir":"2012-12-12","content":"Spring 框架是一个分层架构,由 7 个定义良好的模块组成。Spring 模块构建在心容器之上,核心容器定义了创建、配置和管理 bean 的方式。为了测试添加一个内容北京","address":"上海"}
{"index":{"_id":3}}
{"name":"张小五","age":8,"bir":"2012-12-12","content":"SpringCloud作为Java语言的微服务框架,它依赖于Spring Boot,有快速开发、持续交付和容易部署等特点。SpringCloud的组件非常多,涉及微服务的方方面面,并在开源社区Spring 和Netflix、Pivotal 两大公司的推动下越来越完善","address":"无锡"}
{"index":{"_id":4}}
{"name":"win7","age":9,"bir":"2012-12-12","content":"Spring的目标是致力于全方位的简化Java开发。 这势必引出更多的解释,Spring是如何简化Java开发的?","address":"南京"}
{"index":{"_id":5}}
{"name":"梅超风","age":43,"bir":"2012-12-12","content":"Redis一个开源的使  用ANSIC语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API","address":"杭州"}
{"index":{"_id":6}}
{"name":"张无忌","age":59,"bir":"2012-12-12","content":"ElasticSearch是一个  基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口","address":"北京"}

from和size(分页查询)

formsize等同于MySQL中limit后的2个数值,借助这2个属性可以完成分页。

GET /ems/emp/_search

{
	"query":{"match_all":{}},
	"from":3,
	"size":3,
	"sort":[
		{"age":{"order": "desc"}}
	]
} 

在这里插入图片描述

在这里插入图片描述

sort(排序)

sort属性值是一个数组,表示可以设定多个字段的排序

{
	"sort":[
		{"字段1":{"order":"asc|desc"}},
		{"字段2":{"order":"asc|desc"}}
	]
} 

上述语法也可以简化如下:

{
	"sort":[
		{"字段1":"asc|desc"},
		{"字段2":"asc|desc"}
	]
}   

案例:
GET /ems/emp/_search

{
	"query":{"match_all":{}},
	"sort":[
		{"address":{"order":"desc"}},
		{"age":{"order": "asc"}}
	]
}  
{
	"query":{"match_all":{}},
	"sort":[
		{"address":"desc"},
		{"age":"asc"}
	]
} 

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

_source(查询指定字段)

_source是一个数组,指定要显示的字段。

{
	"_source":["字段名1","字段名2",...]
} 

案例:
GET /ems/emp/_search

{
	"query": {
		"match_all": {}
	},
	"_source":["name","age"]
}  

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

query(查询规则)

query用于设置查询规则,Elasticsearch中有多种查询规则

{
	"query":{
		"match_all":{},//匹配所有
		"match":{},//分词查询
		"term":{},//关键字查询
		"range":{},//范围查询
		"prefix":{},//前缀查询
		"wildcard":{},//通配符查询
		"ids":{},//多id查询
		"fuzzy":{},//模糊查询
		"bool":{},//bool查询
		"multi_match":{}//多字段查询
	}
}     

我们选几种常见的进行讲解

match(分词查询)

match 匹配查询,会对条件分词后查询

GET /ems/emp/_search

{
	"query":{
		"match":{
			"content": "Redis Java"
		}
	}
}   

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

term (关键字查询)

term 关键字: 用来使用关键词查询,不会对条件分词

GET /ems/emp/_search

{
    "query":{
        "term":{
            "content":{
                "value":"spring" //注意字母必须小写;如果出现大写字母,查询不到结果
            }
        }
    }
}

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

range(范围查询)

range 关键字: 用来指定查询指定范围内的文档

GET /ems/emp/_search

{
    "query":{
        "range":{
            "age":{
                "gte":40, // greater than equals
                "lt":80 // less than
            }
        }
    }
}

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

ids(多id查询)

GET /ems/emp/_search

{
    "query":{
        "ids":{
            "values":["1","2"]
        }
    }
}

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

bool(布尔查询)

bool查询:bool查询用于合并多个查询条件
bool查询中有must、should、must_not3个关键字
must:相当于java中的&&,所有条件必须同时满足
should:相当于java中||,任一条件满足即可
must_not:相当于java中的!,取反操作

  1. must示例:
    GET /ems/emp/_search
{
    "query":{
        "bool":{
            "must":[
                { //查询地址以北作为前缀的
                    "prefix":{ 
                        "address":{
                            "value":"北"
                        }
                    }
                },{
                    "range":{
                        "age":{
                            "gte":40
                        }
                    }
                }
            ]
        }
    }
}

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

  1. should示例
    GET /ems/emp/_search
{
    "query":{
        "bool":{
            "should":[
                {
                    "prefix":{
                        "address":{
                            "value":"北"
                        }
                    }
                },{
                    "ids":{
                        "values":["1","3","5"]
                    }
                }
            ]
        }
    }
}

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

  1. must_not示例
    GET /ems/emp/_search
{
    "query":{
        "bool":{
            "must_not":[
                {
                    "prefix":{
                        "address":{
                            "value":"北"
                        }
                    }
                },{
                    "term":{
                        "content":{
                            "value":"spring"
                        }
                    }
                }
            ]
        }
    }
}

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

multi_match(多字段分词查询)

muli_match用于在多个字段中分词查询

GET /ems/emp/_search

{
    "query":{
        "multi_match":{
            "query":"张黑java",
            "fields":["name","content"]
        }
    }
}

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

高亮查询

hightlight用于在查询关键字上添加样式,以达到高亮显示的效果。
GET /ems/emp/_search

{
    "query":{
        "multi_match":{
            "query":"张黑java",
            "fields":["name","content"]
        }
    },
    "highlight":{
        "fields":{
            "content":{},
            "name":{}
        },
        "pre_tags":["<span style='color:red'>"],
        "post_tags":["</span>"]
    }
}

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1293314.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android Audio实战——音频链路分析(二十五)

在 Android 系统的开发过程当中,音频异常问题通常有如下几类:无声、调节不了声音、爆音、声音卡顿和声音效果异常(忽大忽小,低音缺失等)等。尤其声音效果这部分问题通常从日志上信息量较少,相对难定位根因。想要分析此类问题,便需要对声音传输链路有一定的了解,能够在链…

/proc/sys/net/ipv4/ 下网络参数的理解

/proc/sys/net/ipv4/下文件详细解释&#xff1a; /proc/sys/net/ipv4/下文件 /proc/sys/net/ipv4/ip_forward 该文件表示是否打开IP转发。 0&#xff0c;禁止 1&#xff0c;转发 基本用途&#xff1a;如VPN、路由产品的利用&#xff1b; 出于安全考虑&#xff0c;Linux系…

【开源】基于JAVA的个人健康管理系统

项目编号&#xff1a; S 040 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S040&#xff0c;文末获取源码。} 项目编号&#xff1a;S040&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 健康档案模块2.2 体检档案模块2.3 健…

uni-app 微信小程序之好看的ui登录页面(二)

文章目录 1. 页面效果2. 页面样式代码 更多登录ui页面 uni-app 微信小程序之好看的ui登录页面&#xff08;一&#xff09; uni-app 微信小程序之好看的ui登录页面&#xff08;二&#xff09; uni-app 微信小程序之好看的ui登录页面&#xff08;三&#xff09; uni-app 微信小程…

SAP UI5 walkthrough step1 hello word

这里我用的VS Studio 来进行本地化学习 关于SAP UI5是啥&#xff0c;我就不再赘述了&#xff0c;另外还有VS Studio 的安装&#xff0c;请提前做好准备 下面我们直接进入正文 1.首先在你的本地新建一个文件夹&#xff0c;此处我命名为&#xff1a;walkthrough 2.在VS中打开…

【动手学深度学习】(十)PyTorch 神经网络基础+GPU

文章目录 一、层和块1.自定义块2.顺序块3.在前向传播函数中执行代码 二、参数管理1.参数访问2.参数初始化3.参数绑定 三、自定义层1.不带参数的层2.带参数的层 四、读写文件1.加载和保存张量2.加载和保存模型参数五、使用GPU [相关总结]state_dict() 一、层和块 为了实现复杂神…

Verilog学习 | 用initial语句写出固定的波形

initial beginia 0;ib 1;clk 0;#10ia 1; #20ib 0;#20ia 0; endalways #5 clk ~clk; 或者 initial clk 0;initial beginia 0;#10ia 1; #40ia 0; endinitial beginib 1;#30 ib 0; endalways #5 clk ~clk;

[数据集][目标检测]拉横幅识别横幅检测数据集VOC+yolo格式1962张1类别

数据集格式&#xff1a;Pascal VOC格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;1962 标注数量(xml文件个数)&#xff1a;1962 标注数量(txt文件个数)&#xff1a;1962 标注类别数&a…

0010Java安卓程序设计-ssm基于安卓的掌上校园系统

文章目录 **摘要**目录系统实现5.2管理员功能模块开发环境 编程技术交流、源码分享、模板分享、网课分享 企鹅&#x1f427;裙&#xff1a;776871563 摘要 随着Internet的发展&#xff0c;人们的日常生活已经离不开网络。未来人们的生活与工作将变得越来越数字化&#xff0c;…

自然语言处理基础知识 学习

参考&#xff1a;OpenBMB - 让大模型飞入千家万户 【清华NLP】刘知远团队大模型公开课全网首发&#xff5c;带你从入门到实战_哔哩哔哩_bilibili 图灵测试&#xff1a;imitation Game 模仿游戏 Part of speech tagging 词性标注 Named entity recognition &#xff1a; 命名…

LED透镜粘接UV胶是一种特殊的UV固化胶,用于固定和粘合LED透镜。

LED透镜粘接UV胶是一种特殊的UV固化胶&#xff0c;用于固定和粘合LED透镜。 它具有以下特点&#xff1a; 1. 高透明度&#xff1a;LED透镜粘接UV胶具有高透明度&#xff0c;可以确保光线的透过性&#xff0c;不影响LED的亮度和效果。 2. 快速固化&#xff1a;经过UV紫外线照射…

查看端口号是否被占用

windows10查看端口号是否被占用及解除占用的常用命令 netstat -ano&#xff1a;查看所有端口号占用情况 netstat -ano |findstr “XXX”&#xff1a;查看端口号为XXX的占用情况&#xff0c;如下&#xff1a; 得到进程号为12160的进程正在占用本地的9090端口号&#xff08;如果只…

uni-app 微信小程序之好看的ui登录页面(四)

文章目录 1. 页面效果2. 页面样式代码 更多登录ui页面 uni-app 微信小程序之好看的ui登录页面&#xff08;一&#xff09; uni-app 微信小程序之好看的ui登录页面&#xff08;二&#xff09; uni-app 微信小程序之好看的ui登录页面&#xff08;三&#xff09; uni-app 微信小程…

redis-学习笔记(list)

因为 list 可以头插头删, 尾插尾删, 所以其实更像 C 中的 deque (双端队列) ---- 知道就好, 别乱说, 具体底层编码是啥, 俺也不知道(没注意过) 可以通过组合, 把 list 当作队列 / 栈来用 list 的几种底层编码: ziplist(压缩列表) , linkedlist(链表) , quicklist ziplist 就是将…

TCP聊天

一、项目创建 二、代码 Client类 package tcp;import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; import java.util.Scanner;public class Client {public static void m…

[足式机器人]Part2 Dr. CAN学习笔记-数学基础Ch0-6复数Complex Number

本文仅供学习使用 本文参考&#xff1a; B站&#xff1a;DR_CAN Dr. CAN学习笔记-数学基础Ch0-6复数Complex Number x 2 − 2 x 2 0 ⇒ x 1 i x^2-2x20\Rightarrow x1\pm i x2−2x20⇒x1i 代数表达&#xff1a; z a b i , R e ( z ) a , I m ( z ) b zabi,\mathrm{Re}…

华为配置Smart Link负载分担示例

Smart Link基本概念 Smart Link通过两个端口相互配合工作来实现功能。这样的一对端口组成了一个Smart Link组。为了区别一个Smart Link组中的两个端口&#xff0c;我们将其中的一个叫做主端口&#xff0c;另一个叫做从端口。同时我们利用Flush报文、Smart Link实例和控制VLAN等…

2. PyTorch——Tensor和Numpy

2.1Tensor和Numpy Tensor和Numpy数组之间具有很高的相似性&#xff0c;彼此之间的互操作也非常简单高效。需要注意的是&#xff0c;Numpy和Tensor共享内存。由于Numpy历史悠久&#xff0c;支持丰富的操作&#xff0c;所以当遇到Tensor不支持的操作时&#xff0c;可先转成Numpy…

java设计模式学习之【装饰器模式】

文章目录 引言装饰器模式简介定义与用途实现方式 使用场景优势与劣势装饰器模式在Spring中的应用画图示例代码地址 引言 在日常生活中&#xff0c;我们常常对基本事物添加额外的装饰以增强其功能或美观。例如&#xff0c;给手机加一个保护壳来提升其防护能力&#xff0c;或者在…

阿里云磁盘在线扩容

我们从阿里云的控制面板中给硬盘扩容后结果发现我们的磁盘空间并没有改变 注意&#xff1a;本次操作是针对CentOS 7的 &#xfeff;#使用df -h并没有发现我们的磁盘空间增加 #使用fdisk -l发现确实还有部分空间 运行df -h命令查看云盘分区大小。 以下示例返回分区&#xf…