参见博文:Apache solr入门
配置dataimport参见博文:Apache solr进阶----导入数据库数据
配置定时任务 下载jar包,名字:solr-dataimport-scheduler.jar (jar包自行下载,csdn不允许我免费上传重复资源) 将jar包上传到$SOLR_INSTALL_HOME/server/solr-webapp/webapp/WEB-INF/lib目录下 修改$SOLR_INSTALL_HOME/server/solr-webapp/webapp/WEB-INF/web.xml文件,加入以下内容:(注意ApplicationListener后不要多复制了空格)
org.apache.solr.handler.dataimport.scheduler.ApplicationListener
在$SOLR_INSTALL_HOME/server/solr/conf目录下新增文件 dataimport.properties
详细配置文件参数意义如下:
#################################################
# #
# dataimport scheduler properties #
# 数据端口调度程序 #
# #
#################################################
# tosync or not to sync
# 1- active; anything else - inactive
# 1:启动定时同步程序,其他值均是不启动
syncEnabled=1
# which cores to schedule
# ina multi-core environment you can decide which cores you want syncronized
# leave empty or comment it out if using single-core deployment
# 修改成你所使用的core,多个core用逗号(英文逗号)隔开
syncCores=instance,esbinstance
# solr server name or IP address
# [defaults to localhost if empty]
#这个一般都是localhost不会变
server=localhost
# solr server port
# [defaults to 80 if empty]
# 安装solr的tomcat端口,如果你使用的是默认的端口,就不用改了,否则改成自己的端口就好了
port=8983
# application name/context
# [defaults to current ServletContextListener's context (app) name]
# 这里默认不改(\tomcat\webapp\ 下的solr目录名)
webapp=solr
# URL params [mandatory]
# remainder of URL
# solr同步数据时请求的链接, 如果需要定时同步全部core,去掉连接中的entity参数,即为同步全部core
params=/dataimport?command=delta-import&clean=false&commit=true&optimize=false&wt=json&indent=true&verbose=false&debug=false&entity=INSTANCE_DETAIL
# schedule interval
# number of minutes between two runs
# [defaults to 30 if empty]
#这里是设置定时任务的,单位是分钟,也就是多长时间你检测一次数据同步,根据项目需求修改
interval=10
# 重做索引的时间间隔,单位分钟,默认7200,即5天;
# 为空,为0,或者注释掉:表示永不重做索引
reBuildIndexInterval=0
# 重做索引的参数
reBuildIndexParams=/select?qt=/dataimport&command=full-import&clean=true&commit=true
# 重做索引时间间隔的计时开始时间,第一次真正执行的时间=reBuildIndexBeginTime+reBuildIndexInterval*60*1000;
# 两种格式:2012-04-11 03:10:00 或者 03:10:00,后一种会自动补全日期部分为服务启动时的日期
reBuildIndexBeginTime=03:10:00
重启solr,一方面可以通过观察日志查看同步情况,再者可以通过在界面查询数据来验证定时任务是否有在正常运作