Archive: Posts Tagged ‘sphinx total_found’

从sphinx的total、total_found到max_matches

No comments December 15th, 2011

公司网站已经用sphinx很长一段时间了,一直没研究它,今天终于因为发现了一个分布问题了解了一点sphinx的基础知识。

问题是这样的,信息列表页的分页里显示有100多页,但到51页的时候不显示正确的信息列表了。按惯例,输出结果,查看可疑之处。发现返回的结果里total永远都是1000,total_found大概是分页中显示的页数和每页信息数的乘积,这说明total_found返回的是真正的信息数,但查询结果的时候又受到了total的限制。

百度sphinx total_found,得知sphinx有个max_matches是限制匹配结果数的,看了sphinx.conf,发现其中设置的max_matches远大于查询结果数,看来代码中有设置了,又查看sphinx的应用类,发现了SetLimits($start, $limit, 1000)这个东东,原来max_matches在这儿被定成了1000。

据说max_matches设定太大的话,查询速度会受影响,想了想把这个值设成变量,等于要查询的页数和每页信息数的乘积,这样就能得到正确的结果了,而且不会影响小页码的页面原查询速度。

Sphinx 0.9.9/Coreseek 3.2 参考手册
Sphinx 客户端手册