Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 06 Apr 2018 08:41:25 +0000
From:      Steven Hartland <killing@multiplay.co.uk>
To:        Borja Marcos <borjam@sarenet.es>
Cc:        "Eugene M. Zheganin" <eugene@zhegan.in>,  FreeBSD-STABLE Mailing List <freebsd-stable@freebsd.org>, Warner Losh <imp@bsdimp.com>
Subject:   Re: TRIM, iSCSI and %busy waves
Message-ID:  <CAHEMsqaLSBURNSsx4k8YKBckAWtN2uva36vck5G8jWjhkLLgmQ@mail.gmail.com>
In-Reply-To: <8935E1F4-10DE-4621-8153-26AF851CC26E@sarenet.es>
References:  <92b92a3d-3262-c006-ed5a-dc2f9f4a5cb9@zhegan.in> <CANCZdfrQBqcb5ASPFGjLN=nif4bQ9vTjMtBuDaOvvUKkM7u3XA@mail.gmail.com> <8935E1F4-10DE-4621-8153-26AF851CC26E@sarenet.es>

next in thread | previous in thread | raw e-mail | index | archive | help
That is very hw and use case dependent.

The reason we originally sponsored the project to add TRIM to ZFS was that
in our case without TRIM the performance got so bad that we had to secure
erase disks every couple of weeks as they simply became so slow they where
unusable.

Now admittedly that was a fair few years ago and hw has moved on since
then, but the point remains that it=E2=80=99s not totally true that just no=
t
TRIMing is an option.

On Fri, 6 Apr 2018 at 09:10, Borja Marcos <borjam@sarenet.es> wrote:

>
> > On 5 Apr 2018, at 17:00, Warner Losh <imp@bsdimp.com> wrote:
> >
> > I'm working on trim shaping in -current right now. It's focused on NVMe=
,
> > but since I'm doing the bulk of it in cam_iosched.c, it will eventually
> be
> > available for ada and da. The notion is to measure how long the TRIMs
> take,
> > and only send them at 80% of that rate when there's other traffic in th=
e
> > queue (so if trims are taking 100ms, send them no faster than 8/s). Whi=
le
> > this will allow for better read/write traffic, it does slow the TRIMs
> down
> > which slows down whatever they may be blocking in the upper layers. Can=
't
> > speak to ZFS much, but for UFS that's freeing of blocks so things like
> new
> > block allocation may be delayed if we're almost out of disk (which we
> have
> > no signal for, so there's no way for the lower layers to prioritize tri=
ms
> > or not).
>
> Have you considered "hard" shaping including discarding TRIMs when needed=
?
> Remember that a TRIM is not a write, which is subject to a contract with
> the application,
> but a better-if-you-do-it operation.
>
> Otherwise, as you say, you might be blocking other operations in the uppe=
r
> layers.
> I am assuming here that with many devices doing TRIMs is better than not
> doing them.
> And in case of queue congestion doing *some* TRIMs should be better than
> doing
> no TRIMs at all.
>
> Yep, not the first time I propose something of the sort, but my queue of
> suggestions
> to eventually discard TRIMs doesn=E2=80=99s implement the same method ;)
>
>
> Borja.
>
>
> _______________________________________________
> freebsd-stable@freebsd.org mailing list
> https://lists.freebsd.org/mailman/listinfo/freebsd-stable
> To unsubscribe, send any mail to "freebsd-stable-unsubscribe@freebsd.org"
>



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?CAHEMsqaLSBURNSsx4k8YKBckAWtN2uva36vck5G8jWjhkLLgmQ>