This repository has been archived by the owner on Oct 4, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 168
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
may be worth thinking about more flexible and beautiful ways to display information... 'monitor', 'attach', etc, along with termui, graphs... output can be 'machiney'-- line-by-line, or human-y -- pictures of buffalo and whatnot.
solution: use a go func connected to the node's Ethereum to grab and calculate relevant logs rel ethereumproject#127 rel ethereumproject#318 --- TODO: fix or remove: - downloading-from peers, eg 'this var/x/x peers' - shows mode 'FullSync' before downloader initializes, even if it will be 'FastSync'
solution: comment code and include small explanation
solution: remove exploratory code that is not useless
solution: move to Warn from Error
solution: update it and simplify
solution: - remove dead code, old notes - remove units from --log-pace= argument, just use seconds as value (simpler is better) - if mining, show STATUS MINE with minerthreads and hashrate (TODO: more?) - gofmt Rel ethereumproject#127, ethereumproject#318
solution: improve legibility
solution: relegate to debug
solution: share chan in main between shutdown and closing status log goroutine
solution: implement and glog SetAlsoToStdErr exported function and use in case of --log-dir
results in missing any logs after shutdown processes in FS logs solution: defer log Flush after shutdown services also decrease flushInterval from 30 -> 5 seconds (rate at which log buffer is written to FS)
solution: rename flag and flagvar and status log function also adds logstatus flag to correct category for usage output
solution: refactor to use '--log-status='sync=60'' syntax, which can eventually support other features besides 'sync', eg. mine, net, disk
…to cmd.go solution: cut and paste and update imports
solution: error if neither fastblock nor fullblock match desired head number fixes ethereumproject#325
solution: don't share os-interrupt channel as a global. Notify library documentation clearly says Notify events can be called multiple times and notification will be copied, so there's no harm in listening for the same event on mutliple channels. This pattern avoids a global and encourages per-feature handling of shutdown scenarios.
…g-pace' wording solution: fix
solution: implement initial spec with tentative mlog-dir and filename defaults peer 'handle' func sends mlogs to file rel ethereumproject#317
solution: remove import
solution: refactor mlog from p2p to discover package - establish mlog label and detail structs Resolves ethereumproject#317
…tation solution: create vars for all available lines and comment them. not even sure if concision is a word Rel ethereumproject#317
…s by them solution: refactor details, implementing function to set details with variadic vals
solution: use type switch filtering in send/handle functions instead of dispersed mlog calls 'farther down the food chain'
Here's just a copy-and-paste example of what the logs look like: 2017/08/03 09:31:59 [discover] PING SEND TO 209.222.30.133:30388 127
2017/08/03 09:31:59 [discover] FINDNODE SEND TO 149.202.184.138:30303 171
2017/08/03 09:31:59 [discover] FINDNODE SEND TO 46.5.207.98:30303 171
2017/08/03 09:31:59 [discover] PONG HANDLE FROM 192.99.194.116:57955 285d57553cd31781018e7d055f297197c70d9d70f84eeeae4b6ab7f67d63c60b0ffabcdabb39f3bc1a405afe057155a89b39a291f91a06dfa3b6ee3867266186 149
2017/08/03 09:31:59 [discover] PONG HANDLE FROM 209.222.30.133:30388 c65ca649729d72749dc3c90c206bb6bff76930f3411da0005f06271989185f0124aa52daa88e2e3d921f2d2838f8d3b40ed0d693cc172e90fda4461316edcb99 149
2017/08/03 09:32:04 [discover] FINDNODE SEND TO 62.45.159.216:30303 171
2017/08/03 09:32:04 [discover] FINDNODE SEND TO 178.134.252.152:30303 171
2017/08/03 09:32:04 [discover] FINDNODE SEND TO 31.31.78.100:30303 171
2017/08/03 09:32:04 [discover] NEIGHBORS HANDLE FROM 62.45.159.216:30303 3090a9103ba95cc45114efd410630eb9f95ac9f207bd7cc46d1a201649547390a16556ab21c7affae69173b0568fae4419e4dd01a60fe182dc56f446c1f54801 1057
2017/08/03 09:32:04 [discover] NEIGHBORS HANDLE FROM 62.45.159.216:30303 3090a9103ba95cc45114efd410630eb9f95ac9f207bd7cc46d1a201649547390a16556ab21c7affae69173b0568fae4419e4dd01a60fe182dc56f446c1f54801 425
2017/08/03 09:32:04 [discover] PING SEND TO 188.106.30.87:30303 127
2017/08/03 09:32:05 [discover] PING SEND TO 104.131.49.217:30303 127
2017/08/03 09:32:05 [discover] NEIGHBORS HANDLE FROM 178.134.252.152:30303 4f9a08798c269172d578cbf78100420387bea6714ad63d1dde1d872254b73beefb29cb072db188ae392f7789afd80eb28c921868852775bd1ade7e1cb0e68393 1057
2017/08/03 09:32:05 [discover] NEIGHBORS HANDLE FROM 178.134.252.152:30303 4f9a08798c269172d578cbf78100420387bea6714ad63d1dde1d872254b73beefb29cb072db188ae392f7789afd80eb28c921868852775bd1ade7e1cb0e68393 425 |
3 tasks
whilei
changed the title
[WIP]: machine-readable peer discovery logs
machine-readable peer discovery logs
Aug 4, 2017
solution: use type switch (faster)
Closing in deference to #328, which includes and extends these changes. |
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Preliminary implementation of writing machine-readable logs to
mlog
files; peer discovery logs are the first API.Find initial working spec here: https://gist.github.com/whilei/2acddb54d169881e1bfb5651bd16f234
Still builds from, and includes unmerged commits from #324. Unique changes for this PR begin with 670b285.