drf中elasticsearch、haystack的使用

简介: 简单使用

elasticsearch的安装

使用docker安装
通过pull拉取,或者压缩包解压。
更改配置文件,
image.png
image.png
将network.host修改为自己的虚拟机ip。

3.使用docker运行elasticsearch,输入命令$ sudo docker run -dti --name=elasticsearch --network=host -v /home/python/elasticsearch-2.4.6/config:/usr/share/elasticsearch/config delron/elasticsearch-ik:2.4.6-1.0

配置

在django框架中需要通过django-haystack来对接搜索引擎的使用,所以务必要在python虚拟环境中安装django-haystack和elasticsearch.

pip3 install django-haystack
pip3 install elasticsearch
1
2
django-haystack是专门给 django 提供搜索功能的。 django-haystack提供了一个统一的API搜索接口,底层可以根据自己需求更换搜索引擎( Solr, Elasticsearch,Whoosh, Xapian 等等),类似于 django 中的 ORM插件,提供了一个操作数据库接口,但是底层具体使用哪个数据库是可以在配置文件中进行设置的。

在django中可以通过使用haystack来调用Elasticsearch搜索引擎。而在drf框架中,也有一个对应的drf-haystack模块,是django-haystack进行封装处理的。

setting中的配置

注册apps

INSTALLED_APPS = [

'haystack',

]

Haystack

HAYSTACK_CONNECTIONS = {

'default': {
    'ENGINE': 'haystack.backends.elasticsearch_backend.ElasticsearchSearchEngine',
    # elasticsearch运行的服务器ip地址,端口号默认为9200
    'URL': 'http://192.168.153.162:9200/', # 配置 IP:port
    # elasticsearch建立的索引库的名称,一般使用项目名作为索引库
    'INDEX_NAME': 'object_name',
},

}

设置在Django运行时,如果有数据产生变化(添加、修改、删除),

haystack会自动让Elasticsearch实时生成新数据的索引

HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor'

模型类的创建

完成索引类的创建,一定要在对应的app下创建索引文件indexes_search.py(注:必须是这个名字,否则无法索引)。
from haystack import indexes

from .models import SKU

class SKUIndex(indexes.SearchIndex, indexes.Indexable):

"""SKU索引数据模型类"""
text = indexes.CharField(document=True, use_template=True)

def get_model(self):
    """返回建立索引的模型类"""
    return SKU

def index_queryset(self, using=None):
    """返回要建立索引的数据查询集"""
    return self.get_model().objects.filter(is_launched=True)

要在templates下创建text文件
具体在templates/search/indexes/goods/sku_text.txt文件中定义

{{ object.title }}
{{ object.content }}
{{ object.id }}

1
2
3
4
此模板指明SKU的id、name、caption作为text字段的索引值来进行关键字索引查询。

手动生成初始索引
$ python manage.py rebuild_index

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。  
相关文章
单细胞分析|映射和注释查询数据集
单细胞分析|映射和注释查询数据集
|
消息中间件 监控 NoSQL
Celery 高效异步任务队列:打破常规,颠覆认知,应用实践全攻略在此!
【8月更文挑战第5天】Celery 是一款强大的异步任务队列框架,适用于后台执行耗时任务如邮件发送、报表生成等。可通过`pip install celery`安装,并配置消息代理(如Redis)以启动服务。定义异步任务使用装饰器`@app.task`,并通过`.delay()`方法执行。任务状态和结果可通过`.ready()`和`.get()`查询。异常处理支持任务重试,性能优化包括调整并发数和选用高效消息代理。Celery 能显著提升应用效率与用户体验。
856 0
|
Dubbo Java 应用服务中间件
深入Dubbo异步化:探索AsyncContext的神奇之处
深入Dubbo异步化:探索AsyncContext的神奇之处
475 0
|
开发者
深入了解HTTP状态码
深入了解HTTP状态码
550 64
hutool 验证是否为手机号码(中国)
hutool 验证是否为手机号码(中国)
|
NoSQL MongoDB 数据库
MongoDB v4.4.6安装、创建服务及Web客户端访问MongoDB详解
MongoDB v4.4.6安装、创建服务及Web客户端访问MongoDB详解
710 0
MongoDB v4.4.6安装、创建服务及Web客户端访问MongoDB详解
|
存储 数据中心 数据安全/隐私保护
|
存储 关系型数据库 MySQL
Mysql大数据批量插入方法
Mysql大数据批量插入方法
619 0
|
Linux Docker 容器
使用Docker来安装ElasticSearch,并且配置ik分词器
使用Docker来安装ElasticSearch,并且配置ik分词器
714 0
|
算法 Ubuntu Java
数据包完整性校验总结
为了保证分发的数据包的一致性,常常需要增加数据包校验码,这样可以减少因为传递过程中造成的数据包不能使用问题,比如jar包的__invalid distance code__问题。在开始讨论数据包校验码生成方法前,先了解一下基本概念。 # 核心技术 ## 哈希 哈希是一种不可逆的映射,可以将数据经过哈希算法计算得到一个哈希值,而无法再将该哈希值反映射得到原始的数据。一般来说,不同的数据得到的哈
3335 0