Details
-
Improvement
-
Status: Resolved
-
Major
-
Resolution: Workaround
-
None
-
None
-
None
Description
I should be able to pipe JSON/XML/CSV or whatever is possible at the /update/* to a command which in turn uses SolrJ to send the docs to the correct leader in native format.
In the following examples , all connection details of the cluster is put into a file called solrj.properties
example :
#post a file cat myjson.json | bin/post -c gettingstarted -s http://localhost:8983/solr #or a producer program myprogram | bin/post -c gettingstarted -s http://localhost:8983/solr
The behavior of the script would be exactly similar to the behavior if I were to post the request directly to solr to the specified qt . Everything parameter the requesthandler accepts would be accepted as a -<param-name>=<param-value> format. The same things could be put into a properties file called indexer.properties and be passed as a -p parameter. The script would expect the following extra properties zk.url for cloud or solr.url for standalone.
post.jar already reads from stdin if you pass -Ddata=stdin. Does not use SolrJ though, but perhaps it is time for bin/post to start using SolrJ?
The open-ended -<param-name>=<param-value> is scary if a request handler's param overlaps with script args.