On Mon, Apr 23, 2012 at 02:42:40PM +0200, Jan Kara wrote: > On Mon 23-04-12 18:24:20, Wu Fengguang wrote: > > On Mon, Apr 23, 2012 at 11:14:32AM +0200, Jan Kara wrote: > > > On Fri 20-04-12 21:34:41, Wu Fengguang wrote: > > > > But be warned! Partitioning the dirty pages always means more > > > > fluctuations of dirty rates (and even stalls) that's perceivable by > > > > the user. Which means another limiting factor for the backpressure > > > > based IO controller to scale well. > > > Sure, the smaller the memcg gets, the more noticeable these fluctuations > > > would be. I would not expect memcg with 200 MB of memory to behave better > > > (and also not much worse) than if I have a machine with that much memory... > > > > It would be much worse if it's one single flusher thread round robin > > over the cgroups... > > > > For a small machine with 200MB memory, its IO completion events can > > arrive continuously over time. However if its a 2000MB box divided > > into 10 cgroups and the flusher is writing out dirty pages, spending > > 0.5s on each cgroup and then go on to the next, then for any single > > cgroup, its IO completion events go quiet for every 9.5s and goes up > > on the other 0.5s. It becomes really hard to control the number of > > dirty pages. > Umm, but flusher does not spend 0.5s on each cgroup. It submits 0.5s > worth of IO for each cgroup. Right. > Since the throughput computed for each cgroup > will be scaled down accordingly (and thus write_chunk will be scaled down > as well), it should end up submitting 0.5s worth of IO for the whole system > after it traverses all the cgroups, shouldn't it? Effectively we will work > with smaller write_chunk which will lead to lower total throughput - that's > the price of partitioning and higher fairness requirements (previously the Sure you can do that. However I think we were talking about memcg dirty limits, in which case we still have good chances to keep the 0.5s per inode granularity by making the dirty limits high so that it won't be hit normally. Only when there comes lots of memory cgroups that the flusher cannot easily safeguard fairness among them, we may consider decreasing the writeback chunk size. > requirement was to switch to a new inode every 0.5s, now the requirement is > to switch to a new inode in each cgroup every 0.5s). In the end, we may end > up increasing the write_chunk by some factor like \sqrt(number of memcgs) > to get some middle ground between the guaranteed small latency and > reasonable total throughput but before I'd go for such hacks, I'd wait to > see real numbers - e.g. paying 10% of total throughput for partitioning the > machine into 10 IO intensive cgroups (as in your tests with dd's) would be > a reasonable cost in my opinion. For IO cgroups, I'd always prefer to avoid partitioning the dirty pages and async IO queue so as to avoid such embarrassing tradeoffs in the first place :-) > Also the granularity of IO completions should depend more on the > granularity of IO scheduler (CFQ) rather than the granularity of flusher > thread as such so I wouldn't think that would be a problem. By avoiding the partitions, we'll cancel the fairness problem. So the coarse granularity of flusher won't be a problem for IO cgroups at all. balance_dirty_pages() will do proper throttling when dirty pages are created, based directly on the blkcg weights and ongoing IO. After that all async IOs go as a single stream from the flusher to the storage. There are no need for page tracking. No split inode lists and hence granularity or shared inodes issues for the flusher. Above all there will be no degradation of performance at all, whether it be throughput, latency or responsiveness. Thanks, Fengguang _______________________________________________ Containers mailing list Containers@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/containers