当前位置:   article > 正文

Django对接elasticsearch怎么实现全文检索(前后端分离)_django+elasticsearch8.0

django+elasticsearch8.0

目录

第一步:首先安装相关的依赖包

第二步:在django项目配置文件settings.py中注册应用

第三步:在django项目配置文件settings.py中指定搜索的后端

第四步:创建索引类

第五步:在templates目录中创建text字段使用的模板文件

第六步:手动更新索引

第七步:创建haystack序列化器

第八步:创建视图类

第九步:添加路由

第十步:结果


说到搜索,第一时间想到的是mysql数据库的like语句。但是,假如你的数据库有几千万条数据,name字段没有索引,可能查询需要十几分钟,用户可能会等你?那为什么不给name字段增加索引?数据表不仅仅是用来查询,也会经常修改数据,新增删除数据等。建立索引后,做增删改操作时也会大大占用数据库资源。所以应该怎么解决呢?Elasticsearch!

第一步:首先安装相关的依赖包

  1. pip install drf-haystack
  2. pip install elasticsearch
  3. pip install djangorestframework

第二步:在django项目配置文件settings.py中注册应用

  1. INSTALLED_APPS =
  2. [
  3. 'haystack',
  4. 'rest_framework'
  5. ]

第三步:在django项目配置文件settings.py中指定搜索的后端

  1. HAYSTACK_CONNECTIONS = {
  2. 'default':{
  3. 'ENGINE':'haystack.backends.elasticsearch_backend.ElasticsearchSearchEngine',
  4. 'URL': 'http://127.0.0.1:9200/', # 此处为elasticsearch运行的服务器ip地址,端口号固定为9200
  5. 'INDEX_NAME': 'test', # 指定elasticsearch建立的索引库的名称
  6. },
  7. }
  8. # 当添加、修改、删除数据时,自动生成索引
  9. HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor'
  10. # 指定搜索结果每页的条数
  11. # HAYSTACK_SEARCH_RESULTS_PER_PAGE = 1

第四步:创建索引类

在此之前要先创建model类,并插入数据

  1. from django.db import models
  2. class Es(models.Model):
  3. name=models.CharField(max_length=32)
  4. desc=models.CharField(max_length=32)

在需要进行索引的应用的目录下创建文件search_indexes.py, 在该文件内创建该索引类
我在app应用下创建:search_indexes.py(文件名固定不变)

  1. # 索引模型类的名称必须是 模型类名称 + Index
  2. from haystack import indexes
  3. from .models import Es
  4. class EsIndex(indexes.SearchIndex, indexes.Indexable):
  5. text = indexes.CharField(document=True, use_template=True)
  6. def get_model(self):
  7. """返回建立索引的模型类"""
  8. return Es
  9. def index_queryset(self, using=None):
  10. """返回要建立索引的数据查询集"""
  11. return self.get_model().objects.all()

第五步:在templates目录中创建text字段使用的模板文件

创建文件templates/search/indexes/app/es_text.txt文件中定义

{{ object.name }}

{{ object.desc }}

第六步:手动更新索引

python manage.py rebuild_index   #数据库有多少条数据,全部会被同步到es中

第七步:创建haystack序列化

  1. from drf_haystack.serializers
  2. import HaystackSerializer
  3. from rest_framework.serializers
  4. import ModelSerializer from app
  5. import models
  6. from app.search_indexes import EsIndex
  7. class EsSerializer(ModelSerializer):
  8. class Meta:
  9. model=models.Es
  10. fields='__all__'
  11. class EsIndexSerializer(HaystackSerializer):
  12. object = EsSerializer(read_only=True) # 只读,不可以进行反序列化
  13. class Meta:
  14. index_classes = [EsIndex] # 索引类的名称
  15. fields = ('text', 'object') # text由索引类进行返回, object 由序列化类进行返回,第一个参数必须是text

第八步:创建视图类

  1. from drf_haystack.viewsets
  2. import HaystackViewSet
  3. from app.models import Book
  4. from app.serializers import EsIndexSerializer
  5. class EsSearchView(HaystackViewSet):
  6. index_models = [Es]
  7. serializer_class = EsIndexSerializer

第九步:添加路由

  1. from django.conf.urls
  2. import url from django.contrib
  3. import admin
  4. from rest_framework import routers
  5. from app.views import EsSearchView
  6. router = routers.DefaultRouter()
  7. router.register("book/search", EsSearchView, base_name="book-search")
  8. urlpatterns = [ url(r'^admin/', admin.site.urls), ]
  9. urlpatterns += router.urls

第十步:结果

http://127.0.0.1:8000/?text=测试

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号