Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mirrored stream stops when an invalid source Nats-Expected-Last-Subject-Sequence appears [v2.10.20] #5865

Open
VeryStrongFingers opened this issue Sep 8, 2024 · 2 comments
Assignees
Labels
defect Suspected defect such as a bug or regression stale This issue has had no activity in a while

Comments

@VeryStrongFingers
Copy link

VeryStrongFingers commented Sep 8, 2024

Observed behavior

Creating a Mirrored stream using a source that contains messages with Nats-Expected-Last-Subject-Sequence headers still performs sequence checks as per the source stream once performed.

Expected behavior

Mirrored streams to ignore Nats-Expected-Last-Subject-Sequence headers (also possibly other 'Expect' headers?).

Existence of the message in the source alone means the original assertion was valid.
There is no need for a mirror to have the same expectations and checks as the original source stream.

Alternatively an option for mirrored streams to remove source headers would work too for a resolution. (#5409)

Server and client version

nats-cli: 0.1.5
nats-server: v2.10.20

Host environment

Tested in both Linux/amd64 & Darwin/arm64

Steps to reproduce

# Create stream
nats stream create cool_stream \
	--subjects="cool.*" --storage=file \
	--replicas=1 --retention=limits \
	--discard=old --max-msgs=-1 --max-msgs-per-subject=-1 \
	--max-bytes=-1 --ack --max-age=-1 --max-msg-size=-1 \
	--dupe-window=2m0s --allow-rollup \
	--no-deny-delete --no-deny-purge

# Publish a bunch of messages
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:0"  "a"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:1"  "b"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:2"  "c"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:3"  "d"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:4"  "e"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:5"  "f"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:6"  "g"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:7"  "h"

# Remove sequence number 5 from stream (message body: e)
nats stream rmm cool_stream 5 -f

# Create mirrored stream (after messages are already published)
nats stream create cool_stream_mirrored \
	--storage=file --replicas=1 \
	--retention=limits --discard=old \
	--max-msgs=-1 --max-msgs-per-subject=-1 \
	--max-bytes=-1 --ack --max-age=-1 \
	--max-msg-size=-1 --dupe-window=2m0s \
	--allow-rollup --no-deny-delete \
	--no-deny-purge --mirror=cool_stream

# Publish some more messages

nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:8"  "i"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:9"  "j"
nats pub "cool.aaa" --header "Nats-Expected-Last-Subject-Sequence:10"  "k"

# View streams
nats stream ls
╭────────────────────────────────────────────────────────────────────────────────────────────╮
│                                           Streams                                          │
├──────────────────────┬─────────────┬─────────────────────┬──────────┬───────┬──────────────┤
│ Name                 │ Description │ Created             │ Messages │ Size  │ Last Message │
├──────────────────────┼─────────────┼─────────────────────┼──────────┼───────┼──────────────┤
│ cool_stream_mirrored │             │ 2024-09-08 21:35:20 │ 4        │ 376 B │ 15m12s       │
│ cool_stream          │             │ 2024-09-08 19:37:21 │ 10       │ 943 B │ 2.25s        │
╰──────────────────────┴─────────────┴─────────────────────┴──────────┴───────┴──────────────╯

cool_stream_mirrored stream will no longer mirror any new messages because of the invalid Nats-Expected-Last-Subject-Sequence header

[36649] 2024/09/08 21:35:20.258473 [WRN] Error processing inbound mirror message for '$G' > 'cool_stream_mirrored': last sequence by subject mismatch: 5 vs 4

Relevant code seems to be

  • nats-server/server/stream.go

    Lines 2468 to 2474 in 7f92c34

    if err != errLastSeqMismatch {
    mset.mu.RLock()
    accName, sname := mset.acc.Name, mset.cfg.Name
    mset.mu.RUnlock()
    s.RateLimitWarnf("Error processing inbound mirror message for '%s' > '%s': %v",
    accName, sname, err)
    } else {
  • nats-server/server/stream.go

    Lines 4742 to 4752 in 7f92c34

    if err != nil || fseq != seq {
    mset.mu.Unlock()
    bumpCLFS()
    if canRespond {
    resp.PubAck = &PubAck{Stream: name}
    resp.Error = NewJSStreamWrongLastSequenceError(fseq)
    b, _ := json.Marshal(resp)
    outq.sendMsg(reply, b)
    }
    return fmt.Errorf("last sequence by subject mismatch: %d vs %d", seq, fseq)
    }
@VeryStrongFingers VeryStrongFingers added the defect Suspected defect such as a bug or regression label Sep 8, 2024
@derekcollison
Copy link
Member

Yes this is a known issue we plan on improving in 2.11.

@derekcollison derekcollison self-assigned this Sep 10, 2024
@wallyqs wallyqs changed the title Mirrored stream stops when an invalid source Nats-Expected-Last-Subject-Sequence appears Mirrored stream stops when an invalid source Nats-Expected-Last-Subject-Sequence appears [v2.10.20] Sep 13, 2024
@m3nowak
Copy link

m3nowak commented Oct 15, 2024

There is a similar issue with messages containing the 'Nats-Expected-Stream' header. They won’t be sent to the mirrored stream unless it is named the same as the source stream.

@github-actions github-actions bot added the stale This issue has had no activity in a while label Dec 11, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
defect Suspected defect such as a bug or regression stale This issue has had no activity in a while
Projects
None yet
Development

No branches or pull requests

3 participants