Tech

从零开始搭建Django Solr的环境

本文介绍在Ubuntu系统中,用django-haystack处理Django搜索请求的方法。如果有涉及连词、多条件等较为复杂的搜索需求,这是一个很不错的解决方案。如果只需要基本的搜索功能,或是刚接触Django的用户则不推荐使用,这个模块功能强大相应的配置也很繁琐,稍有不慎就会出错。

安装tomcat, solr, django-haystack:

$ sudo apt-get install tomcat6
$ sudo apt-get install solr-tomcat6 #Ubuntu 11.10 12.04里是 solr-tomcat
$ pip install django-haystack

安装成功后打开:http://127.0.0.1:8080/solr 可以看到Solr的管理界面。接下来开始配置Django,首先在项目目录中新建search_sites.py文件,内容是:


编辑settings.py文件加入haystack模块,指定Solr作为搜索引擎:

urls.py里引入haystack:

现在打开这个地址/search/会提示找不到相应的模板文件,在模板文件夹中创建/search/search.html:

再次打开/search/,就可以看到haystack提供的search界面(如下图)了,它会提示:Select a valid choice. core.product is not one of the available choices. 因为还没有注册需要被搜索的模块。

假设我要搜索的Model是product应用中的Product。在product目录下创建search_indexes.py

刷新页面,如果会出现名为Product的复选框,Django部分的设置就成功了。但现在还无法搜索,要生成一个与现有Model对应的schema,把它写入Solr:

$ python manage.py build_solr_schema > /etc/solr/conf/schema.xml

完成后需要重启tomcat6。现在执行 manger.py rebuild_index命令,提示:TemplateDoesNotExist: search/indexes/product/product_text.txt。因为在search_indexes.py的text字段指定了use_template=True,需要创建一个数据模板,在提示的模板目录中(本例是search/indexes/product/)创建product_text.txt

再次执行manger.py rebuild_index,成功后就可以使用Solr提供的搜索功能了:

如果出现错误可以先查看文档中的Debug部分或是在评论中提出。

7 thoughts on “从零开始搭建Django Solr的环境”

Leave a Reply

Your email address will not be published. Required fields are marked *