[root@nutch nutch2]# wget http://archive.apache.org/dist/lucene/solr/4.2.0/solr-4.2.0.tgz
[root@nutch nutch2]# tar -xzvf solr-4.2.0.tgz
#把nutch/conf/schema.xml复制到solr/collection1/conf
在solr4.2.0版本中,我们需要把nutch的schema-solr4.xml文件复制到collection1下的conf目录内,指定为schema.xml
[root@nutch nutch2]# cp /home/nutch2/release-1.6/runtime/local/conf/schema-solr4.xml /home/nutch2/solr-4.2.0/example/solr/collection1/conf/schema.xml
[root@nutch example]# java -jar start.jar &
启动之后报错:
_version_ does not exist
Unable to use updateLog: _version_field must exist in schema, using indexed="true" stored="true" and multiValued="false" (_version_ does not exist)
不存在_version_字段
解决方案:
修改solr/collection1/conf/schema.xml,在<fields>下增加:<field name=”_version_” type=”long” indexed=”true” stored=”true”/>
[root@nutch example]# jps
4625 jar
4664 Jps
[root@nutch example]# kill -9 4625
[root@nutch example]#
在solr4.2.0版本中,我们不再需要把solr/conf/solrconfig.xml文件里的<str name=”df”>text</str>都替换为<str name=”df”>content</str>
[root@nutch example]# java -jar start.jar &
http://192.168.1.49:8983/solr/
我们在不配分词的情况下提交索引,它使用默认的分词。但默认分词效果并不是我们想要的。所以,我们给solr配置mmseg4j分词器。
[root@nutch example]# jps
5927 Jps
5853 jar
[root@nutch example]# kill -9 5853
[root@nutch nutch2]# wget http://mmseg4j.googlecode.com/files/mmseg4j-1.9.1.v20130120-SNAPSHOT.zip
[root@nutch nutch2]# unzip mmseg4j-1.9.1.v20130120-SNAPSHOT.zip -d mmseg4j-1.9.1
[root@nutch nutch2]# mkdir solr-4.2.0/example/solr/collection1/lib
[root@nutch nutch2]# cp mmseg4j-1.9.1/mmseg4j-1.9.1-SNAPSHOT/dist/* solr-4.2.0/example/solr/collection1/lib
[root@nutch nutch2]# vi solr-4.2.0/example/solr/collection1/conf/schema.xml
把<tokenizer class="solr.WhitespaceTokenizerFactory"/>和<tokenizer class="solr.StandardTokenizerFactory"/>替换为<tokenizer class="com.chenlb.mmseg4j.solr.MMSegTokenizerFactory" mode="complex"/>
复制jar包
替换schema分词器
[root@nutch example]# java -jar start.jar &
[root@nutch local]# bin/nutch solrindex http://192.168.1.49:8983/solr/ data/crawldb/ -linkdb data/linkdb/ -dir data/segments/