0

コードのこの部分を使用してスフィンクスからドキュメントを取得しますが、スフィンクス クエリは常に None を返します。しかし、コマンド ラインからコードを実行すると、正しい結果が得られます。

def search_query(query, offset=0):
    mode = SPH_MATCH_EXTENDED
    host = 'localhost'
    port = 9312
    index = 'rss_item'
    filtercol = 'group_id'
    filtervals = []
    sortby = '-@weights'
    groupby = 'id'
    groupsort = '@group desc'
    limit = 30

    # do query
    cl = SphinxClient()
    cl.SetServer ( host, port )
    cl.SetWeights ( [100, 1] )
    cl.SetMatchMode ( mode )

    #cl.SetSortMode(SPH_SORT_TIME_SEGMENTS)
    if limit:
        cl.SetLimits ( offset, limit, max(limit,1000) )
    res = cl.Query ( query, index )

    docs =[]
    for item in res['matches']:
        docs.append(item['id'])

    return docs

# this is django view
def search(request):
    q = request.GET.get('q', '')
    offset = int(request.GET.get('older', 0))
    docs=search_query(q, offset)

    result = Item.objects.filter(id__in=docs).all()

    objects = dict([(obj.id, obj) for obj in result])
    sorted_objects = [objects[id] for id in docs]

    result = sorted_objects

    return render_to_response('rss/_items.html',
                              {'latest_items':result, 'offset':offset+30,'q':q},
                              context_instance=RequestContext(request))

サーバー: centos6、スフィンクス: 2.0.5、ジャンゴ: 1.4.2、apache/wsgi

4

1 に答える 1

1

問題を解決するには、Selinux をオフにしてサーバーを再起動し、次のコマンドで Apache プロセスをリッスンします。

ps auxw | grep httpd | awk '{print"-p " $2}' | xargs strace

apache から sphinx および memcache へのアクセスが拒否されたことを確認します。

于 2012-12-09T16:45:12.027 に答える