From 8bec2759947700271cd44a8150520611ca842b70 Mon Sep 17 00:00:00 2001 From: Morgen Peschke Date: Thu, 13 Jun 2024 18:26:22 -0700 Subject: [PATCH 1/3] Clean up unneeded calls to Show Calling `Show` on an `Int` or `String` doesn't have any particular benefit, particularly if it's inside of a string interpolation anyway --- .../log4cats/PagingSelfAwareStructuredLogger.scala | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala index 5ab16662..1be2d915 100644 --- a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala +++ b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala @@ -123,15 +123,15 @@ object PagingSelfAwareStructuredLogger { ): F[(String, Map[String, String])] = randomUUID.map { uuid => val logSplitId = uuid.show - val msgLength = msg.length.show + val msgLength = msg.length ( logSplitId, ctx .updated(logSplitIdN, logSplitId) - .updated("page_size", s"${pageSizeK.show} Kib") - .updated("whole_message_size_bytes", msgLength) + .updated("page_size", s"$pageSizeK Kib") + .updated("whole_message_size_bytes", s"$msgLength") // The following is deprecated - .updated("log_size", s"${msgLength} Byte") + .updated("log_size", s"$msgLength Byte") ) } @@ -142,9 +142,9 @@ object PagingSelfAwareStructuredLogger { ctx: Map[String, String] ): Map[String, String] = ctx - .updated("total_pages", totalPages.show) - .updated("page_num", pageNum.show) - .updated("log_size_bytes", page.length.show) + .updated("total_pages", s"$totalPages") + .updated("page_num", s"$pageNum") + .updated("log_size_bytes", s"${page.length}") private def doLogging( loggingLevelChk: => F[Boolean], From 230e82d95ee3775da3216f8e98850607daecd9ab Mon Sep 17 00:00:00 2001 From: Morgen Peschke Date: Thu, 13 Jun 2024 18:34:27 -0700 Subject: [PATCH 2/3] Materialize the paged message before interacting with it. Previously the message would be materialized multiple times: - `1` time in `addMsgCtx` - `3` or `1 + 3p` times in `pagedLogging` - Lower Bound (single page): `3` times - `1` time to calculate the number of pages - `1` time in `addPageCtx` to calculate the page length - `1` time when calling `logOpWithCtx` - Upper Bound (`p` pages): `1 + 3p` - `1` time to calculate the number of pages - `1` time per page to split out each page - `1` time per page in `addPageCtx` to calculate the page length - `1` time per page when calling `logOpWithCtx` Materializing early gives these improvements: - Single page: from `4` times to `1` time - Multiple pages: from `2 + 3p` times to `1` time Also removes some by-name parameters that were always called with materialized values. --- .../PagingSelfAwareStructuredLogger.scala | 24 ++++++++++++------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala index 1be2d915..c055fae4 100644 --- a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala +++ b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala @@ -87,10 +87,10 @@ object PagingSelfAwareStructuredLogger { private val pageSize = pageSizeK * 1024 private def pagedLogging( - logOpWithCtx: Map[String, String] => (=> String) => F[Unit], + logOpWithCtx: Map[String, String] => String => F[Unit], ctx: Map[String, String], logSplitId: String, - msg: => String + msg: String ): F[Unit] = { val numOfPagesRaw = (msg.length - 1) / pageSize + 1 val numOfPages = Math.min(numOfPagesRaw, maxPageNeeded) @@ -118,7 +118,7 @@ object PagingSelfAwareStructuredLogger { } private def addMsgCtx( - msg: => String, + msg: String, ctx: Map[String, String] ): F[(String, Map[String, String])] = randomUUID.map { uuid => @@ -136,9 +136,9 @@ object PagingSelfAwareStructuredLogger { } private def addPageCtx( - page: => String, - pageNum: => Int, - totalPages: => Int, + page: String, + pageNum: Int, + totalPages: Int, ctx: Map[String, String] ): Map[String, String] = ctx @@ -148,13 +148,19 @@ object PagingSelfAwareStructuredLogger { private def doLogging( loggingLevelChk: => F[Boolean], - logOpWithCtx: Map[String, String] => (=> String) => F[Unit], + logOpWithCtx: Map[String, String] => String => F[Unit], msg: => String, ctx: Map[String, String] = Map() ): F[Unit] = { loggingLevelChk.ifM( - addMsgCtx(msg, ctx).flatMap { case (logSplitId, newCtx) => - pagedLogging(logOpWithCtx, newCtx, logSplitId, msg) + { + // At this point we know we're going to log and/or interact + // with msg, so we materialize the message here so we don't + // materialize it multiple times + val materializedMsg = msg + addMsgCtx(materializedMsg, ctx).flatMap { case (logSplitId, newCtx) => + pagedLogging(logOpWithCtx, newCtx, logSplitId, materializedMsg) + } }, Applicative[F].unit ) From b215b560b97518bbd85cc6ae0ff53235f9479193 Mon Sep 17 00:00:00 2001 From: Morgen Peschke Date: Thu, 13 Jun 2024 19:20:47 -0700 Subject: [PATCH 3/3] Fix misalignment of types --- .../typelevel/log4cats/PagingSelfAwareStructuredLogger.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala index c055fae4..14001193 100644 --- a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala +++ b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala @@ -87,7 +87,7 @@ object PagingSelfAwareStructuredLogger { private val pageSize = pageSizeK * 1024 private def pagedLogging( - logOpWithCtx: Map[String, String] => String => F[Unit], + logOpWithCtx: Map[String, String] => (=> String) => F[Unit], ctx: Map[String, String], logSplitId: String, msg: String @@ -148,7 +148,7 @@ object PagingSelfAwareStructuredLogger { private def doLogging( loggingLevelChk: => F[Boolean], - logOpWithCtx: Map[String, String] => String => F[Unit], + logOpWithCtx: Map[String, String] => (=> String) => F[Unit], msg: => String, ctx: Map[String, String] = Map() ): F[Unit] = {