2017-05-19 3 views
0

Ich habe versucht, PDF-Dokumente mit Cloudera Search aka Apache Solr zu indizieren. Zuerst konnte ich Twitter-Tweets indizieren. Später habe ich versucht, PDF-Dateien zu indizieren. Ich habe die entsprechende Sammlung mit solrctl mit Standardschema erstellt. Die morphline Datei, die ich verwendet, ist (ich habe die IP-Adresse zkHost hier maskiert) ...Indizierung von PDF-Dokumenten mit Cloudera Suche

solrLocator : { 
    # Name of solr collection 
    #collection : collection1 
    collection : pdfs 

    # ZooKeeper ensemble 
    #zkHost : "127.0.0.1:2181/solr" 
    zkHost : "xxx.xxx.xxx.xxx:2181,xxx.xxx.xxx.xxx:2181/solr" 

    # The maximum number of documents to send to Solr per network batch (throughput knob) 
    # batchSize : 100 
} 
morphlines : [ 

{ 

id : morphlinepdfs 

importCommands : ["org.kitesdk.**", "org.apache.solr.**"] 

commands : [ 

{ detectMimeType { includeDefaultMimeTypes : true } } 

{ 

solrCell { 

solrLocator : ${solrLocator} 

captureAttr : true 

lowernames : true 

capture : [id, title, author, content, content_type, subject, description, keywords, category, resourcename, url, last_modified, links] 

parsers : [ { parser : org.apache.tika.parser.pdf.PDFParser } ] 

} 

} 

{ generateUUID { field : id } } 

{ sanitizeUnknownSolrFields { solrLocator : ${solrLocator} } } 

{ loadSolr: { solrLocator : ${solrLocator} } } 

] 

} 

] 

Die PDF-Metadatenfelder vorhanden sind, in schema.xml Datei wie ...

<field name="title" type="text_general" indexed="true" stored="true" multiValued="true"/> 
    <field name="subject" type="text_general" indexed="true" stored="true"/> 
    <field name="description" type="text_general" indexed="true" stored="true"/> 
    <field name="comments" type="text_general" indexed="true" stored="true"/> 
    <field name="author" type="text_general" indexed="true" stored="true"/> 
    <field name="keywords" type="text_general" indexed="true" stored="true"/> 
    <field name="category" type="text_general" indexed="true" stored="true"/> 
    <field name="resourcename" type="text_general" indexed="true" stored="true"/> 
    <field name="url" type="text_general" indexed="true" stored="true"/> 
    <field name="content_type" type="string" indexed="true" stored="true" multiValued="true"/> 
    <field name="last_modified" type="date" indexed="true" stored="true"/> 
    <field name="links" type="string" indexed="true" stored="true" multiValued="true"/> 

Aber in der Solr/Select-Abfrage-Ausgabe, bekomme ich nur Inhalte und Inhaltstyp Felder. Wie bekomme ich alle Metadaten in der Solr-Frontend-Abfrage? Muss ich die schema.xml oder die entsprechende Morphline-Datei ändern? Kann ich auch die Felder innerhalb des PDF-Inhalts indizieren?

Der Befehl I Index pdf-Datei verwendet wird:

hadoop --config /etc/hadoop/conf.cloudera.yarn jar /usr/lib/solr/contrib/mr/search-mr-1.0.0-cdh5.8.2-job.jar org.apache.solr.hadoop.MapReduceIndexerTool -D 'mapred.child.java.opts=-Xmx500m' --log4j /usr/share/doc/search-1.0.0+cdh5.8.2+0/examples/solr-nrt/log4j.properties --morphline-file /usr/share/doc/search-1.0.0+cdh5.8.2+0/examples/solr-nrt/test-morphlines/solrPDF.conf --output-dir hdfs://xxxxxx:8020/user/root/outdir --verbose --go-live --zk-host xxxxx:2181/solr --collection pdfs hdfs://xxxxxx:8020/user/root/indir 

Vielen Dank im Voraus.

Antwort

0

Ich habe das Problem gefunden. Die von mir verwendete PDF-Datei enthält keine Metadaten. Ich habe es mit anderen PDF-Dateien versucht und die Ergebnisse erhalten. Hoffe es hilft anderen.