Skip to content

Commit

Permalink
Move new JetStream API docs to top level README (#1352)
Browse files Browse the repository at this point in the history
  • Loading branch information
piotrpio committed Jul 20, 2023
1 parent 83e1310 commit 4354bd9
Show file tree
Hide file tree
Showing 2 changed files with 110 additions and 71 deletions.
98 changes: 27 additions & 71 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -90,91 +90,47 @@ nc.Drain()
nc.Close()
```

## JetStream Basic Usage
## JetStream

> __NOTE__
>
> We encourage you to try out a new, simplified version on JetStream API.
> The new API is currently in preview and is available under `jetstream` package.
>
> You can find more information on the new API [here](https://github.com/nats-io/nats.go/blob/main/jetstream/README.md)
JetStream is the built-in NATS persistence system. `nats.go` provides a built-in
API enabling both managing JetStream assets as well as publishing/consuming
persistent messages.

```go
import "github.com/nats-io/nats.go"
### Basic usage

// Connect to NATS
```go
// connect to nats server
nc, _ := nats.Connect(nats.DefaultURL)

// Create JetStream Context
js, _ := nc.JetStream(nats.PublishAsyncMaxPending(256))

// Simple Stream Publisher
js.Publish("ORDERS.scratch", []byte("hello"))

// Simple Async Stream Publisher
for i := 0; i < 500; i++ {
js.PublishAsync("ORDERS.scratch", []byte("hello"))
}
select {
case <-js.PublishAsyncComplete():
case <-time.After(5 * time.Second):
fmt.Println("Did not resolve in time")
}

// Simple Async Ephemeral Consumer
js.Subscribe("ORDERS.*", func(m *nats.Msg) {
fmt.Printf("Received a JetStream message: %s\n", string(m.Data))
})

// Simple Sync Durable Consumer (optional SubOpts at the end)
sub, err := js.SubscribeSync("ORDERS.*", nats.Durable("MONITOR"), nats.MaxDeliver(3))
m, err := sub.NextMsg(timeout)

// Simple Pull Consumer
sub, err := js.PullSubscribe("ORDERS.*", "MONITOR")
msgs, err := sub.Fetch(10)

// Unsubscribe
sub.Unsubscribe()

// Drain
sub.Drain()
```

## JetStream Basic Management
// create jetstream context from nats connection
js, _ := jetstream.New(nc)

```go
import "github.com/nats-io/nats.go"
ctx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()

// Connect to NATS
nc, _ := nats.Connect(nats.DefaultURL)
// get existing stream handle
stream, _ := js.Stream(ctx, "foo")

// Create JetStream Context
js, _ := nc.JetStream()
// retrieve consumer handle from a stream
cons, _ := stream.Consumer(ctx, "cons")

// Create a Stream
js.AddStream(&nats.StreamConfig{
Name: "ORDERS",
Subjects: []string{"ORDERS.*"},
// consume messages from the consumer in callback
cc, _ := cons.Consume(func(msg jetstream.Msg) {
fmt.Println("Received jetstream message: ", string(msg.Data()))
msg.Ack()
})
defer cc.Stop()
```

// Update a Stream
js.UpdateStream(&nats.StreamConfig{
Name: "ORDERS",
MaxBytes: 8,
})
To find more information on `nats.go` JetStream API, visit
[`jetstream/README.md`](jetstream/README.md)

// Create a Consumer
js.AddConsumer("ORDERS", &nats.ConsumerConfig{
Durable: "MONITOR",
})
> The current JetStream API replaces the [legacy JetStream API](legacy_jetstream.md)
// Delete Consumer
js.DeleteConsumer("ORDERS", "MONITOR")
## Service API

// Delete Stream
js.DeleteStream("ORDERS")
```
The service API (`micro`) allows you to [easily build NATS services](micro/README.md) The
services API is currently in beta release.

## Encoded Connections

Expand Down
83 changes: 83 additions & 0 deletions legacy_jetstream.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
# Legacy JetStream API

This is a documentation for the legacy JetStream API. A README for the current
API can be found [here](jetstream/README.md)

## JetStream Basic Usage

```go
import "github.com/nats-io/nats.go"

// Connect to NATS
nc, _ := nats.Connect(nats.DefaultURL)

// Create JetStream Context
js, _ := nc.JetStream(nats.PublishAsyncMaxPending(256))

// Simple Stream Publisher
js.Publish("ORDERS.scratch", []byte("hello"))

// Simple Async Stream Publisher
for i := 0; i < 500; i++ {
js.PublishAsync("ORDERS.scratch", []byte("hello"))
}
select {
case <-js.PublishAsyncComplete():
case <-time.After(5 * time.Second):
fmt.Println("Did not resolve in time")
}

// Simple Async Ephemeral Consumer
js.Subscribe("ORDERS.*", func(m *nats.Msg) {
fmt.Printf("Received a JetStream message: %s\n", string(m.Data))
})

// Simple Sync Durable Consumer (optional SubOpts at the end)
sub, err := js.SubscribeSync("ORDERS.*", nats.Durable("MONITOR"), nats.MaxDeliver(3))
m, err := sub.NextMsg(timeout)

// Simple Pull Consumer
sub, err := js.PullSubscribe("ORDERS.*", "MONITOR")
msgs, err := sub.Fetch(10)

// Unsubscribe
sub.Unsubscribe()

// Drain
sub.Drain()
```

## JetStream Basic Management

```go
import "github.com/nats-io/nats.go"

// Connect to NATS
nc, _ := nats.Connect(nats.DefaultURL)

// Create JetStream Context
js, _ := nc.JetStream()

// Create a Stream
js.AddStream(&nats.StreamConfig{
Name: "ORDERS",
Subjects: []string{"ORDERS.*"},
})

// Update a Stream
js.UpdateStream(&nats.StreamConfig{
Name: "ORDERS",
MaxBytes: 8,
})

// Create a Consumer
js.AddConsumer("ORDERS", &nats.ConsumerConfig{
Durable: "MONITOR",
})

// Delete Consumer
js.DeleteConsumer("ORDERS", "MONITOR")

// Delete Stream
js.DeleteStream("ORDERS")
```

0 comments on commit 4354bd9

Please sign in to comment.