問題タブ [solr]
For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.
java - solrは複数形を単数形に変換します。
複数形のアイテムがあり、非常に特殊なロケーターとして使用されるフィールドがあるので、solr検索type:articlesを実行すると、次のように変換されます。
タイプ:記事タイプ:articl
それは本当にイライラします、これを無効にする方法はありますか?
lucene - Solr - 「追加」をサーバーにポストするときのエラー
以下をSolrサーバーに投稿しています:
SolrNetを使用してドキュメントを送信しています。コードからの抜粋です (s は上記の xml です)。
request.GetResponse に到達すると、次のエラーで失敗しました:
base {System.InvalidOperationException} = {"リモート サーバーがエラーを返しました: (500) 内部サーバー エラー"}
Apache のログでサーバーを調べると、次の理由が表示されます。
最後に入力ブロックが予期せず終了しました
完全なスタック トレースは次のとおりです。
2009 年 9 月 17 日 10:13:53 AM org.apache.solr.common.SolrException ログ SEVERE: com.ctc.wstx.exc.WstxEOFException: [row,col {unknown-source} の終了タグの入力ブロックの予期しない終了]: [26,1266] com.ctc.wstx.sr.StreamScanner.throwUnexpectedEOB(StreamScanner.java:700) で com.ctc.wstx.sr.StreamScanner.loadMoreFromCurrent(StreamScanner.java:1054) で com.ctc. com.ctc.wstx.sr.BasicStreamReader.readEndElem(BasicStreamReader.java:3211) の wstx.sr.StreamScanner.getNextCharFromCurrent(StreamScanner.java:811) com.ctc.wstx.sr.BasicStreamReader.nextFromTree(BasicStreamReader.java: 2832) で com.ctc.wstx.sr.BasicStreamReader.next(BasicStreamReader.java:1019) で org.apache.solr.handler.XmlUpdateRequestHandler.processUpdate(XmlUpdateRequestHandler.java:148) で org.apache.solr.handler.XmlUpdateRequestHandler.handleRequestBody(XmlUpdateRequestHandler.java:123) org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:131) org.apache.solr.core.SolrCore.execute(SolrCore.java:1204) org .apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:303) org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:232) org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain) .java:235) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) org.apache.catalina. org.apache.catalina.core の core.StandardContextValve.invoke(StandardContextValve.java:191)。StandardHostValve.invoke(StandardHostValve.java:128) org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) org .apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) at org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) at org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process (Http11AprProtocol.java:574) org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1527) で java.lang.Thread.run(Thread.java:619)109) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) で org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) で org.apache.coyote.http11.Http11AprProtocol $Http11ConnectionHandler.process(Http11AprProtocol.java:574) at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1527) at java.lang.Thread.run(Thread.java:619)109) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) で org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) で org.apache.coyote.http11.Http11AprProtocol $Http11ConnectionHandler.process(Http11AprProtocol.java:574) at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1527) at java.lang.Thread.run(Thread.java:619)
Solr サーバーは次のシステムで実行されていることに注意してください。
Microsoft Windows Server 2003 R2 Apache Tomcat 6
最後に私の質問は次のとおりです。
私が送信している Xml は私には問題ないように見えます.Solr がこの例外をスローしている理由について誰か考えがありますか?
ありがとう
デイブ
編集回答は次のとおりです。
solr - カスタム Solr Transformer のクラスパス
Solr DataImportHandler のカスタム Transformer サブクラスを作成しました。それはjarファイルにありますが、solrにそれを見つける方法がわかりません。
カスタム トランスフォーマーへのフル パスを使用して data-config.xml ファイルを構成しました。
見つかったすべての /lib、/dist ディレクトリで jar ファイルを試してみたところ、依存ファイルに問題があると思いました。見つからない実際のクラスがログに示されていれば非常に便利ですが、あまり役に立ちません。MyTransformer 仕様を削除すると、dataimporthandler は問題なく動作します。
java - SOLR 検索時にインデックスを選択
これを Nabble グループにも投稿しましたが、ここでアドバイスが得られるかもしれないと考えました。
複数のコアを使用せずに、検索時にSOLRに指定したインデックスを検索させる方法はありますか?
SOLR を使用してインデックスを構築するのではなく、独自の Java クラスを使用して構築しますが、後で検索するために SOLR を使用します。検索時にアクセスするインデックスを Solr に伝えるとよいでしょう。私もそれらを組み合わせましたが、これは機能しますが、私の特定のケースではいくつかの問題があり、検索時にインデックス名/パスを送信することで解決しやすくなります。
ありがとう
drupal-6 - solrのテキスト領域タイプのcckフィールドにインデックスを付ける方法:drupal6
filed_descという名前のtextareaタイプのcckファイルを作成しました。このフィールドをsolrでインデックス化するにはどうすればよいですか。
この記事http://acquia.com/blog/understanding-apachesolr-cck-apiを見つけました。これを試しましたが、ファイルのインデックスが作成されていません。誰かが助けてくれます。
php - 内部にabjectがあるPHP配列の解析
phpのsolrクエリからの応答があります。以下は、drupal6のapachesolrからの応答です。Apache_Solr_Document内のidフィールドにアクセスする必要があります。
print_r($ result);を使用してこれを印刷できました。
配列([タイプ]=>ブックマーク[ノード]=> Apache_Solr_Documentオブジェクト([_documentBoost:protected] => [_fields:protected] =>配列([id] => b17692e4ad53 / node / 274)))
print_r($ result [node]);を実行した場合 私は得ています
Apache_Solr_Document Object([_documentBoost:protected] => [_fields:protected] => Array( [id] => b17692e4ad53 / node / 274))
ここから、IDにアクセスする方法がわかりません。
lucene - SOLR-日付が現在に最も近いドキュメントのスコアを上げるためのブースト機能(bf)
先月から1年後までの範囲の「startTime」フィールドを持つドキュメントを含むsolrインスタンスがあります。startTimeフィールドが現在の時刻に近いドキュメントのスコアを上げるためのブーストクエリ/関数を追加したいと思います。
これまで、rordを使用して新しいドキュメントにブーストを追加する例をたくさん見てきましたが、このような例は見たことがありません。
誰か教えてもらえますか?
ありがとう
search - 検索クエリがドキュメント ID のみを返す必要がある (または返さない) のはなぜですか?
新しいプロジェクトとして、e コマース サイトのシステムを構築しています。アイデアは、サプライヤーから製品をインポートし、それらをカタログに直接挿入する代わりに、すべての情報をステージング エリアに保存することです。各サプライヤーには独自のステージ (つまり、データベース内のテーブル) があり、複数のステージング領域を 1 つのエンティティ (現在は 1 つのテーブルですが、後でおそらく Sphinx または Solr に) にフラット化します。次に、マーチャンダイザーは、ステージング製品の関連フィールド (名前と説明) を検索し、一致する製品のリストを表示して、それらの製品をライブ カタログにプッシュすることを選択できます。検索では、単一のテーブル (フラット化されたステージング領域) に対してクエリが実行されます。
私のデザインでは、名前、説明、supplier_id、supplier_prod_id など、単一のフラット化されたテーブルに検索可能およびフィルター可能なフィールドのみを格納するように呼び出します。検索クエリは、一致するアイテムの ID と、使用されるクラス (supplier_id) のみを返します。製品がどのステージングエリアからのものかを識別します。
別のシニア エンジニアは、平坦化された検索テーブルに他のメタ フィールド (検索対象外) を含める必要があると考えていますが、製品をステージからライブ カタログに「プッシュ」するときに使用できます。彼はまた、クエリがこの他のすべての情報を返す必要があると感じています。
フラット化されたテーブルに検索可能なフィールドのみを持ち、検索でクラス/ID のペアのみが返されるようにすることについて、私はかなり強く感じています。 、3))。
私の推論の一部は、これにより、後でフラット化されたテーブルをデータベースから sphinx や solr などの検索サーバーに切り替えることが容易になり、検索の実装が変更されたという理由だけで残りのコードを変更する必要がなくなるというものです。
私は正しい道を進んでいますか?検索可能なフィールドのみを保持し、ID のみを返すことが重要である理由を他のエンジニアに納得させるにはどうすればよいですか? もっと具体的に言えば、なぜ検索アプリケーションはオブジェクトの ID だけを返さなければならないのでしょうか?
apache - Solrのキーワードフィールドからキーワードのセットを検索するにはどうすればよいですか?
したがって、このスキーマを使用したキーワードフィールドがあります。インデックス付き、トークン化、複数値、TermVectorストア、ノルムの省略
それから私はそれに対してキーワードのセットを検索したい
q = keyword:keyword1、keyword2、keyword3など
最も一致するキーワードを返したい場合は、1つの一致キーワードでも問題ありませんが、最も一致する順に並べ替えます。
ありがとうございました