Kotlin 为什么Sinks.many().multicast().onBackpressureBuffer()会在其中一个订阅者取消订阅后完成,以及如何避免

Kotlin 为什么Sinks.many().multicast().onBackpressureBuffer()会在其中一个订阅者取消订阅后完成,以及如何避免,kotlin,spring-webflux,project-reactor,reactive-streams,Kotlin,Spring Webflux,Project Reactor,Reactive Streams,我在使用接收器时遇到了一种我不理解的行为。许多向多个订阅者通知某些事件: fun main() { val sink : Sinks.Many<String> = Sinks.many().multicast().onBackpressureBuffer() val flux = sink.asFlux().log() val d = flux.subscribe { println("--> $it")

我在使用
接收器时遇到了一种我不理解的行为。许多
向多个订阅者通知某些事件:

fun main() {

    val sink : Sinks.Many<String>  = Sinks.many().multicast().onBackpressureBuffer()
    val flux = sink.asFlux().log()

    val d = flux.subscribe {
        println("--> $it")
    }

    sink.emitNext("1", Sinks.EmitFailureHandler.FAIL_FAST)

    val d2 = flux.subscribe {
        println("--2> $it")
    }

    sink.emitNext("2", Sinks.EmitFailureHandler.FAIL_FAST)
}
现在,假设第一个用户在第一次发射后处理(取消)其订阅,我希望第一个用户得到1,第二个用户得到2:


    val sink : Sinks.Many<String>  = Sinks.many().multicast().onBackpressureBuffer()
    val flux = sink.asFlux().log()

    val d = flux.subscribe {
        println("--> $it")
    }

    sink.emitNext("1", Sinks.EmitFailureHandler.FAIL_FAST)

    d.dispose()

    val d2 = flux.subscribe {
        println("--2> $it")
    }

    sink.emitNext("2", Sinks.EmitFailureHandler.FAIL_FAST)

}

但是,当第二个订户尝试订阅时,流量被视为已完成。为什么会这样?我需要水槽。许多水槽随时可用,可以在不取消订阅的情况下订阅和取消订阅。

我刚刚遇到了同样的问题

它是由autoCancel默认为true引起的。不幸的是,报告没有提到这一点

这种行为是从记录的地方继承的

要将autoCancel标志设置为false,必须使用替代项

Many sink=Sinks.Many().multicast().onBackpressureBuffer(Queues.SMALL\u BUFFER\u SIZE,false);

    val sink : Sinks.Many<String>  = Sinks.many().multicast().onBackpressureBuffer()
    val flux = sink.asFlux().log()

    val d = flux.subscribe {
        println("--> $it")
    }

    sink.emitNext("1", Sinks.EmitFailureHandler.FAIL_FAST)

    d.dispose()

    val d2 = flux.subscribe {
        println("--2> $it")
    }

    sink.emitNext("2", Sinks.EmitFailureHandler.FAIL_FAST)

}
11:51:48.684 [main] INFO reactor.Flux.EmitterProcessor.1 - onSubscribe(EmitterProcessor.EmitterInner)
11:51:48.685 [main] INFO reactor.Flux.EmitterProcessor.1 - request(unbounded)
11:51:48.689 [main] INFO reactor.Flux.EmitterProcessor.1 - onNext(1)
--> 1
11:51:48.689 [main] INFO reactor.Flux.EmitterProcessor.1 - cancel()
11:51:48.689 [main] INFO reactor.Flux.EmitterProcessor.1 - onSubscribe(EmitterProcessor.EmitterInner)
11:51:48.689 [main] INFO reactor.Flux.EmitterProcessor.1 - request(unbounded)
11:51:48.690 [main] INFO reactor.Flux.EmitterProcessor.1 - onComplete()