在 2022/02/02 1:20, Tejun Heo 写道:
Hello,
On Thu, Jan 27, 2022 at 10:36:38AM +0800, yukuai (C) wrote:
In our case, the disk is provided by server, and such disk can be shared
by multipul clients. Thus for the client side, the server is a higher
level parent.
Theoretically, limit the io from server for each client is feasible,
however, the main reason we don't want to do this is the following
shortcoming:
client can still send io to server unlimited, we can just limit the
amount of io that can complete from server, which might cause too much
pressure on the server side.
I don't quite follow the "send io to server unlimited" part. Doesn't that
get limited by available number of requests?
Hi, Tejun
Here I mean that io is not limited through io throttle from client. Of
course io must be limited by avaliable number of requests.
ie. if the server throttles,
the in-flight requests will take longer to complete which exhausts the
available requests and thus slows down the client.
For example, if we have 8 clients, and available requests is 64.
1) If we don't limit iops, and each client send 64 io to server, some
client might have performance issue.
2) If we limit iops to 8 from clients, then server can receive 64 io at
most at the same time, both client and server should work fine.
3) If we limit iops to 8 for each client from server, client should work
fine, however, server can receive 64 x 8 = 512 io at most at the same
time, which might cause too much pressure on the server.(maybe bps is
more appropriate to explain the high pressure).
Thus I prefer to limit io from client.
Thanks,
Kuai
That's how it's supposed
to work on the local machine too.
Thanks.