Skip to content

Commit adba6b2

Browse files
committed
Example for change streams in MongoDB 3.6
1 parent a844f00 commit adba6b2

File tree

5 files changed

+95
-0
lines changed

5 files changed

+95
-0
lines changed

mongodriver/.gitignore

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
/.settings/
2+
/target/

mongodriver/pom.xml

Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
<?xml version="1.0"?>
2+
<project
3+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
4+
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
5+
<modelVersion>4.0.0</modelVersion>
6+
<parent>
7+
<groupId>de.codecentric</groupId>
8+
<artifactId>springdata-examples</artifactId>
9+
<version>1.0.0</version>
10+
</parent>
11+
<groupId>de.codecentric</groupId>
12+
<artifactId>mongodriver</artifactId>
13+
<version>1.0.0</version>
14+
<name>mongodb36</name>
15+
<url>http://maven.apache.org</url>
16+
<properties>
17+
<mongo.driver.version>3.6.0</mongo.driver.version>
18+
</properties>
19+
20+
<dependencies>
21+
<dependency>
22+
<groupId>org.mongodb</groupId>
23+
<artifactId>mongo-java-driver</artifactId>
24+
<version>${mongo.driver.version}</version>
25+
</dependency>
26+
</dependencies>
27+
</project>
Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
package de.codecentric.notifications;
2+
3+
import org.bson.Document;
4+
5+
import com.mongodb.MongoClient;
6+
import com.mongodb.MongoClientURI;
7+
import com.mongodb.client.MongoCollection;
8+
9+
public class DocumentProducer {
10+
11+
public static void main(String[] args) throws Exception {
12+
13+
MongoCollection<Document> eventCollection =
14+
new MongoClient(
15+
new MongoClientURI("mongodb://localhost:27001,localhost:27002,localhost:27003/test?replicatSet=demo-dev")
16+
).getDatabase("test").getCollection("events");
17+
18+
long i = 0;
19+
while (true) {
20+
Document doc = new Document();
21+
doc.put("i", i++);
22+
doc.put("even", i % 2);
23+
eventCollection.insertOne(doc);
24+
//System.out.println("inserted: " + doc);
25+
Thread.sleep(2000L + (long)(1000*Math.random()));
26+
}
27+
}
28+
}
Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
package de.codecentric.notifications;
2+
3+
import static java.util.Arrays.asList;
4+
5+
import org.bson.Document;
6+
7+
import com.mongodb.Block;
8+
import com.mongodb.MongoClient;
9+
import com.mongodb.MongoClientURI;
10+
import com.mongodb.client.ChangeStreamIterable;
11+
import com.mongodb.client.MongoCollection;
12+
import com.mongodb.client.model.Aggregates;
13+
import static com.mongodb.client.model.Filters.*;
14+
import com.mongodb.client.model.changestream.ChangeStreamDocument;
15+
16+
public class EventListener {
17+
public static void main(String[] args) throws Exception {
18+
19+
MongoCollection<Document> eventCollection =
20+
new MongoClient(
21+
new MongoClientURI("mongodb://localhost:27001,localhost:27002,localhost:27003/test?replicatSet=demo-dev")
22+
).getDatabase("test").getCollection("events");
23+
24+
ChangeStreamIterable<Document> changes = eventCollection.watch(asList(
25+
Aggregates.match( and( asList(
26+
in("operationType", asList("insert")),
27+
eq("fullDocument.even", 1L)))
28+
)));
29+
30+
changes.forEach(new Block<ChangeStreamDocument<Document>>() {
31+
@Override
32+
public void apply(ChangeStreamDocument<Document> t) {
33+
System.out.println("received: " + t.getFullDocument());
34+
}
35+
});
36+
}
37+
}

pom.xml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,7 @@
1515
<module>springdata-neo4j</module>
1616
<module>springdata-jpa</module>
1717
<module>spring-boot-mongo</module>
18+
<module>mongodb36</module>
1819
</modules>
1920

2021
<properties>

0 commit comments

Comments
 (0)