add individual topics for logging
This commit is contained in:
parent
3ede25222e
commit
13e6eba161
|
@ -17,9 +17,13 @@
|
||||||
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
|
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
(require racket/async-channel racket/bool racket/engine racket/fasl racket/function racket/list
|
(require racket/async-channel racket/bool racket/engine racket/fasl racket/function racket/list
|
||||||
racket/match racket/tcp racket/unit syntax/parse/define
|
racket/logging racket/match racket/tcp racket/unit syntax/parse/define
|
||||||
(for-syntax racket/base racket/list racket/syntax racket/unit racket/unit-exptime)
|
(for-syntax racket/base racket/list racket/syntax racket/unit racket/unit-exptime)
|
||||||
"not-crypto.rkt")
|
"logging.rkt" "not-crypto.rkt")
|
||||||
|
|
||||||
|
;; logging!
|
||||||
|
(define-logger comms #:parent global-logger)
|
||||||
|
(define-logger tm #:parent global-logger)
|
||||||
|
|
||||||
;; define message types (they must all be prefab for fasl)
|
;; define message types (they must all be prefab for fasl)
|
||||||
(struct msg [from-id] #:prefab)
|
(struct msg [from-id] #:prefab)
|
||||||
|
@ -167,7 +171,7 @@
|
||||||
session-key)))
|
session-key)))
|
||||||
|
|
||||||
(thread-sendrecv el-thread 'register-channel (cons (node-id peer-data) new-thd))
|
(thread-sendrecv el-thread 'register-channel (cons (node-id peer-data) new-thd))
|
||||||
(displayln (list "new node connection:" (node-id peer-data)))
|
(log-comms-info "new node connection: ~a" (node-id peer-data))
|
||||||
|
|
||||||
;; monitor thread -- shuts down the custodian once the peer thread is done
|
;; monitor thread -- shuts down the custodian once the peer thread is done
|
||||||
(thread (lambda ()
|
(thread (lambda ()
|
||||||
|
@ -198,6 +202,7 @@
|
||||||
(with-handlers ([exn? (lambda (ex) (thread-send from ex #f))])
|
(with-handlers ([exn? (lambda (ex) (thread-send from ex #f))])
|
||||||
(when (false? listener-thd)
|
(when (false? listener-thd)
|
||||||
(set! listener (tcp-listen port 4 #t))
|
(set! listener (tcp-listen port 4 #t))
|
||||||
|
(log-comms-info "listening on port ~a" port)
|
||||||
(set! listener-thd
|
(set! listener-thd
|
||||||
(thread
|
(thread
|
||||||
(lambda ()
|
(lambda ()
|
||||||
|
@ -274,7 +279,6 @@
|
||||||
;; transferred, in which case you wouldn't be notified that it failed
|
;; transferred, in which case you wouldn't be notified that it failed
|
||||||
['dispatch-msg
|
['dispatch-msg
|
||||||
(match-define (cons peer-id msg) data)
|
(match-define (cons peer-id msg) data)
|
||||||
(displayln (list "dispatch msg" peer-id msg))
|
|
||||||
(if (= peer-id (node-id my-node))
|
(if (= peer-id (node-id my-node))
|
||||||
(begin (async-channel-put local-msg-channel msg)
|
(begin (async-channel-put local-msg-channel msg)
|
||||||
(thread-send from (void) #f))
|
(thread-send from (void) #f))
|
||||||
|
@ -400,15 +404,13 @@
|
||||||
(with-handlers ([exn? (lambda (ex)
|
(with-handlers ([exn? (lambda (ex)
|
||||||
(cleanup) (thread-send from ex #f))])
|
(cleanup) (thread-send from ex #f))])
|
||||||
(thread-receive) ;; go token
|
(thread-receive) ;; go token
|
||||||
(displayln "sending transaction")
|
|
||||||
(comms-dispatch-msg/retry comms to-id transaction)
|
(comms-dispatch-msg/retry comms to-id transaction)
|
||||||
(match (sync/timeout TRANSACTION-TIMEOUT (thread-receive-evt))
|
(match (sync/timeout TRANSACTION-TIMEOUT (thread-receive-evt))
|
||||||
[#f
|
[#f
|
||||||
(cleanup)
|
(cleanup)
|
||||||
(displayln "timeout!!!")
|
(log-tm-error "timeout sending transaction to ~a" to-id)
|
||||||
(thread-send from (make-error "transaction timeout") #f)]
|
(thread-send from (make-error "transaction timeout") #f)]
|
||||||
[_ (define response (thread-receive))
|
[_ (define response (thread-receive))
|
||||||
(displayln "got response!")
|
|
||||||
(thread-send from (trans-data-deserialize response) #f)])))
|
(thread-send from (trans-data-deserialize response) #f)])))
|
||||||
|
|
||||||
(define (send-transaction from to-id rpc-id rpc-data)
|
(define (send-transaction from to-id rpc-id rpc-data)
|
||||||
|
@ -422,12 +424,13 @@
|
||||||
|
|
||||||
(define (handle-incoming-transaction func msg)
|
(define (handle-incoming-transaction func msg)
|
||||||
(match-define (msg:transaction from-id trans-id _ rpc-id rpc-data) msg)
|
(match-define (msg:transaction from-id trans-id _ rpc-id rpc-data) msg)
|
||||||
(displayln "handling incoming transaction")
|
|
||||||
|
|
||||||
(define (respond data)
|
(define (respond data)
|
||||||
(define resp
|
(define resp
|
||||||
(msg:transaction (node-id my-node) trans-id #f rpc-id (trans-data-serialize data)))
|
(msg:transaction (node-id my-node) trans-id #f rpc-id (trans-data-serialize data)))
|
||||||
(with-handlers ([exn? (lambda (ex) (displayln "failed to dispatch transaction response"))])
|
(with-handlers ([exn?
|
||||||
|
(lambda (ex)
|
||||||
|
((error-display-handler) "failed to dispatch transaction response" ex))])
|
||||||
(comms-dispatch-msg/retry comms from-id resp)))
|
(comms-dispatch-msg/retry comms from-id resp)))
|
||||||
|
|
||||||
(with-handlers ([exn? respond])
|
(with-handlers ([exn? respond])
|
||||||
|
@ -437,7 +440,6 @@
|
||||||
;; TODO : apply timeout on the handler function?
|
;; TODO : apply timeout on the handler function?
|
||||||
;; we don't want this thread to potentially hang forever if there's some sort of deadlock
|
;; we don't want this thread to potentially hang forever if there's some sort of deadlock
|
||||||
(apply func arg-data)))
|
(apply func arg-data)))
|
||||||
(displayln (list "result" result "sending back..."))
|
|
||||||
(respond result)))
|
(respond result)))
|
||||||
|
|
||||||
(define (handle-thread-msg)
|
(define (handle-thread-msg)
|
||||||
|
@ -455,18 +457,17 @@
|
||||||
[_ (thread-send from (make-error "invalid transaction thread msg" #f))]))
|
[_ (thread-send from (make-error "invalid transaction thread msg" #f))]))
|
||||||
|
|
||||||
(define (handle-incoming msg)
|
(define (handle-incoming msg)
|
||||||
(displayln (list "incoming message!" msg))
|
|
||||||
(match msg
|
(match msg
|
||||||
[(msg:transaction from-id trans-id #t rpc-id rpc-data)
|
[(msg:transaction from-id trans-id #t rpc-id rpc-data)
|
||||||
(match (hash-ref rpc-table rpc-id #f)
|
(match (hash-ref rpc-table rpc-id #f)
|
||||||
[#f (displayln (list "got unknown rpc req" msg))]
|
[#f (log-tm-warning "got unknown rpc req: ~a" msg)]
|
||||||
[func (thread (lambda () (handle-incoming-transaction func msg)))])]
|
[func (thread (lambda () (handle-incoming-transaction func msg)))])]
|
||||||
[(msg:transaction from-id trans-id #f rpc-id rpc-data)
|
[(msg:transaction from-id trans-id #f rpc-id rpc-data)
|
||||||
(define key (cons from-id trans-id))
|
(define key (cons from-id trans-id))
|
||||||
(match (hash-ref response-table key #f)
|
(match (hash-ref response-table key #f)
|
||||||
[#f (displayln (list "got spurious transaction response" msg))]
|
[#f (log-tm-warning "got spurious transaction response: ~a" msg)]
|
||||||
[thd (thread-send thd rpc-data #f) (hash-remove! response-table key)])]
|
[thd (thread-send thd rpc-data #f) (hash-remove! response-table key)])]
|
||||||
[_ (displayln (list "got unknown msg" msg))]))
|
[_ (log-tm-warning "got unknown msg: ~a" msg)]))
|
||||||
|
|
||||||
;; it's a thread cell and i'm too lazy to add a parameterize clause... it should work
|
;; it's a thread cell and i'm too lazy to add a parameterize clause... it should work
|
||||||
(current-custodian tm-cust)
|
(current-custodian tm-cust)
|
||||||
|
@ -582,7 +583,7 @@
|
||||||
;
|
;
|
||||||
; (comms-listen comms 1337)
|
; (comms-listen comms 1337)
|
||||||
;
|
;
|
||||||
; (displayln "listening")
|
; (log-info "listening")
|
||||||
; (sleep 9999)
|
; (sleep 9999)
|
||||||
;
|
;
|
||||||
; (tm-shutdown tm)
|
; (tm-shutdown tm)
|
||||||
|
@ -592,9 +593,9 @@
|
||||||
; (comms-set-node-info comms server-node)
|
; (comms-set-node-info comms server-node)
|
||||||
; (define tm (make-transaction-manager client-node comms))
|
; (define tm (make-transaction-manager client-node comms))
|
||||||
;
|
;
|
||||||
; (displayln "transacting...")
|
; (log-info "transacting...")
|
||||||
; (displayln (tm-transact tm 0 'add1 (list 1)))
|
; (log-info "transaction: ~a" (tm-transact tm 0 'add1 (list 1)))
|
||||||
; (displayln "done")
|
; (log-info "done")
|
||||||
;
|
;
|
||||||
; (tm-shutdown tm)
|
; (tm-shutdown tm)
|
||||||
; (comms-shutdown comms)])
|
; (comms-shutdown comms)])
|
||||||
|
|
|
@ -18,7 +18,17 @@
|
||||||
|
|
||||||
(require racket/bool racket/date racket/match racket/string)
|
(require racket/bool racket/date racket/match racket/string)
|
||||||
|
|
||||||
(provide install-logging!)
|
(provide global-logger install-logging!)
|
||||||
|
|
||||||
|
(define global-logger (make-logger))
|
||||||
|
|
||||||
|
(define (default-log-filter level topic)
|
||||||
|
(match topic
|
||||||
|
['optimizer #f]
|
||||||
|
['collapsible-contract-bailout #f]
|
||||||
|
['collapsible-value-bailout #f]
|
||||||
|
['racket/contract #f]
|
||||||
|
[else #t]))
|
||||||
|
|
||||||
(define (recv-thd receiver stop-chan)
|
(define (recv-thd receiver stop-chan)
|
||||||
;; iso8601 gang
|
;; iso8601 gang
|
||||||
|
@ -27,38 +37,40 @@
|
||||||
;; formats one log entry to stdout
|
;; formats one log entry to stdout
|
||||||
(define (log-one entry)
|
(define (log-one entry)
|
||||||
(match-define (vector level msg arg topic) entry)
|
(match-define (vector level msg arg topic) entry)
|
||||||
(define level-str
|
(when (default-log-filter level topic)
|
||||||
(match level
|
(define level-str
|
||||||
['fatal "FATAL"]
|
(match level
|
||||||
['error "ERROR"]
|
['fatal "FATAL"]
|
||||||
['warning "WARN "]
|
['error "ERROR"]
|
||||||
['info "INFO "]
|
['warning "WARN "]
|
||||||
['debug "DEBUG"]
|
['info "INFO "]
|
||||||
[_ "NONE "]))
|
['debug "DEBUG"]
|
||||||
;; for systemd
|
[_ "NONE "]))
|
||||||
(define prefix-str
|
;; for systemd
|
||||||
(match level
|
(define prefix-str
|
||||||
['fatal "<2>"]
|
(match level
|
||||||
['error "<3>"]
|
['fatal "<2>"]
|
||||||
['warning "<4>"]
|
['error "<3>"]
|
||||||
['info "<6>"]
|
['warning "<4>"]
|
||||||
['debug "<7>"]
|
['info "<6>"]
|
||||||
[_ "<7>"]))
|
['debug "<7>"]
|
||||||
|
[_ "<7>"]))
|
||||||
|
|
||||||
;; in UTC
|
;; in UTC
|
||||||
(define time-str (date->string (seconds->date (* 0.001 (current-inexact-milliseconds)) #f) #t))
|
(define time-str (date->string (seconds->date (* 0.001 (current-inexact-milliseconds)) #f) #t))
|
||||||
;; prefix each line of the log entry with the metadata
|
;; prefix each line of the log entry with the metadata
|
||||||
(define msg-lines (string-split msg "\n"))
|
(define msg-lines (string-split msg "\n"))
|
||||||
(for ([line (in-list msg-lines)])
|
(for ([line (in-list msg-lines)])
|
||||||
(printf "~a [~aZ] [~a] ~a\n" prefix-str time-str level-str line)))
|
(printf "~a[~aZ] [~a] ~a\n" prefix-str time-str level-str line))))
|
||||||
|
|
||||||
;; process log entries until told to stop
|
;; process log entries until told to stop
|
||||||
;; this uses the same technique as with-intercepted-logging
|
;; this uses the same technique as with-intercepted-logging
|
||||||
(let loop ()
|
(let loop ()
|
||||||
(define next (sync receiver stop-chan))
|
(match (sync receiver stop-chan)
|
||||||
(unless (symbol=? next 'stop)
|
['stop (void)]
|
||||||
(log-one next)
|
[next
|
||||||
(loop)))
|
(log-one next)
|
||||||
|
(loop)]))
|
||||||
|
|
||||||
;; flush any remaining log entries
|
;; flush any remaining log entries
|
||||||
(let cleanup ()
|
(let cleanup ()
|
||||||
|
@ -70,12 +82,11 @@
|
||||||
;; install the logging system
|
;; install the logging system
|
||||||
;; call as early as possible in the application
|
;; call as early as possible in the application
|
||||||
(define (install-logging! [level 'debug])
|
(define (install-logging! [level 'debug])
|
||||||
(define logger (make-logger))
|
(define recv (make-log-receiver global-logger level))
|
||||||
(define recv (make-log-receiver logger level))
|
|
||||||
(define stop-chan (make-channel))
|
(define stop-chan (make-channel))
|
||||||
(define logger-thd (thread (lambda () (recv-thd recv stop-chan))))
|
(define logger-thd (thread (lambda () (recv-thd recv stop-chan))))
|
||||||
|
|
||||||
(current-logger logger)
|
(current-logger global-logger)
|
||||||
|
|
||||||
;; make uncaught exceptions go through the log
|
;; make uncaught exceptions go through the log
|
||||||
;; this uses the same (tbh, disgusting) trick as xrepl
|
;; this uses the same (tbh, disgusting) trick as xrepl
|
||||||
|
@ -88,7 +99,7 @@
|
||||||
(define os (open-output-string))
|
(define os (open-output-string))
|
||||||
(parameterize ([current-error-port os])
|
(parameterize ([current-error-port os])
|
||||||
(original-handler msg ex))
|
(original-handler msg ex))
|
||||||
(log-message logger 'fatal
|
(log-message global-logger 'fatal
|
||||||
(format "uncaught exception: ~a" (get-output-string os))
|
(format "uncaught exception: ~a" (get-output-string os))
|
||||||
(current-continuation-marks))))
|
(current-continuation-marks))))
|
||||||
|
|
||||||
|
|
|
@ -17,13 +17,17 @@
|
||||||
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
|
;; along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
(require db/base db/sqlite3
|
(require db/base db/sqlite3
|
||||||
data/queue racket/bool racket/contract racket/fasl racket/file racket/list racket/match
|
data/queue racket/bool racket/contract racket/fasl racket/file racket/list racket/logging
|
||||||
racket/path racket/random racket/runtime-path racket/set racket/string racket/unit srfi/19
|
racket/match racket/path racket/random racket/runtime-path racket/set racket/string
|
||||||
|
racket/unit srfi/19
|
||||||
north/base north/adapter/base north/adapter/sqlite
|
north/base north/adapter/base north/adapter/sqlite
|
||||||
"comms.rkt" "manifest.rkt" "not-crypto.rkt" "pattern.rkt" "protocol.rkt"
|
"comms.rkt" "logging.rkt" "manifest.rkt" "not-crypto.rkt" "pattern.rkt" "protocol.rkt"
|
||||||
;; port-fsync
|
;; port-fsync
|
||||||
(submod "static-support.rkt" misc-calls))
|
(submod "static-support.rkt" misc-calls))
|
||||||
|
|
||||||
|
;; logging
|
||||||
|
(define-logger server #:parent global-logger)
|
||||||
|
|
||||||
;; configuration
|
;; configuration
|
||||||
|
|
||||||
(define PRODUCTION? #f)
|
(define PRODUCTION? #f)
|
||||||
|
@ -61,7 +65,7 @@
|
||||||
(define target-revision (migration-revision (migration-most-recent base)))
|
(define target-revision (migration-revision (migration-most-recent base)))
|
||||||
(define plan (migration-plan base current-revision target-revision))
|
(define plan (migration-plan base current-revision target-revision))
|
||||||
(for ([migration (in-list plan)])
|
(for ([migration (in-list plan)])
|
||||||
(displayln (format "applying migration: ~a" (migration-revision migration)))
|
(log-server-info "applying migration: ~a" (migration-revision migration))
|
||||||
(adapter-apply! adapter (migration-revision migration) (migration-up migration)))
|
(adapter-apply! adapter (migration-revision migration) (migration-up migration)))
|
||||||
(void))
|
(void))
|
||||||
|
|
||||||
|
@ -119,7 +123,7 @@
|
||||||
(define existing-ids (mutable-set))
|
(define existing-ids (mutable-set))
|
||||||
(call-with-transaction (current-db) (lambda ()
|
(call-with-transaction (current-db) (lambda ()
|
||||||
(define (cleanup id exists? path)
|
(define (cleanup id exists? path)
|
||||||
(displayln (format "removing corrupted/incomplete task ~a" id))
|
(log-server-warning "removing corrupted/incomplete task ~a" id)
|
||||||
(when exists? (delete-file path))
|
(when exists? (delete-file path))
|
||||||
(query-exec (current-db) q-delete-task id))
|
(query-exec (current-db) q-delete-task id))
|
||||||
(for ([(id committed) (in-query (current-db) q-get-task-id-commit)])
|
(for ([(id committed) (in-query (current-db) q-get-task-id-commit)])
|
||||||
|
@ -424,7 +428,7 @@
|
||||||
(define (invoke/retry-forever proc)
|
(define (invoke/retry-forever proc)
|
||||||
(let init-loop ([retry-delay *min-retry-delay*])
|
(let init-loop ([retry-delay *min-retry-delay*])
|
||||||
(with-handlers ([exn? (lambda (ex)
|
(with-handlers ([exn? (lambda (ex)
|
||||||
(displayln (format "agent ~a encountered error ~a" id ex))
|
(log-server-error "agent ~a encountered error ~a" id ex)
|
||||||
(sleep retry-delay)
|
(sleep retry-delay)
|
||||||
(init-loop (min *max-retry-delay*
|
(init-loop (min *max-retry-delay*
|
||||||
(* *retry-delay-ratio* retry-delay))))])
|
(* *retry-delay-ratio* retry-delay))))])
|
||||||
|
@ -565,7 +569,7 @@
|
||||||
;; although ideally this case wouldn't occur because the timeout is three times the target
|
;; although ideally this case wouldn't occur because the timeout is three times the target
|
||||||
;; subtask duration
|
;; subtask duration
|
||||||
(hash-set! task-size taskid *min-subtask-size*)
|
(hash-set! task-size taskid *min-subtask-size*)
|
||||||
(displayln (format "agent ~a timed out on task ~a" id taskid))
|
(log-server-warning "agent ~a timed out on task ~a" id taskid)
|
||||||
(cancel-assignment! overdue)))
|
(cancel-assignment! overdue)))
|
||||||
|
|
||||||
;; cancel whatever the agent is currently working on, in case the server crashed and came back
|
;; cancel whatever the agent is currently working on, in case the server crashed and came back
|
||||||
|
@ -691,9 +695,10 @@
|
||||||
(require racket/cmdline)
|
(require racket/cmdline)
|
||||||
|
|
||||||
;; TODO : read cmdline and config file
|
;; TODO : read cmdline and config file
|
||||||
;; TODO : real logging, replace all displayln
|
|
||||||
|
|
||||||
;; initialize server
|
;; initialize server
|
||||||
|
(install-logging!)
|
||||||
|
(log-server-info "initializing server")
|
||||||
(current-db (open-server-db 'create))
|
(current-db (open-server-db 'create))
|
||||||
(migrate-server-db)
|
(migrate-server-db)
|
||||||
;; temp key
|
;; temp key
|
||||||
|
@ -718,13 +723,14 @@
|
||||||
;; start listening
|
;; start listening
|
||||||
(comms-listen (current-comms) 1337)
|
(comms-listen (current-comms) 1337)
|
||||||
|
|
||||||
(displayln "server running")
|
(log-server-info "server running")
|
||||||
|
|
||||||
;; wait for break
|
;; wait for break
|
||||||
(with-handlers ([exn? (lambda (ex) (displayln (format "encountered exception: ~a" ex)))])
|
(with-handlers ([exn:break? void])
|
||||||
(sync never-evt))
|
(sync never-evt))
|
||||||
|
|
||||||
;; shutdown
|
;; shutdown
|
||||||
(displayln "stopping server")
|
(log-server-info "stopping server")
|
||||||
(agent-handler-shutdown)
|
(agent-handler-shutdown)
|
||||||
(tm-shutdown (current-tm))
|
(tm-shutdown (current-tm))
|
||||||
(comms-shutdown (current-comms))
|
(comms-shutdown (current-comms))
|
||||||
|
|
Loading…
Reference in New Issue