If you give a read to the official documentation , you will see that:
Nothing happens until you subscribe
Now to understand, In spring boot webflux based microservice, who is the subscriber?, have a look at this stackoverflow question
Now, if you think, you can have blocking and reactive implementations in the same service, unfortunately, it doesn't work like that. For this you have to understand the event loop model on which reactor works. Thus calling a block method at any point in the flow is of no good and is equivalent to using the old blocking spring-web methods. Because the thread in which the request is being processed gets blocked and waits for the outcome of the I/O operation / network call.
Coming to your question in the comment:
But when i use flatMap in my controller to call handler method it goes service method with Object not mono?serviceRequest-->Mono-->Object how this works?
Let me give you a simple example for this:
Suppose you have an employee application, where you want to fetch details of an employee for a given id.
Now in your controller, you will have an endpoint like this:
@GetMapping("/{tenant}/api/employee/{id}")
public Mono<ResponseEntity> getEmployeeDetails(@PathVariable("id") Long employeeId) {
return employeeService.getDetails(employeeId)
.map(ResponseEntity::ok);
}
Now in your service,
public Mono<EmployeeEntity> getDetails(Long employeeId) {
return employeeRepository.findById(employeeId);
}
And your repository will look like this:
@Repository
public interface EmployeeRepository extends ReactiveCrudRepository<EmployeeEntity, Long> {
}
mapis lazy.Mono<String> jsonString. If it is completely impossible to do that (for example, you're using a database that doesn't have a reactive driver), then you'll need to callblock()to "exit" the reactive context and retrieve your value. (I think that what you mean by "fails most of the time" is simply that you were outputting from inside the pipeline and didn't always see it. If you'd put asleepin the place you calledsubscribe()and given it time to run, you'd probably have seen it.)Mono. If that is not possible, you have to callblock()and pass the result. (block()interrupts the reactive processing, so it is less efficient than passing aMonoorFlux, but if you must work with non-reactive services, then that's what you do.)