Skip to content
This repository has been archived by the owner on May 1, 2023. It is now read-only.

raditzlawliet/solr-copy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Warning Project will be archived as read-only. This project still can be use, But there will be no update until unknown date announcement.

Solr Copy

Golang library for copy collection from Solr to Solr/MongoDB with Solr API. This project already using dep as package manager.

Available Source

  • Solr 6.6

Available Target

  • Solr 6.6
  • MongoDB 3.6

Sample

Example copy old data into new data with modified date into new date

{
	// we want to insert new data (with old data) instead re-indexing
	InsertNewData := true
	sConf := model.SolrConfig{
		SourceHost:       "http://192.168.70.230:8983/solr/",
		TargetHost:       "http://192.168.70.230:8983/solr/",
		Source:           "searchLog",
		Target:           "searchLog",
		SourceQuery:      "*:*&sort=date+asc,id+asc&fq=date:[2017-01-01T00:00:00Z%20TO%202017-02-01T00:00:00Z]",
		SourceCursorMark: "*", 
		SourceRows:       10000,
		Max:              1, // -1 / 0 to fetch all data
		ReadOnly:         true, // false to commit after process
		DataProcess: func(data map[string]interface{}) map[string]interface{} {
			if datei, ok := data["date"]; ok {
				datestr := datei.(string)
				layout := "2006-01-02T15:04:05Z"
				date, err := time.Parse(layout, datestr)
				if err != nil {
					log.Error(err)
				}
				newDate := date.AddDate(1, 4, 0)
				newDatestr := newDate.Format(layout)
				data["date"] = newDatestr
			}
			if InsertNewData {
				delete(data, "id") 
			}
			return data
		},
	}
	solr.Copy(sConf)
}

About

Golang library for copy collection from Solr to Solr/MongoDB with Solr API

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published