log.go 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. package lnd
  2. import (
  3. "github.com/btcsuite/btcd/connmgr"
  4. "github.com/btcsuite/btclog"
  5. "github.com/lightninglabs/neutrino"
  6. sphinx "github.com/lightningnetwork/lightning-onion"
  7. "github.com/lightningnetwork/lnd/autopilot"
  8. "github.com/lightningnetwork/lnd/build"
  9. "github.com/lightningnetwork/lnd/chainntnfs"
  10. "github.com/lightningnetwork/lnd/chainreg"
  11. "github.com/lightningnetwork/lnd/chanacceptor"
  12. "github.com/lightningnetwork/lnd/chanbackup"
  13. "github.com/lightningnetwork/lnd/chanfitness"
  14. "github.com/lightningnetwork/lnd/channeldb"
  15. "github.com/lightningnetwork/lnd/channelnotifier"
  16. "github.com/lightningnetwork/lnd/cluster"
  17. "github.com/lightningnetwork/lnd/contractcourt"
  18. "github.com/lightningnetwork/lnd/discovery"
  19. "github.com/lightningnetwork/lnd/funding"
  20. "github.com/lightningnetwork/lnd/healthcheck"
  21. "github.com/lightningnetwork/lnd/htlcswitch"
  22. "github.com/lightningnetwork/lnd/invoices"
  23. "github.com/lightningnetwork/lnd/lnrpc/autopilotrpc"
  24. "github.com/lightningnetwork/lnd/lnrpc/chainrpc"
  25. "github.com/lightningnetwork/lnd/lnrpc/devrpc"
  26. "github.com/lightningnetwork/lnd/lnrpc/invoicesrpc"
  27. "github.com/lightningnetwork/lnd/lnrpc/neutrinorpc"
  28. "github.com/lightningnetwork/lnd/lnrpc/peersrpc"
  29. "github.com/lightningnetwork/lnd/lnrpc/routerrpc"
  30. "github.com/lightningnetwork/lnd/lnrpc/signrpc"
  31. "github.com/lightningnetwork/lnd/lnrpc/verrpc"
  32. "github.com/lightningnetwork/lnd/lnrpc/walletrpc"
  33. "github.com/lightningnetwork/lnd/lnwallet"
  34. "github.com/lightningnetwork/lnd/lnwallet/btcwallet"
  35. "github.com/lightningnetwork/lnd/lnwallet/chancloser"
  36. "github.com/lightningnetwork/lnd/lnwallet/chanfunding"
  37. "github.com/lightningnetwork/lnd/lnwallet/rpcwallet"
  38. "github.com/lightningnetwork/lnd/monitoring"
  39. "github.com/lightningnetwork/lnd/netann"
  40. "github.com/lightningnetwork/lnd/peer"
  41. "github.com/lightningnetwork/lnd/peernotifier"
  42. "github.com/lightningnetwork/lnd/routing"
  43. "github.com/lightningnetwork/lnd/rpcperms"
  44. "github.com/lightningnetwork/lnd/signal"
  45. "github.com/lightningnetwork/lnd/sweep"
  46. "github.com/lightningnetwork/lnd/tor"
  47. "github.com/lightningnetwork/lnd/watchtower"
  48. "github.com/lightningnetwork/lnd/watchtower/wtclient"
  49. )
  50. // replaceableLogger is a thin wrapper around a logger that is used so the
  51. // logger can be replaced easily without some black pointer magic.
  52. type replaceableLogger struct {
  53. btclog.Logger
  54. subsystem string
  55. }
  56. // Loggers can not be used before the log rotator has been initialized with a
  57. // log file. This must be performed early during application startup by
  58. // calling InitLogRotator() on the main log writer instance in the config.
  59. var (
  60. // lndPkgLoggers is a list of all lnd package level loggers that are
  61. // registered. They are tracked here so they can be replaced once the
  62. // SetupLoggers function is called with the final root logger.
  63. lndPkgLoggers []*replaceableLogger
  64. // addLndPkgLogger is a helper function that creates a new replaceable
  65. // main lnd package level logger and adds it to the list of loggers that
  66. // are replaced again later, once the final root logger is ready.
  67. addLndPkgLogger = func(subsystem string) *replaceableLogger {
  68. l := &replaceableLogger{
  69. Logger: build.NewSubLogger(subsystem, nil),
  70. subsystem: subsystem,
  71. }
  72. lndPkgLoggers = append(lndPkgLoggers, l)
  73. return l
  74. }
  75. // Loggers that need to be accessible from the lnd package can be placed
  76. // here. Loggers that are only used in sub modules can be added directly
  77. // by using the addSubLogger method. We declare all loggers so we never
  78. // run into a nil reference if they are used early. But the SetupLoggers
  79. // function should always be called as soon as possible to finish
  80. // setting them up properly with a root logger.
  81. ltndLog = addLndPkgLogger("LTND")
  82. rpcsLog = addLndPkgLogger("RPCS")
  83. srvrLog = addLndPkgLogger("SRVR")
  84. atplLog = addLndPkgLogger("ATPL")
  85. )
  86. // genSubLogger creates a logger for a subsystem. We provide an instance of
  87. // a signal.Interceptor to be able to shutdown in the case of a critical error.
  88. func genSubLogger(root *build.RotatingLogWriter,
  89. interceptor signal.Interceptor) func(string) btclog.Logger {
  90. // Create a shutdown function which will request shutdown from our
  91. // interceptor if it is listening.
  92. shutdown := func() {
  93. if !interceptor.Listening() {
  94. return
  95. }
  96. interceptor.RequestShutdown()
  97. }
  98. // Return a function which will create a sublogger from our root
  99. // logger without shutdown fn.
  100. return func(tag string) btclog.Logger {
  101. return root.GenSubLogger(tag, shutdown)
  102. }
  103. }
  104. // SetupLoggers initializes all package-global logger variables.
  105. func SetupLoggers(root *build.RotatingLogWriter, interceptor signal.Interceptor) {
  106. genLogger := genSubLogger(root, interceptor)
  107. // Now that we have the proper root logger, we can replace the
  108. // placeholder lnd package loggers.
  109. for _, l := range lndPkgLoggers {
  110. l.Logger = build.NewSubLogger(l.subsystem, genLogger)
  111. SetSubLogger(root, l.subsystem, l.Logger)
  112. }
  113. // Initialize loggers from packages outside of `lnd` first. The
  114. // packages below will overwrite the names of the loggers they import.
  115. // For instance, the logger in `neutrino.query` is overwritten by
  116. // `btcwallet.chain`, which is overwritten by `lnwallet`. To ensure the
  117. // overwriting works, we need to initialize the loggers here so they
  118. // can be overwritten later.
  119. AddSubLogger(root, "BTCN", interceptor, neutrino.UseLogger)
  120. AddSubLogger(root, "CMGR", interceptor, connmgr.UseLogger)
  121. // Some of the loggers declared in the main lnd package are also used
  122. // in sub packages.
  123. signal.UseLogger(ltndLog)
  124. autopilot.UseLogger(atplLog)
  125. AddSubLogger(root, "LNWL", interceptor, lnwallet.UseLogger)
  126. AddSubLogger(root, "DISC", interceptor, discovery.UseLogger)
  127. AddSubLogger(root, "NTFN", interceptor, chainntnfs.UseLogger)
  128. AddSubLogger(root, "CHDB", interceptor, channeldb.UseLogger)
  129. AddSubLogger(root, "HSWC", interceptor, htlcswitch.UseLogger)
  130. AddSubLogger(root, "CNCT", interceptor, contractcourt.UseLogger)
  131. AddSubLogger(root, "UTXN", interceptor, contractcourt.UseNurseryLogger)
  132. AddSubLogger(root, "BRAR", interceptor, contractcourt.UseBreachLogger)
  133. AddSubLogger(root, "SPHX", interceptor, sphinx.UseLogger)
  134. AddSubLogger(root, "SWPR", interceptor, sweep.UseLogger)
  135. AddSubLogger(root, "SGNR", interceptor, signrpc.UseLogger)
  136. AddSubLogger(root, "WLKT", interceptor, walletrpc.UseLogger)
  137. AddSubLogger(root, "ARPC", interceptor, autopilotrpc.UseLogger)
  138. AddSubLogger(root, "NRPC", interceptor, neutrinorpc.UseLogger)
  139. AddSubLogger(root, "DRPC", interceptor, devrpc.UseLogger)
  140. AddSubLogger(root, "INVC", interceptor, invoices.UseLogger)
  141. AddSubLogger(root, "NANN", interceptor, netann.UseLogger)
  142. AddSubLogger(root, "WTWR", interceptor, watchtower.UseLogger)
  143. AddSubLogger(root, "NTFR", interceptor, chainrpc.UseLogger)
  144. AddSubLogger(root, "IRPC", interceptor, invoicesrpc.UseLogger)
  145. AddSubLogger(root, "CHNF", interceptor, channelnotifier.UseLogger)
  146. AddSubLogger(root, "CHBU", interceptor, chanbackup.UseLogger)
  147. AddSubLogger(root, "PROM", interceptor, monitoring.UseLogger)
  148. AddSubLogger(root, "WTCL", interceptor, wtclient.UseLogger)
  149. AddSubLogger(root, "PRNF", interceptor, peernotifier.UseLogger)
  150. AddSubLogger(root, "CHFD", interceptor, chanfunding.UseLogger)
  151. AddSubLogger(root, "PEER", interceptor, peer.UseLogger)
  152. AddSubLogger(root, "CHCL", interceptor, chancloser.UseLogger)
  153. AddSubLogger(root, routing.Subsystem, interceptor, routing.UseLogger)
  154. AddSubLogger(root, routerrpc.Subsystem, interceptor, routerrpc.UseLogger)
  155. AddSubLogger(root, chanfitness.Subsystem, interceptor, chanfitness.UseLogger)
  156. AddSubLogger(root, verrpc.Subsystem, interceptor, verrpc.UseLogger)
  157. AddSubLogger(root, healthcheck.Subsystem, interceptor, healthcheck.UseLogger)
  158. AddSubLogger(root, chainreg.Subsystem, interceptor, chainreg.UseLogger)
  159. AddSubLogger(root, chanacceptor.Subsystem, interceptor, chanacceptor.UseLogger)
  160. AddSubLogger(root, funding.Subsystem, interceptor, funding.UseLogger)
  161. AddSubLogger(root, cluster.Subsystem, interceptor, cluster.UseLogger)
  162. AddSubLogger(root, rpcperms.Subsystem, interceptor, rpcperms.UseLogger)
  163. AddSubLogger(root, tor.Subsystem, interceptor, tor.UseLogger)
  164. AddSubLogger(root, btcwallet.Subsystem, interceptor, btcwallet.UseLogger)
  165. AddSubLogger(root, rpcwallet.Subsystem, interceptor, rpcwallet.UseLogger)
  166. AddSubLogger(root, peersrpc.Subsystem, interceptor, peersrpc.UseLogger)
  167. }
  168. // AddSubLogger is a helper method to conveniently create and register the
  169. // logger of one or more sub systems.
  170. func AddSubLogger(root *build.RotatingLogWriter, subsystem string,
  171. interceptor signal.Interceptor, useLoggers ...func(btclog.Logger)) {
  172. // genSubLogger will return a callback for creating a logger instance,
  173. // which we will give to the root logger.
  174. genLogger := genSubLogger(root, interceptor)
  175. // Create and register just a single logger to prevent them from
  176. // overwriting each other internally.
  177. logger := build.NewSubLogger(subsystem, genLogger)
  178. SetSubLogger(root, subsystem, logger, useLoggers...)
  179. }
  180. // SetSubLogger is a helper method to conveniently register the logger of a sub
  181. // system.
  182. func SetSubLogger(root *build.RotatingLogWriter, subsystem string,
  183. logger btclog.Logger, useLoggers ...func(btclog.Logger)) {
  184. root.RegisterSubLogger(subsystem, logger)
  185. for _, useLogger := range useLoggers {
  186. useLogger(logger)
  187. }
  188. }
  189. // logClosure is used to provide a closure over expensive logging operations so
  190. // don't have to be performed when the logging level doesn't warrant it.
  191. type logClosure func() string
  192. // String invokes the underlying function and returns the result.
  193. func (c logClosure) String() string {
  194. return c()
  195. }
  196. // newLogClosure returns a new closure over a function that returns a string
  197. // which itself provides a Stringer interface so that it can be used with the
  198. // logging system.
  199. func newLogClosure(c func() string) logClosure {
  200. return logClosure(c)
  201. }