Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rwynn/redisetgo
Continuously index your MongoDB data stream in RediSearch
https://github.com/rwynn/redisetgo
mongodb redisearch search streaming
Last synced: 2 months ago
JSON representation
Continuously index your MongoDB data stream in RediSearch
- Host: GitHub
- URL: https://github.com/rwynn/redisetgo
- Owner: rwynn
- License: mit
- Created: 2019-05-02T00:40:37.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-07-15T16:58:14.000Z (over 4 years ago)
- Last Synced: 2024-06-20T14:25:04.729Z (7 months ago)
- Topics: mongodb, redisearch, search, streaming
- Language: Go
- Homepage:
- Size: 60.5 KB
- Stars: 8
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# redisetgo
Continuously index your MongoDB data stream in [RediSearch](https://redislabs.com/redis-enterprise/technology/redis-search/).
### setup MongoDB
Before running redisetgo you will need to ensure that MongoDB is setup as a replica set.
Following the instructions for [deploying a replica set](http://docs.mongodb.org/manual/tutorial/deploy-replica-set/).
If you haven't already done so,
follow the 5 step [procedure](https://docs.mongodb.com/manual/tutorial/deploy-replica-set/#procedure)
to initiate and validate your replica set.For local testing your replica set may contain a
[single member](https://docs.mongodb.com/manual/tutorial/convert-standalone-to-replica-set/).### testing with docker
Start up a redisearch server
```
docker run --rm -p 6379:6379 redislabs/redisearch:latest
```Start up a redis client to inspect indexes
```
docker run --rm -it --network host redislabs/redisearch redis-cli
```Start up the redisetgo daemon
```
go run redisetgo.go
INFO 2019/05/01 14:33:31 Watching changes on the deployment
```Create a document in MongoDB
```
rs1:PRIMARY> use test;
switched to db test
rs1:PRIMARY> db.test.insert({foo: 1})
```Run a query via redis-cli to ensure the indexing was successful
```
127.0.0.1:6379> FT.SEARCH test.test *
1) (integer) 1
2) "test.test.5cc9ae490862227ef20c3116"
3) 1) "foo"
2) "1"
```### configure redisetgo
You can configure redisetgo via flags and/or a TOML config file. The most important options are the
connection settings. By default redisetgo will look to connect to MongoDB and RedisSearch on localhost
at the default ports. You can change this via```
redisetgo -mongo mongodb://user:pass@hostname:port -redis hostname:6379
```The MongoDB URL can be customized with
[advanced settings](https://github.com/mongodb/mongo-go-driver/blob/v1.0.2/x/network/connstring/connstring.go)
for security, etc.For Redisearch you can provide a comma separated list of host:port,host:port...
### customize the behavior with modules
You can write you own modules to change the behavior. See examples/plugin.go for an example.
To build and run the example plugin,
```
cd examples
go build -buildmode=plugin
cd ..
go run redisetgo.go -plugin examples/examples.so
```In this case we have just one plugin but you can have multiple
```
go run redisetgo.go -plugin myplugins/p1.so -plugin myplugins/p2.so```
Test the example plugin by inserting some data into MongoDB
```
rs1:PRIMARY> use test;
switched to db test
rs1:PRIMARY> db.test.insert({foo: "ok", bar: "ignored"}) // succeeds
rs1:PRIMARY> db.test.insert({foo: 1}) // fails as designed
```Search for the data in RediSearch
```
127.0.0.1:6379> FT.SEARCH my-index *
1) (integer) 1
2) "5cd3131ba169676422407f1a"
3) 1) "foo"
2) "ok"
```