user/dev discussion of public-inbox itself
 help / color / mirror / code / Atom feed
* [PATCH 0/4] www|nntp: optimize uses of Email::Simple
@ 2019-06-27 22:51 Eric Wong
  2019-06-27 22:51 ` [PATCH 1/4] nntp: rework and simplify art_lookup response Eric Wong
                   ` (3 more replies)
  0 siblings, 4 replies; 5+ messages in thread
From: Eric Wong @ 2019-06-27 22:51 UTC (permalink / raw)
  To: meta

We can rely on the documented behavior of Email::Simple->new
modifying its string buffer in-place to save us the trouble
of calling ->body (or ->body_set('') to clobber the buffer).

This yields significant memory use improvements in avoiding full
message body copies in the WWW mbox code.  Unfortunately, NNTP
messages with LF-only line-endings won't benefit, since the
protocol requires CRLF endings and the s/// operations get
expensive.

Memory bloat from giant emails and Email::MIME will require
more work :<

Eric Wong (4):
  nntp: rework and simplify art_lookup response
  mbox: use Email::Simple->new to do in-place modifications
  mbox: split header and body processing
  nntp: reduce syscalls for ARTICLE and BODY

 lib/PublicInbox/Mbox.pm | 73 +++++++++++++++++++++--------------------
 lib/PublicInbox/NNTP.pm | 59 ++++++++++++++++-----------------
 2 files changed, 67 insertions(+), 65 deletions(-)

-- 
EW

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2019-06-27 22:51 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-06-27 22:51 [PATCH 0/4] www|nntp: optimize uses of Email::Simple Eric Wong
2019-06-27 22:51 ` [PATCH 1/4] nntp: rework and simplify art_lookup response Eric Wong
2019-06-27 22:51 ` [PATCH 2/4] mbox: use Email::Simple->new to do in-place modifications Eric Wong
2019-06-27 22:51 ` [PATCH 3/4] mbox: split header and body processing Eric Wong
2019-06-27 22:51 ` [PATCH 4/4] nntp: reduce syscalls for ARTICLE and BODY Eric Wong

Code repositories for project(s) associated with this public inbox

	https://80x24.org/public-inbox.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).