This release fixes a couple of bugs:
- Sometimes probe would fail to remove its record of a container when it is destroyed #3623
- Contrast mode was not being reflected in the URL #3617
Thanks to everyone who contributed to this release: @Deepak1100, @SaifRehman, @awolde, @bboreham, @bia, @dholbach, @fbarl, @foot, @guyfedwards, @jrryjcksn, @leavest, @n0rig, @najeal, @paulmorabito, @qiell, @qurname2, @rade, @satyamz, @shindanim, @tiriplicamihai, @tvvignesh, @xrgy.
Special thanks to @qiell and @satyamz for implementing both features!
- Conditional report censoring #3571
- Add a confirmation dialog for deleting a pod #3572
- Add OpenTracing span for report.ReadBinary() #3598
- Add metrics for report size and count per tenant #3599
- Security fixes in dev dependencies #3578
- Use Time Travel context when downloading raw reports #3582
- Fix bug Chrome 56+ can't prevent default wheel events #3593
- Fix dnssnooper probe for multiple CNAMEs #3566
- Fix build-pkg script #3587
- Upgrade to Webpack 4 #3580
- Upgrade client-go version to 10.0.0 #3588
- Upgrade ui-components and some of similar dependencies #3574
- Remove materialize-css JS dep #3596
- The path is actually examples/k8s #3586
- Update examples/k8s RBAC permissions #3595
- Update example yamls to probe Kubernetes once per cluster #3569
- Add CPU and memory requests to example Kubernetes manifests #3570
- Extend FAQ with basic auth through environment variables #3575
This release has a security fix, a few bug-fixes and some other minor improvements.
Special thanks to @arnulfojr, @Akashtic, @AVRahul, @carlosedp, @ycao56 for community contributions!
Security and bug fixes:
- Address vulnerability (CVE-2018-16487) by updating lodash dependency #3568
- Address vulnerability (CVE-2019-0542) by updating xterm.js dependency #3557
- Fix missing nodes in Kubernetes Cluster mode #3444
- Show all connections when one pod has multiple PVCs #3553
- Fix spurious connection to PVC with same name in different namespace #3530
- Fix linkage from metrics graph to external monitoring url #3534
- Fix build mount path in UI unit tests #3558
- Add extra internal ID on control buttons #3565
Feature improvements:
- Dynamically expand namespace list if you hover over it #3117 #3562
- Make Scope's container memory usage number match Docker's #3435
Build improvements:
- Add ARM64 build #3537
- Add a CI test to detect the problem which caused release 1.10.0 to fail #3440
- Update some 3rd-party UI components #3450
- re-order some code to make it more readable #3551
- Small performance improvement in rendering Kubernetes volume claims #3445
Documentation improvements:
This is a re-release of 1.10.0 which got hit by an unfortunate build error.
- UI Build: stop deleting static ui files when building external ui #3439
Highlights:
-
Add Kubernetes Persistent Volume snapshot and clone operations #3355
-
Kubernetes objects can be reported just once in a cluster, instead of reporting the same data from every node. #3274 #3419 #3432
-
App now supports http basic auth #3393
Some changes (#3266, #3272) were made to the wire protocol, which means new probes are not compatible with an older app.
Thanks for contributions from @Akash4927, @akshatnitd, @bhavin192, @hexmind, @gfeun, @gotjosh, @gruebel, @hexmind, @jgsqware, @ltachet, @muthumalla, @rvrvrv, @satyamz, @ScottBrenner, @ssiddhantsharma, @visualapps, @WhiteHatTux, @ycao56, @Xivolkar - some of these came via Hacktoberfest.
Performance:
- Probe: use netlink to talk to conntrack #3298
- Remove First and Last data members from Metrics structs #3266
- Remove old 'Controls' field which was replaced two years ago #3272
- Probe: Don't report dead or defunct processes #3379
- Simplify fetch of IP addresses in a namespace #3335
- Discard pod updates for other nodes #3391
- Probe: Rate-limit report publishing #3386
- In multitenant app, drop all nodes for big topologies #3384
Bug fixes and minor improvements:
- Initial Container Runtime Interface (CRI) support #3275 #3305 #3308 #3392 #3364
- Add storage driver name to Persistent Volume #3260
- Fix WithLatests() fixup on duplicate keys #3281
- Add EKS variant of 'pause container' #3421
- Add Opentracing (Jaeger) distributed tracing for profiling the app #3307 #3380 #3383 #3325
- app: update stopped container message #3396
- Example Kubernetes yaml files: fix typos and work with newer Kubernetes #3403
- Example Kubernetes yaml files: add support for PodSecurityPolicy #3354
- Example Kubernetes yaml files: add rules in cluster role for storage components #3290
- rename 'storagesheet' to 'sheet' in reports #3323 #3324
- Check container is running before trying to open its namespace #3279
User Interface
- Upgrade to font-awesome 5 and new icons #3426
- replace share icon with sitemap on graph button #3387
- Bump ui-components version #3282 #3431
- Use GraphNode component from ui-components library #3262
- Make header semitransparent #3294
- Fix broken styling of terminal in contrast mode #3347
- Add onRouteChange hook to Scope app #3349
- Stop two Scope instances on the same domain from changing each other's history #3326
- Use new Search component from ui-components repo #3337
- Update localStorage with Scope state also on initial router hook #3315
Build and test improvements
- Remove weaveutil and weave from Dockerfile.cloud-agent #3369
- Build on Power CPU architecture. #3231
- build: Fix import for golint which has moved #3389
- Sleep to stop TestRegistryDelete() failing #3334
- Fix vendoring of ugorji/go #3280
- Update version of sirupsen/logrus #3276 #3277
- Upgrade Kubernetes client-go version to 8.0.0 #3329
- Update lodash dependency to remove security warning #3310
- Rework UI build to improve caching and fix packaging issue #3353 #3356 #3360 #3382
- Update the 'tools' subdirectory #3311 #3312
- Clean up Dockerfiles #3411
- update vendored copy of tcptracer-bpf for licence reasons #3336
- vendor: update gopkg.in/yaml.v2 to latest upstream #3317
- Create bpf stop file differently, in integration test #3332
- Move to CircleCI 2.0 #3333
Highlights:
Scope now displays Kubernetes Storage (PersistentVolume and PersistentVolumeClaim) information on the Pods view. #3132
Thanks to @satyamz and all at OpenEBS for this contribution!
Also thanks for the example Kubernetes manifests from @tasdikrahman.
Bug fixes and minor improvements:
- Fix 'Unmanaged' nodes showing despite 'Hide Umanaged' filter #3189
- Fixes monospace font overlapping in terminal+linux #3248
- make process-by-name topology show something #3208
- Use the default value for a TopologyOption if omitted #3165
- Adjusted terminal character width/height estimation #3179
- Fix pause image detection for Kubernetes 1.10 #3183
- ebpf: update check for known faulty Ubuntu kernels #3188
- Add option to print probe reports to stdout, for debugging #3204
- Fix querier panic introduced in #3143 #3156
- Fix rare crash in filter function #3232
- Probe: fix error message to name the correct flag probe.proc.spy #3216
- Remove ProcessWithContainerNameRenderer, it wasn't working #3263
- Close terminal window on exit; update xterm to version 3.3.0 #3172
- Add org.opencontainers.image.* labels to Dockerfiles #3171
- Make table header line up with columns when scrollbar appears #3169
- Add command-line flag to set SQS RPC timeout #3157
Performance:
A number of small performance improvements have gone into this release, reducing memory and CPU usage.
- Probe: remove backwards-compatibility code when publishing reports #3215
- Optimise Node.WithLatests() #3268
- Optimise WithParents() when there is only one parent #3269
- Re-use gzip writers in a pool #3267
- Optimise merge where one side is a subset of the other #3253
- Use a buffer pool in report.ReadBinary() to reduce garbage-collection #3255
- Faster report merging through mutating objects #3236
- Faster path to check an IP address against known networks #3142
- Skip pods with no IP addresses when rendering network connections #3201
- Fetch container IPs directly from the namespace instead of calling 'weave ps' #3207
UI:
A number of changes adjusting fonts and colors, and standardising the UI through the use of a theme.
- Update fonts - use Proxima Nova as a default font instead of Roboto. #3177
- Adjust font sizes #3181
- Update gray theme colors #3234
- Use new accent theme colors #3230
- Use new purple theme colors #3229
- Use new theme gray colors #3227
- Stop using dropped theme colors #3148
- Merge neutral theme colors #3146
- Slightly lightening background to match the rest of WeaveCloud #3206
- Sentence cased text everywhere #3166
- Show image tag more clearly in node details #3173
- Standardise border radius #3170
- Enforce theme font sizes #3167
- Use only z-index values from the theme #3159
Weave Cloud specific
As well as some bug-fixes, refactoring of places where the integration of Scope into the hosted Weave Cloud UI complicated the code.
- Correct api.getFluxImages usage #3233
- Show deployments in Time Travel #3222
- Separate API endpoint namespace from URL path part #3221
- Fix scope report download URL in Weave Cloud #3213
- Use common TimestampTag component #3195
- Change URL resolution to accommodate Weave Cloud paths #3175
- Support rendering node details extras #3244
- Support TimeTravel injection #3239
Highlights:
- Change in behaviour of table data: Docker labels are now sent in full, while Docker environment variables are not reported by default
- Plugins can now render http links and show controls on more objects
New plugin features:
- Render http links in tables #3105
- Support plugin controls in K8s Service, DaemonSet, StatefulSet, Cronjob. #3110
Bug fixes and minor improvements:
- Work around Ubuntu kernel crash #3141
- Stop truncating tables; disable reporting Docker env vars by default #3139
- Don't show Failed pods #3126
- Make scope start with Docker for Mac again. #3140
- Fix browser history when deep linking into node details with time context #3134
- Move to more consistent colour theme #3116 #3124 #3136
- Fix format string only used in debugging #3129
- Fix docs for OpenShift installation #3128
Performance:
- Use unsafe merge in joinResults.addChildAndChildren() #3143
- Use single-owner code path to accumulate children when rendering #3138
- Simplify Map.Render() #3135
- Let probe send smaller 'shortcut' reports to update the UI faster #3121
Highlights:
- Many performance improvements
- A change in the wire protocol (see #3061 below - the new app is compatible with older probes but not vice-versa)
New features and enhancements:
- Add Kubernetes service type and ports to Services display #3090
Bug fixes and minor improvements:
- revamp install instructions #3052
- Fix 'Unmanaged' nodes showing despite 'Hide Umanaged' filter #3097
- Remove large gap in between header and table #3066
- Blank out value on LatestMap decode insert #3095
- refactor: don't return receiver in Topology.AddNode() #3075
- Remove unused process tree function GetChildren() #3094
Performance improvements:
- Move DNS name mapping from endpoint to report #3061
- Enable setting to stop requesting pod list from kubelet, via environment variable #3077
- Exclude null entries for networks on container nodes in probe report #3091
- Remove flag -probe.kubernetes.interval and stop re-syncing Kubernetes data #3080
- Optimise processTopology() #3074
- More efficient docker Tagger #3093
- Add topology.ReplaceNode() for efficiency #3073
- Set 'omitempty' on Node Adjacency #3062
Security:
- Bump JavaScript dependencies to pick up fix for security advisory #3102
Build and test:
- Add a test that checks if reports with data round-trip #2399
- Save generated source code as a CI artifact, in case it is needed for troubleshooting. #3056
Weave Cloud related changes:
- Disable detail panel link if monitoring is not available. #3070 #3072
- Add (cloud.)weave.works to the list of known services #3084
- Only modify document title if running standalone #3071
- Fixes bug showing "container image status" on all resource types #3054
- Changes relating to Guided Tours #3068 #3088
- Show Time Travel at all times in Weave Cloud #3065
- Update service cpu/mem link #3060
Bug fixes and minor improvements:
- Fixes the problem where, if the api server was unreachable at start up, no kubernetes resources would be reported. #3050
Highlights:
- eBPF tracker working on GKE: this makes connection tracking more efficient and accurate
New features and enhancements:
- vendor: bump tcptracer-bpf #3042
Bug fixes and minor improvements:
- Close terminal pipe, when closing the pod panel #3045
- Fetch cronjobs from 'batch/v1beta1'. This fixes a bug which caused CronJobs in recent k8s not to appear in Scope. #3044
Documentation:
- Update install instructions to use weave namespace #3041
Highlights:
- A bug was introduced in 1.7.0 when closing the pod log terminal panel that causes the probe to spin, therefore saturating a cpu. This has been fixed in #3034.
- Fix issue that would cause the probe not to report certain kubernetes resources if, at start up, it failed to successfully connect to kubernetes' API.
Bug fixes and minor improvements:
- logReadCloser: ensure EOF after
Close()
#3034 - Check if k8s resources are supported in
runReflectorUntil
#3037 - Stop page router on App unmount #3025
- client: Fix uptime sort in table view #3038
Internal improvements and cleanup:
- Remove default values from URL state hash #3030
- Correctly handle Time Travel resuming in Monitor #3028
- Change pausedAt format from moment() back to ISO string #3036
Highlights:
- Displaying pod logs now shows all container logs with each line prefixed by
[containerName]
. Previously, the same view would fail if the pod had multiple containers. - Show all Kubernetes namespaces, including empty ones.
- Various small improvements and performance work
New features and enhancements:
- Reading pod logs returns all container logs #3013
- Probe reports namespaces #2985
- show unconnected processes #3009
Bug fixes and minor improvements:
- Set a timeout to Terminal animation #3021
- 'updateKubeFilters` returns early if there are no namespaces #3017
- don't map image adjacencies to hosts #2997
- cope with one->many topology mappings #2996
- Tag images at build time #2987
- don't exclude NATed connections in mapping to processes #2978
Internal improvements and cleanup:
- refactor: extract common code in endpoint mapping #3016
- refactor: make PropagateSingleMetrics a renderer #3008
- refactor: move RenderContext where it belongs #3005
- render sensible labels for nodes with little/no metadata #2998
- refactor: banish TheInternet #3003
- benchmark report summarization #3000
- refactor: inline summarisation of metadata, metrics, tables #2999
- Upgrade Go to 1.9.2 #2993
- simplify
joinResults
#2994 - Suggest how to disable weave errors and warnings #2990
- refactor: drop networks from render.MapFunc #2991
Performance improvements:
- remove Node.Edges #2992
- remove unnecessary metadata propagation #3007
- permit setting
probe.kubernetes.interval
to 0 #3012 - Stop fetching ReplicaSets and ReplicationControllers #3014
- optimisation: pre-allocate, and fewer slices during summarisation #3002
- make
Report.Topology(name)
fast #3001
Weave Cloud related changes:
- Bump ui-components to v0.4.18 #3019
- Simplifying backgrounds to match lightgray in service-ui and ui-compo… #3011
This is a minor patch release.
Internal improvements and cleanup:
- Upgrade weaveworks-ui-components to 0.3.10 #2980
- Lock styled-components version and upgrade ui-components #2976
- don't embed docker binary #2977
- bump embedded Weave Net version to 2.1.3 #2975
- do not report allocations in benchmarks #2964
Performance improvements:
- "Intern" map keys #2865
- Upgrade reports before caching #2979
- report.Upgrade() add deployments to pods as parent #2973
Weave Cloud related changes:
- probe: Use an absolute FQDN for cloud.weave.works by default #2971
- Bump ui-components to include decomposed Time Travel #2986
- cheap probe connectedness api endpoint #2983
This is a minor patch release.
New features and enhancements:
- Upgrade to React 16 #2929
- Humanize reported durations #2915
- Use firstSeenConnectAt for beginning of availability period in Time Travel #2912
- Flat background instead of gradient #2886
Bug fixes and minor improvements:
- fix incorrect reporting of replicaset DesiredReplicas #2955
- filter internet adjacencies #2954
- filter out unconnected pseudo nodes just once, at the end #2951
- Correctly show whether there are new images or not. #2948
- Fix undefined image bug #2934
- Use timestamp in URL #2919
- Fix incorrect image status text bug #2935
- Don't de-reference pointers from ECS without checking #2918
- MAINTAINER is deprecated, now using LABEL #2916
- Try to prevent zooming NaN errors #2906
- Check whether tableContent ref is present #2907
- Use TimeTravel from ui-components repo #2903
- docker: Close pipe when the docker API call fails #2894
- terminal: Fix Caculated typo #2897
- Fix golint if/else #2892
- Make Time Travel a modular component #2888
- Use a context sensitive route for the popped out terminal.html #2882
- Fixes images in details-panel after service -> resources change #2885
- Fixes "Save as svg" functionality. #2883
- tracking: Fix in-flight collision of two related PRs #2867
- lint: Fix 2 sites failing a recently introduced golint check #2868
- Continue processing reports if billing fails #2860
Documentation:
Internal improvements and cleanup:
- make render.ResetCache() reset all caches #2949
- Decorators, begone! #2947
- Expand the app's k8s namespace calculation #2946
- pass render filters and maps by value rather than reference #2944
- Remove optional dependencies #2930
- remove unused memoisation #2924
- Simplify Utsname string conversion #2917
- vendoring: Update gopacket to latest master #2911
- Update minor node dependencies #2900
- Update eslint dependencies #2896
- Get rid of react-tooltip dependency #2871
- Update ugorji/go/codec #2863
Performance improvements:
- make report upgrading fast when it's a no-op #2965
- Remove struct wrapping LatestMap #2961
- Stop reporting ReplicaSets #2957
- optimisation: allocate less memory in LatestMap merging #2956
- Decode reports from a byte buffer #2386
- optimisation: faster knownServiceCache #2952
- optimisation: make Memoise(Memoise(...)) only memoise once #2950
- Rewrite more Map-Reduces as Renderers to save garbage #2938
- Parsing optimisations #2937
- produce stats as part of rendering #2926
- Optimisation: replace three map-reduces with Renderers #2920
- Avoid object creation when scanning DNS names #2921
- Re-implement LatestMap as a sorted slice for better performance #2870
- Small memory-allocation reduction #2872
Weave Cloud related changes:
This is a minor patch release.
New features and enhancements:
- Add ECS Cluster Region option #2854
Bug fixes and minor improvements:
Documentation:
Internal improvements and cleanup:
- Fix test broken by #2854 #2856
- Fix circle.yml syntax #2841
- make circleci ui-upload unconditional #2837
Weave Cloud related changes:
- AWS connection keep-alive #2852
Re-release of 1.6.3 for which there were some problems publishing Docker images.
Documentation:
- Fix phrasing in readme #2836
This is a minor patch release.
New features and enhancements:
- Make Scope's URL message more precise #2810
- Balance timeline zooming sensitivity between Firefox and Chrome #2788
- Adjust timeline zoom sensitivity on Firefox #2777
- run a normal (rather than login) shell in containers #2781
- Add pod restart count to details pane #2761
Performance improvements:
- Make nodes graph animations a bit faster #2803
- Improve Firefox performance #2795
- synthesise k8s service network from service IPs #2779 #2806
Bug fixes and minor improvements:
- restart eBPF tracking on error #2735
- Fix processes/hosts table not appearing #2824
- Fix query filters by adding namespaces and using docker container name #2819
- Remove whitespace from empty connection lists #2811
- Fix rendering of exported SVG #2794
- k8s probe: Fix a panic (nil pointer deref) when a cronjob has never been scheduled #2785
Documentation:
- remove extra indent on note #2816
Internal improvements and cleanup:
- Use Node 8.4 for builds #2830
- refactor: reduce duplication in links_test #2820
- add 'realclean' make target to clear out container images #2771
- get rid of endpoint type indicators #2772
- rename 'report_persistence' capability to 'historic_reports' #2774
- Add test for pods number not updating #2741
- refactor: remove duplication #2765
- push release images to quay.io #2763
Weave Cloud related changes:
- Link scope-ui graphs clickable to prometheus queries #2664
- scope/cortex: fix typo in query filter #2815
- Time Travel: keep active node details panels up-to-date #2807
- Time Travel: unmount in the shutdown() action #2801
- Fixes timetravel timestamp input getting truncatated on OSX #2805
- Time Travel: remove the feature flag and make the availability depend on historic reports capability #2616
- log sqs messages at 'debug' rather than 'info' level #2798
- Fix timeline label vertical displacement on some Chromes #2793
- Shrink timeline height and make years fade out #2778
- Always take timestamp into account in Node Details when time travelling #2775
- Hide Service UI Configure button only in Scope #2766
- Time Travel 3.0 #2703
Bugfix patch release
- k8s probe: Fix a panic (nil pointer deref) when a cronjob has never been scheduled #2785
This is a re-release of 1.6.0. The official build for 1.6.0 inadvertently included outdated versions of some components, which introduced security issues.
Highlights:
- New Kubernetes Controllers view
- Add Kubernetes Stateful Sets and Cron Jobs
- Various small improvements and performance work
New features and enhancements:
- kubernetes: Add StatefulSets and CronJobs #2724
- Make Resource view nodes clickable #2679
- Keep topology nav visible if selected #2709
- Show multiple relatives in the nodes-grid view #2648
- Remove type filter in controllers view #2670
- Remove replica sets #2661
- add k8s combined view #2552
- Gather Weave Net plugin and proxy info from report #2719
Performance improvements:
- optimisation: don't copy report stream unnecessarily #2736
- new full reports are more important than old and shortcut reports #2743
- increase default conntrack buffer size #2739
- Use Kubernetes node name to filter pods if possible #2556
- refactor: remove unnecessary and dead Copy() #2675
- performance: only color connected once #2635
- fast network membership check #2625
- memoize isKnownServices for improved performance #2617
- faster matching of known services #2613
Bug fixes and minor improvements:
- k8s: Use 'DaemonSet', 'StatefulSet' etc instead of 'Daemon Set', 'Stateful Set' #2757
- maximize report publishing timeout #2756
- do not back off on timeouts when sending reports #2746
- Fix Pods number in graph not updating (minor label) #2728
- defend against nils #2734
- Fix New Version notification not showing #2720
- render: In minor labels, display '0 things' instead of blank if zero things present #2726
- Reset nodes in frontend when scope-app restarted #2713
- Keep topo nav visible if subnav selected #2710
- don't miss, or fail to forget, initial connections #2704
- bump tcptracer-bpf version #2705
- fix ebpf init race segfault #2695
- Make graph layout zoom limits constant #2678
- Last line of defense against overlapping nodes in graph layout #2688
- Fix
yarn pack
ignoring directory cli flag #2694 - Show table overflow only if limit exceeded by 2+ #2683
- render/pod: Fix a typo in Map2Parent where UnmanagedID will always be used for noParentsPseudoID #2685
- don't show container count in host detail panel image list #2682
- correct determination of a host's container images #2680
- Prevents 6 digit pids from being truncated in details panel/table mode #2666
- correct polarity of initial connections #2645
- ensure connections from /proc/net/tcp{,6} get the right pid #2639
- Avoid race conditions in DNSSnooper's cached domains #2637
- Fix issues with union types #2633
- Fix typo in site/plugins.md #2624
- correct
nodeSummaryGroupSpec
#2631 - Ignore ipv6 #2622
- Fix the table sorting order bug for numerical values #2587
- Fix zoom for
npm start
#2605 - fix error when docker DAEMON is running with user namespace enabled. #2582
- Do not read tcp6 files if TCP version 6 isn't supported #2604
- Elide token-only credentials in cli arguments #2593
- do not filter endpoints by procspied/ebpf in renderers #2652
Internal improvements and cleanup:
- Pass build tags to unit tests #2618
- Allows to skip client build when doing make prog/scope #2732
- only pass WEAVESCOPE_DOCKER_ARGS to actual probe/app start #2715
- Set package.json version to 0.0.0 #2692
- simplify connection join #2714
- EbpfTracker refactoring / cleanup #2699
- Yarn prefixes version with
v
when packing #2691 - don't use eBPF in a couple of tests #2690
- Update README/Makefile/package.json to use yarn #2676
- render/pod: Remove unused options and incorrect code #2673
- Use new k8s go client #2659
- Update github.com/weaveworks/common & dependencies (needs go1.8) #2570
- Publish updated OpenShift instructions (close #2485) #2657
- make integration tests pass with latest Weave Net release (2.0) #2641
- Improved rendering order of nodes/edges in Graph View #2623
- refactor: extract a couple of heavily used constants #2632
- Use latest go1.8.3 #2626
- Use Go 1.8 #2621
- Use 127.0.0.1 instead of localhost, more #2554
- Moved highlighted nodes/edges info to selectors #2584
- rationalise report set usage #2671
- ignore endpoints with >1 adjacency in process rendering #2668
- Honor DOCKER_* env variables in probe and app #2649
Weave Cloud related changes:
- Back off when writing to Dynamo and S3 #2723
- Time travel redesign #2651
- Make API calls with time travel timestamp #2600
Bugfix patch release
Bug fixes:
- initial connections have wrong polarity #2644
- connection to dead process associated with different process #2638
Highlights:
- More accurate and cheaper connection tracking with eBPF, which now is enabled by default.
- Bug fixes and performance improvements.
New features and enhancements:
Performance improvements:
- drop addr and port from Endpoint.Latest map #2581
- parallel reduce #2561
- don't read all of /proc when probe.proc.spy=false #2557
- optimise: don't sort in NodeSet.ForEach #2548
- encode empty ps.Maps as nil #2547
Bug fixes:
- re-target app clients when name resolution changes #2579
- correct type for "Observed Gen." #2572
- Back off upon errored kubernetes api requests #2562
- Close eBPF tracker cleanly #2541
- Simplify connection tracker init and fix procfs scan fallback #2539
- Guard against null DaemonSet store #2538
Internal improvements and cleanup:
- es6ify server.js and include in eslint #2560
- Fix prog/main_test.go #2567
- Fix incomplete dependencies for
make scope/prog
#2563 - bump package.json version to current scope version #2555
- simplify connection join #2559
- Use map helpers #2546
- add copyreport utility #2542
Weave Cloud related changes:
Highlights:
- New Docker Swarm view
- New Kubernetes DaemonSets view
- Probe performance improvements
- Many bugfixes
New features and enhancements:
- Add Docker Swarm view #2444 #2452 #2450
- Kuebrnetes: add daemonsets #2526
- Canvas zoom control #2513
- Consistent resource consumption info in the resource view #2499
- k8s: show all namespaces by default #2522
- Hide container image status for pseudo nodes #2520
- Break out some Azure-based services from "The Internet" #2521
- Remove zoom on double-click #2457
- allow disabling of weaveDNS advertising/lookup #2445
Performance improvements:
- process walker perfs: optimize readLimits and readStats #2491
- proc walker: optimize open file counter #2456
- eliminate excessive calls to mtime.Now() #2486
- Msgpack perf: write psMap out directly #2466
- proc_linux: don't exec
getNetNamespacePathSuffix()
on every walk #2453 - gzip: change compression level to the default #2437
Bug fixes:
- Let conntrack track non-NATed short-lived connections #2527
- Re-enable pod shortcut reports #2528
- ebpf connection tracker: perf map fixes #2507
- ebpf: handle fdinstall events from tcptracer-bpf (aka "accept before kretprobe" issue) #2518
- Fix arrow heads positioning #2505
- Avoid null dereferences in ECS client #2514 #2515
- api_topologies: Don't put namespace filters on containers-by-dns/image #2506
- Log specific error when deployments are not supported #2501
- Missing namespace option in url state breaks filters #2490
- Metric selector not showing pinned metric highlighted #2467
- Fixed view mode switching keyboard shortcuts #2471
- don't lie about reachable address #2443
- Fix node highlight for all shapes #2430
- View mode selector not responding well to resize #2396
- Empty metric selector appearing as a dot #2425
- Cloud node border too thin comparing to other nodes #2417
- Table-mode: origin of details panel is not where clicked #1754
- Table-mode: tooltip for "The Internet" is missing minor label #1884
- Fixes loading of viewState from localStorage into URL #2409
- Don't reset zoom on refresh layout #2407
- Hide the opened help panel when clicking on the search bar icon #2406
Documentation:
- Report data structure documentation #2025
- Add multicolumn-table documentation #2516
- Update k8s installation instructions #2512 #2519
- Update install docs #2257
- Add plugin mention to scope readme #2454
- Fix disabling Scope in the ECS AMI #2435
- Add AMI docs into main docs, modified weave token instructions in one place #2307 #2416 #2415
Internal improvements and cleanup:
- Reduce the number of places topologies are explicitly listed #2436
- Use prop-types library to silence PropTypes deprecation warning #2498
- Update node libraries #2292
- Added search type variable #2493
- Add website preview via Netlify #2480
- Consisten spacing in Markdown headings #2438
- only lint files in git ls-files, not .git/* #2477
- publish master to dockerhub (again) #2449
- scope script: Allow 'user' part of image name to be given by DOCKERHUB_USER env var #2447
- Make various anonymous fields named #2419
- vendor: update gobpf and tcptracer-bpf #2428
- extras/dialer updates and fixes #2350
- Update tcptracer-bpf and re-enable test 311 #2411
- Add check for old options #2405
- shfmt: fix shell formatting #2533
Weave Cloud related changes:
- close s3 response body to prevent leaks #2442
- Add service images widget #2487
- Add weavenet metrics to billing #2504
- Calculate viewport dimensions from the scope-app div #2473
- Added mixpanel tracking for some basic events #2462
- Add NodeSeconds to billing emitter #2422
Highlights:
- New resource usage view
- New Arrows in graph view to indicate connection directions
- Weave Cloud Agent Docker-certified image
- eBPF connection tracking (enabled with --probe.ebpf.connections=true)
New features and enhancements:
- Resource usage view #2296 #2390
- Edge arrows #2317 #2342
- Add eBPF connection tracking #2135 #2327 #2336 #2366
- View multiple Kubernetes namespaces at once #2404
- Exclude pause containers when rendering k8s topologies #2338
- When k8s present, allow filtering of containers by namespace #2285 #2348 #2362
- Add ECS Service scale up/down controls #2197
- Improve error reporting when invoking weave script #2335
- Add options to hide args and env vars #2306 #2311 #2310
- Add loading indicator on topology option change #2272
- report playback #2301
- Show loading indicator on topology changes #2232
Performance improvements:
- Map decode optimisations #2364
- Remove LatestMap, to reduce memory allocation #2351
- Decode via byte slice for memcache and file read #2331
- quantise reports #2305
- Layout rendering dynamic optimizations #2221 #2265
Bug fixes:
- Pinned metric temporarily not displayed on mouse leave #2397
- Search doesn't consider nodes of unloaded topologies #2395
- Help panel height overflow in Containers view #2352
- "Save canvas as SVG" button shown in table mode #2354
- process with no cmd are shown with no name #2315
- Throb animation is called on graph nodes even when the search query doesn't change #2255
- pod names missing #2258
- parse --probe-only as intended #2300
- Graph view zoom states get reset when switching to table view #2254
- graph not rendered top-down, despite lack of cycles #2267
- Hide Uncontained filter in DNS view not hiding uncontained #2170
Documentation:
Internal improvements and cleanup:
- integration test: disable flaky test 311 #2380
- Add job to trigger service-ui build #2376
- Use yarn package manager #2368
- integration tests: list containers for debugging #2346
- scope: use same Docker args for early dry run #2326 #2358
- Bump react version #2339
- integration: disable tests with internet edge #2314
- Secure integration tests #2312
- integration: restart docker daemon after each test #2298
- Changed ui-build-pkg job to use a docker container #2281
- integration tests: fix scripts #2225
- circle.yml: Fix ui upload step so it doesn't build twice #2266
Weave Cloud related changes:
- Create cloud agent image #2284 #2277 #2278
- Container Seconds should not be Container Nanoseconds #2372
- Clear client polling and nodes state on dismount #2361
- Fluent Billing Emitter #2359
- Correct dynamoDB metric label #2344
- Add logic to turn off network requests when Scope dismounts #2290 #2340
- Load contrast stylesheet #2256
- Consolidate API requests into single helper; added CSRF header #2260
- Add logic to remove non-transferrable state when switching Cloud instances #2237
This is a minor patch release.
Documentation
Bugfixes
Improvements
- Reintroduce probe checkpoint flags for kernel version and OS #2224
- Upgraded xterm.js to 2.2.3 #2126
- Allow random seed in dialer #2206
- Rename ECS Service node ids to be cluster;serviceName #2186
Highlights:
- Performance improvements (both in UI and probes).
- Scope now requires Docker version >= 1.10.
New features and enhancements:
- ECS: service details panel should list its tasks #2041
- Prioritize ecs topologies on initial load if available #2105
- Add control status icon to Terminal header #2087
- scope launch script improvements #2077 #2093
- Maintain focus on hovered node table rows #2115
- Add control to reset local view state #2080
- Check that conntrack events are enabled in the kernel #2112
- Hardcode 127.0.0.1 as loopback IP for default target #2103
- prog/main: use flags.app.port for default target #2096
Performance improvements:
Bug fixes:
- ECS reporter throttled by AWS API #2050
- Already closed connections showing up in the containers tab #2181
- Node details spinner Chrome display bug fix #2177
- fix error when docker daemon is running with user namespace enabled. #2161 #2176
- DNSSnooper: Support Dot1Q and limit decoding errors #2155
- Contrast mode not working #2165 #2138
- Scope does not create special nodes within the same VPC #2163
- default view fails to select 'application containers only' #2120
- ECS: Missing link to task on container details panel #2040
- kubernetes reporter is broken on katacoda #2049
- probe's procspy does not report netcat's half-duplex long-lived connections #1972
- Sparkline component throws errors when a container is turned off #2072
- Graph/table buttons don't resize nicely #2056
- JS error on edges with lots of waypoints #1187
- Fix two bugs caused by transition to D3 v4 #2048
- Popped out terminal styles don't quite align with in-scope terminal styles #2209
- Radii of rounded-corner shape don't quite align #2212
Documentation:
- Fix Scope arguments in Docker Compose installation docs #2143
- Document how to run tests on website #2131
- Follow redirections in curl when getting k8s resources #2067
Internal improvements and cleanup:
- Embed and require Docker >= 1.10 #2190
- don't attempt to make 'make clean' work on old checkouts #2189
- Fix linter errors #2068 #2166
- Fix ownership issues with client/build-external #2153
- Allow Scope UI to be installed as a Node module #2144 #2159
- Upgrade container base image to alpine:3.5 #2158
- Use Sass instead of Less #2141
- probe: refactor probeMain #2148
- Update to go1.7.4 #2147
- Bump tools subtree and fix integration tests #2136
- Add support for generic multicolumn tables #2109
- extras/dialer: move dialer.go to sub directory #2108
- Forward OS/Kernel version to checkpoint #2101
- Fix force-push to master #2094
- Upgraded eslint & eslint-config-airbnb #2058 #2084 #2089
- ecs reporter: Fix some log lines that were passing *string instead of string #2060
- Add flag for logging headers #2086
- Add extras/dialer #2082
- Remove wcloud #2081
- Add client linting to CI config #2076
- Importing lodash util functions explicitly #2053
- procspy: use a Reader to copy the background reader buffer #2020
- Use newly-created 'common' repo #2061
- Fix all the npm library versions #2057
- linter: fix punctuation and capitalization #2021
- Using
webpack-dev-middleware
instead ofwebpack-dev-server
directly #2034 - Create
latest_release
Docker image tag during release process #2216
Weave Cloud related changes:
- Deploy to quay when merging to master #2134
- Removed leading slash from getAllNodes() api request #2124
- Correctly instrument websocket handshakes #2074
Highlights:
- New ECS view which allows visualizing your tasks and services in Amazon's EC2 Container Service.
- Custom label-based container filters can be defined through
--app.container-label-filter
New features and enhancements:
- Add ECS views #2026
- Add custom label-based filters in container view #1895
- Improve plugin errors tooltip #2022
- Add anti-dance heuristics (and feature flags) #1993
- Table-mode: sort ips numerically #2007
- increase black/white text contrast in contrast mode #2006
- Improve view-node-in-topo button usability #1926
- Hide Weave topology if empty #2035
Performance improvements:
- Add graph complexity check on page load #1994
Bug fixes:
- plug goroutine leak in control #2003
- Fix details panel not closing on canvas click #1998
- Empty publicpath needed for relative paths of scope #2043
Documentation:
- Use intuitive standalone service name in compose #2019
- Fix kubectl port-forward command to access the scope app locally #2010
- Update website plugins documentation #2008
Internal improvements and cleanup:
- Combined external and prod webpack config files #2014
- Update package.json #2017
- Move plugins to the new organization #1906
- Change webpack local config to use source maps #2011
- middleware/errorhandler: Implement Hijacker so it works with ws proxy #1971
- Fix time-dependant test (stop testing docker client library) #2005
- Give time to the overlay test backoff collectors to finish #1995
- Update D3 to version 4.4.0 #2028
Weave Cloud related changes:
- Add OpenTracing support to TimeRequestHistogram #2023
Highlights:
- New Weave Net View which allows visualizing and troubleshooting your Weave Network.
- New nodes for well-known services. The Internet node is now broken down in individual nodes for known cloud services.
- Improved terminals, with proper resizing, scroll locking and better visuals.
- Refined UI with particularly improved connection information.
- Lots of squashed bugs.
New features and enhancements:
- New Weave Net view #1182 #1973 #1981
- Show well-known services #1863 #1881 #1887 #1897
- Terminal improvements
- Miscellaneous UI improvements
- show more details of a node's internet connections #1875
- Close help dialog when the canvas is clicked #1960
- Improve metadata table 'date' format #1927
- Add a new search section to the help popover #1919
- Add label_minor to tooltips in connections table #1912
- Add localstorage support for saving view state #1853
- Makes services the initial topology if available #1823
- Add image information table to container details panel #1942
- Allow user to specify URLs on the command line, and use that to allow per-target tokens. #1901
- Apply filters from current view to details panel #1904
- Increase timestamp precision #1933
- Add prometheus metrics endpoint to probes. #1915
- Allow users to specify conntrack buffer size. #1896
- Plugins: Add support for table based controls #1818
Performance improvements:
- make smartMerger.Merge merge reports in parallel #1827
Bug fixes:
- Goroutine leak in scope app #1916 #1920
- CPU Usage is not accurate on hosts #1664
- Certain query strings would contain a && instead of & #1953
- Metrics on canvas get stuck #1829
- conntrack not used even though it's working #1826
- pod counts and details panel lists do not respect namespace #1824
- Discard short-lived connections to/from Pods in the host net #1944
- probe: Stats gathering can be started twice #1799
- Visual bug where empty span shows up #1945
- inbound internet connection counts are too fine-grained #1867
- IP address truncated in Internet node details panel connection list #1862
- Incorrect number of connections shown on internet nodes #1495
- details panel connection counts are too high #1842
- inbound internet connections reverse-resolved incorrectly #1847
- Scope hangs after browser reload if current topology goes away #1880
- node names in connection list truncated unnecessarily #1882
- numeric values in details panel tables should be right aligned #1794
- Plugin status line is broken #1825
- Table-mode: non-metric columns are sorted alphabetically reverse #1802
- Fix argument escaping in Scope #1950
- Image details panel shows truncated image name instead of ID #1835
- Truncated tooltips #1139
- Incorrect height of terminal window in Safari #1986
Documentation:
- Simplify k8s instructions #1886
- Improve installation documentation #1838
- Update Scope version in documentation #1859
Internal improvements and cleanup:
- Gracefully shutdown app, letting active http requests finish with timeout #1839
- middleware/errorhandler: Fix a bug which meant it never works #1958
- middleware: Add an ErrorHandler middleware used to serve an alternate handler on a certain error code #1954
- Update client deps to use Node v6.9.0 #1959
- Change term.js library to xterm.js #1948
- Fix linter errors on unkeyed fields #1922
- Fix linter error for string in context.WithValue #1921
- Update tools subtree #1937
- Fix circle.yml to actually deploy external ui changes #1910
- Extend logging middleware to optionally only log failed HTTP requests #1909
- Add option to scope to have static content served from S3 instead #1908
- Upgrade to go1.7 #1797
- circleci: push traffic control plugin image to docker hub #1858
- refactor: extract pluralization #1855
- use go-dockerclient's Client.Stats #1833
- Print logs to debug shutdown integration test #1888
- Allow a nil RouteMatcher in instrumentation #1852
Weave Cloud related changes:
- Don't reencode reports in the collector #1819
This is a minor patch release.
New features and enhancements:
- Extend kubernetes client flags to match kubectl #1813
Bug fixes:
Highlights:
- New Table Mode as an alternative to Scope's classic graph view. It provides higher information density, proving particularly useful when there are many nodes in the graph view.
- Considerable performance enhancements: the CPU efficiency of the Scope App has increased in more than 50% and the Scope probes over 25%.
New features and enhancements:
- Table mode #1673 #1747 #1753 #1774 #1775 #1784
- Loading indicator #1485
- Don't show weavescope logo when running in a frame #1734
- Reduce horizontal gap between nodes in topology views #1693
- Elide service-token when logging commandline arguments #1782
- Don't complain when stopping Scope if it wasn't running #1783
- Silence abnormal websocket close #1768
- Eliminate stats log noise from stopped containers #1687 #1798
- Hide uncontained/unmanaged by default #1694
Performance improvements:
- Remove and optimize more Copy()s #1739
- Use slices instead of linked lists for Metric #1732
- Don't Copy() self on Merge() #1728
- Improve performance of immutable maps #1720
- Custom encoder for latest maps #1709
Bug fixes:
- Connections inside a container shown as going between containers #1733
- Probes leak two goroutines when closing attach/exec window #1767
- Scale node labels with the node's size. #1773
- Kubernetes infra containers seem to resurface in latest on 1.3 #1750
- Search icon is above text #1715
- Highlighting is unpredictable #1756
- Details panel truncates port to four digits #1711
- Stopped containers not shown with their names #1691
- Terminals don't support quote characters from intl keyboard layouts #1403
Internal improvements and cleanup:
- Launcher script: Fix inconsistent whitespace #1776
- Lint fixes #1751
- Add browser console logging for websocket to render times #1742
- circle.yml: deploy master with non-upstream hub accounts #1655 #1710
- Delete unused instrumentation code #1722
- Update version of build tools #1685
- Add flag for block profiling #1681
Weave Cloud related changes:
- Also serve UI under /ui #1752
- Name our routes, so /metrics gives more sensible aggregations #1723
- Add options for storing memcached reports with different compression levels #1684
Bug fixes:
- Scope fails to launch on fresh Docker for Mac installs #1755
This is a bugfix release. In addition, the security of the Scope probe can be hardened by disabling
controls with the new --probe.no-controls
flag, which prevents users from
opening terminals, starting/stopping containers, viewing logs, etc.
New features and enhancements:
- Allow disabling controls in probes #1627
- Make it easier to disable weave integrations #1610
- Print DNS errors #1607
- Add dry run flag to scope, so when launched we can check the args are valid. #1609
Performance improvements:
- Use a slice instead of a persistent list for temporary accumulation of lists #1660
Bug fixes:
- Should check if probe is already running when launch in standalone mode on Docker for Mac #1679
- Fixes network bars position when a node is selected. #1667
- Scope fails to launch on latest Docker for Mac (beta18) #1650 #1669
- Fixes terminal wrapping by syncing docker/term.js terminal widths. #1648
- Wrongly attributed local side in outbound internet connections #1598
- Cannot port-forward app from kubernetes with command in documentation #1526
- Force some known column widths to prevent truncation of others #1641
Documentation:
- Replace wget in instructions with curl, as it's more widely avail. on macs #1670
- Don't prepend
scope launch
with sudo #1606 - Clarify instructions for using Scope with Weave Cloud #1611
- Re-added signup page #1604
- weave cloud screen captures #1603
Internal improvements and cleanup:
- Lint shellscripts from tools #1658
- Promote fixprobe and delete rest of experimental #1646
- refactor some timing helpers into a common lib #1642
- Helper for reading & writing from binary #1600
- Updates to vendoring document #1595
Weave Cloud related changes:
- Store a histogram of report sizes #1668
- Wire up continuous delivery #1654
- Count memcache requests even if they time out #1662
- Adding a static report file mode. #1659
- Bump memcache expiration #1640
- Fixes to memcache support #1628
- Refactor caching layers in dynamo collector #1616
- Rework Scope metrics according to Prometheus conventions. #1615
- Fix nil pointer error when memcache not enabled #1612
- Add backoff to the consul client #1608
- Query memcached from dynamo db collector #1602
- Use histograms over summaries #1665
Highlights:
- New network filter to quickly ascertain what networks your containers belong to.
New features and enhancements:
- Network view #1528 #1593
- Label deployment nodes with replica count #1530
- Add flag to disable reporting of processes (and procspied endpoints) #1511
- Add pod status to summary table #1523
- Add filters for pseudo nodes. #1581
Performance improvements:
- Fast start the dns resolution ticker to improve first report latency. #1508
Bug fixes:
- Fix tall search box in Firefox #1583
- Probe reporter stuck #1576
- Container in multiple networks not showing all connections #1573
- scope probe connects to localhost & prod even when given explicit hostnames #1566
- Fix Docker for Mac check #1551
- If k8s objects only have one container, show that container's metrics on them #1473
- Don't ever store NEW conntrack flows (only ever store updates). #1541
- Pods with > 1 container making connections do not show any connections #1494
- Missing edges when using Docker's IPAM driver #1563
- Duplicate stack in "by image" view #1521
Documentation:
Internal improvements and cleanup:
- Add Identity middleware #1574
- Rewrite net/http.Request.{URL.Path,RequestURI} consistently #1555
- Add Marathon JSON for launching on minimesos cluster #1509
- Circle integration for auto docs publishing. #1517
- Tag scope images on docker hub as we do in service #1572
- Scope slow: improve error messages for debugging #1534
- circle.yml: deploy non-master branches #1535
- Add docker hub badge #1540
- Increase test replicas #1529
- Ignore IPv6 addresses in Docker reporter #1552
Weave Cloud related changes:
- Add probe version header to probe requests #1564
- Fetch non-cached reports in parallel #1554
- Various fix ups for multitenancy #1533
- Use NATS for shortcut reports in the service. #1568
- If we don't get a path name from the router, make one up from the url. #1570
- Log errors in response to http requests. #1569
- Put reports in S3; add in process caching #1545
- Use smart merger in the DynamoDB collector. #1543
- Allow user to specify table name and queue prefix. #1538
- Get route name before munging request #1590
Highlights:
This release comes with:
- Search: new smart search field that allows you to filter what you can see by container names, all kinds of metadata, e.g., IP addresses, and metric comparisons, e.g., CPU > 50%.
- Enhanced Kubernetes Visualization: namespace filters, ReplicaSet/Deployment views, extra metadata, better navigation, show Pod logs, delete Pods, bugfixes and more ...
- Scope App performance improvements: ~3X reduction in CPU consumption.
New features and enhancements:
- New search field #1429 #1499
- Kubernetes improvements:
- Deployment and Replica Set views #1436
- Add scale up/down controls on deployments, replica sets, and replication controllers #1451
- Filter by Kubernetes Namespaces #1386
- Remove App->Probe deployment ordering restriction #1433
- Show Pod IP and # container in the children table in details panel. #1435 #1409
- Add pod delete controls #1368
- Show the k8s load balancer IP if it is set #1378
- Show number of pods in service #1352
- Filter GKE system containers #1438
- Show k8s labels and container env vars in the details panel #1342 #1465
- Implement
scope help
#1357 #1419 - Add swarm-agent, swarm-agent master to system container filter #1356
- Add control for removing stopped docker containers. #1290
- Add a button to download the report as JSON #1365
- Use reverse-resolved DNS info in the connections table. #1359
- Add a 'Unmanaged' node to k8s views which included non-k8s containers. #1350
- Support docker rename events #1332
- Strip image version from parent links #1348
- Add Docker for Mac support #1448
Performance improvements:
- Scope App:
- Scope Probe:
- Precompute base of the container nodes #1456
Bug fixes:
- Correctly attribute DNAT-ed short-lived connections #1410
- Don't attribute conntracked connections to k8s pause containers. #1415
- Don't show kubernetes views if not running kubernetes #1364
- Missing pod names in kubernetes' pod view and Pause containers don't show as children of pods #1412
- Fix grouped node count for filtered children nodes #1371
- Don't show container labels on container images #1374
docker rm -f
ed containers linger #1072- Somehow internet node goes missing, yet edges are there #1304
- Node IDs with / leads to redirect loop when scope is mounted under a path with slash redirect #1335
- Ignore conntracked connections on which we never saw an update #1466
- Containers incorrectly attributed to host #1472
- k8s: Unexpected edge to the Internet node #1469
- When user supplies IP addr on command line, we don't try to connect to localhost #1477
- Wrong host labels on container nodes #1501
Documentation:
- Restructured Scope Docs #1416 #1479
- Add ECS instructions and badge to README #1392
- Document how to access the Scope UI in k8s #1426
- Update readme to express that daemon sets won't schedule on unschedulable nodes prior to kubernetes 1.2 #1434
Internal improvements and cleanup:
- Migrate from Flux to Redux #1388
- Add kubernetes checkpoint flag #1391
- Add generic path rewrite middleware #1381
- Report hostname and version in probe struct, and version in host node. #1377
- Reorganise the render/ package #1360
- Asset fingerprinting #1354
- Upgrade to go1.6.2 #1362
- Add buffer to mockPublisher channel to prevent deadlock between Publish() and Stop() #1358
- Add explicit group node summariser instead of doing it in the other summaries #1327
- Don't build codecs for render/ package anymore. #1345
- Measure report sizes #1458
Highlights:
This release comes with two main new features.
- Probe plugins: Now you can create your HTTP-based plugin to provide new metrics and display them in Scope. You can read more about it and see some examples here.
- Metrics on canvas: Metrics are now displayed on the nodes and not just on the details panel, starting with CPU and memory consumption.
Also, the performance of the UI has been considerably improved and the 100-node rendering limit has been lifted.
New features and enhancements:
- Probe plugins #1126 #1277 #1280 #1283
- Metrics on canvas #1105 #1204 #1225 #1243
- Node details panel improvements
- Graph view improvements
- Enable launching terminals in hosts #1208
- Allow pausing the UI through a button #1106
- Split the internet node for incoming vs outgoing connections. #566
- Show k8s pod status #1289
- Allow customizing Scope's hostname in Weave Net with
scope launch --weave.hostname
#1041 - Rename
--weave.router.addr
to--weave.addr
in the probe for consistency with the app #1060 - Support new
sha256:
Docker image identifiers #1161 #1184 - Handle server disconnects gracefully in the UI #1140
Performance improvements:
- Performance improvements for UI canvas #1186 #1236 #1239 #1262 #1259
- Reduce CPU consumption if UI cannot connect to backend #1229
Bug Fixes:
- Scope app doesn't correctly expire old reports #1286
- Container nodes appear without a host label #1065
- Resizing the window and zooming in/out can confuse window size #1180
- Link from container -> Pod doesn't work #1180
- Various websocket and pipe fixes. #1172 #1175
- Make
--app-only
only run the app and not probe #1067 - Exported SVG file throws "CANT" error in Adobe Illustrator #1144
- Docker labels not rendering correctly #1284
- Error when parsing kernel version in
/proc
background reader #1136 - Opening the terminal doesn't open work for some containers #1195
- Terminals: Try to figure what shell to use instead of simply running
/bin/sh
#1069 - Fix embedded logo size for Safari #1084
- Don't read from app.Version before we initialise it #1163
- Don't show multiple pseudo nodes in the host view for the same IP #1155
- Fix race conditions detected by race detector from Go 1.6 #1192 #1087
Documentation:
- Provide Docker Compose examples for launching the Scope probe with the Scope Cloud Service #1146
Experimental features:
- Update demo for tracer #1157
Service-mode related changes:
Internal improvements and cleanup:
- Make node/edge highlighter objects immutable in app store #1173
- Make cached edge processing more robust #1254
- Make app-store's topologies object immutable #1167
- Fix TestCollector test #1070
- Update docker client, to get better state strings in the UI #1235
- Upgrade to go1.6 #1077
- React/lodash/babel upgrades + updated linting (linted) #1171
- Remove address topology #1127
- Add vendoring docs #1180
- Fix make client-start #1210
- Downgrade react-motion #1183
- Make bin/release work on a mac. #887
- Add various middleware to app. #1234
- Make unconteinerized build work on OSX #1028
- Remove codecgen-generated file before building package #1135
- Build/install packages before invoking codecgen #1042
- circle.yml: add variable $DOCKER_ORGANIZATION #1083
- circle.yml: deploy on a personal hub account #1055
- circle.yml: disable GCE builds when credentials are missing #1054
- Clean out all the JS in the client build dir. #1205
- Remove temporary files in the build container to shrink it down by ~100MB #1206
- Update tools & build container to check for spelling mistakes #1199
- Fix a couple of minor issue for goreportcard and add badge for it. #1203
Bug Fixes:
- Make pipes work with scope.weave.works #1099 #1085 #994
- Don't panic when checking the version fails #1117
Note: This release come with big performance improvements, cutting the probe's CPU usage by 70% and the app's CPU usage by up to 85%. See detailed performance improvement-related changes below:
Performance improvements:
- Improve codec performance #916 #1002 #1005 #980
- Reduce amount of objects allocated by the codec #1000
- Refactor app for multitenancy #997
- Improve performance of docker stats obtention #989
- Rate-limit reading proc files #912 #905
- Compile k8s selectors once (not for each pod) #918
- Fix reading of network namespace inodes #898
New features and enhancements:
- Node shapes for different topologies, e.g. heptagons for Kubernetes pods #884 #1006 #1037
- Force-relayout button that may help with topology layouts that have lots of edge crossings #981
- Download button to save the current node graph as SVG file #1027
- Replace Show More buttons with carets w/ counts #1012 #1029
- Improve contrast of default view #979
- High contrast mode button for viewing scope on projectors #954 #984
- Gather file descriptors as process metric #961
- Show Docker Labels in their own table in details panel #904 #965
- Improve highlighting of selected topology #936 #964
- Details: only show important metadata by default, expand the rest #946
- Reorder the children tables in the details panel by importance #941
- Shorten docker container and image IDs in the details panel. #930
- Shorten some details panel labels which were truncated #940
- Add Container Count column to container images table #919
- Periodically check for newer versions of scope. #907
- Rename Applications -> Process, sort topologies by rank. #866
- Rename 'by hostname' to 'by dns name' #856
- Add container uptime and restart count to details panel. #853
- Use connection directions from conntrack for improved layout flow #967
- Support for container controls in Kubernetes #1043
- Add debug logging #935
Bug fixes:
- Use TCP for weave dns to fix autoclustering #1038
- Add ping/pong to websocket protocol to prevent websocket connections being dropped when traversing loadbalancers #995
- Handle closing of docker events channel gracefully #1014
- Don't show blank IPs metadata row for containers with no IP #960
- Remove pointer math (comparison) from render caching, as it is unreliable #962
- set TERM=xterm on execs to work around docker issue 9299 #969
- Fix weave tagger crash #976
- Use Sirupsen/logrus logger in the Weave tagger #974
- Fix JSON encoding for fixedprobe #975
- Don't render any metrics/metadata for uncontained node #956
- Update go-dockerclient to fix bug with docker 1.10 #952
- Show nice column labels when no children have metrics #950
- Fixes process-by-name layout with ./foo and /foo nodes #948
- Deal with starting / stopping weave whilst scope is running #867
- Remove host links that link to themselves in details panel #917
- Just show the untruncated label in the tooltip on children #911
- Taking a read lock twice only works most of the time. #889
- Details panel table header looks up label in all rows #895
- Fixes some fields overflowing badly in details panel in Chrome 48 #892
- Stop details cards popping up over the terminal. #882
- Fixes host node/details panel color mismatch #880
- Don't log expected websocket errors #1024
- Overwrite /etc/weave/apps, because it might already exist #959
- Log a warning when reporters or taggers take too long to generate #944
- Minor refactor of backend metadata and metric rendering #920
- Add some tests, and a zero-value for report.Sets #903
Build improvements and cleanup:
- Disable checkpointing in tests. #1031
- Turn off GC for builds. #1023
- Bump template name to get latest version of docker. #998
- Fixes building scope outside of a container. #901
- Don't need sudo when DOCKER_HOST is tcp. #888
- Disable npm progress to speed up build #894
- Refactoring deepequal to satisfy linter #890
Documentation:
- Document how to obtain profiles without
go tool pprof
#993 - Use short URL for scope download #1018
- Added note about docker and go dependency to the readme #966
- Update readme and images. #885
- Update approach to trigger signal dumps #883
New features and enhancements:
- New, interactive contextual details panel #752
- Gather per-process CPU and memory metrics #767
- k8s: Use service account token by default and improve error logging #808
- k8s: Filter out pause as a system container to declutter view #823
- k8s: Render container names from label "io.kubernetes.container.name" #810
- Probes now use TLS against scope.weave.works by default #785
- Allow dismissing a disconnected terminal w/ <esc> #819
Bug fixes:
- General k8s fixups #834
- Use argv[0] for process name, differentiate scope app and probe. #796
- Don't panic if you don't understand the message on the control WS. #793
- Highlight a single unconnected node on hover. #790
- Fixes to Terminal resizing and key support #766 #780 #817
- Correctly collapse nodes in the Container Images view when they use non-standard port. #824
- Stop scope crashing chrome when we get "long" edges. #837
- Fix node controls so they behave independently across nodes #797
Build improvements and cleanup:
- Update to latest tools.git #816
- Update to latest go-dockerclient #788
- Speed up builds #775 #789
- Speed up tests #799 #807
- Split and move xfer package. #794
- Add more tests to procspy #751 #781
- Build example app in container. #831
- Various improvements to build & test #829
Bug fix:
- Scrape /proc/PID/net/tcp6 such that we see both ends of local connections change
New features:
- Add a terminal to the UI with the ability to
attach
to, orexec
a shell in, a Docker container. #650 #735 #726 - Added
scope version
command #750 - Various CPU usage reductions for probe #742 #741 #737
- Show hostname of app you are connected to in the bottom right of the UI #707
- Add host memory and CPU usage metrics to the details panel #711
- Add json support to app POST /api/report #722
- Update the docker version we embed into the scope image to 1.6.2 in sync with weave 1.3 changes. #702
- Show a spinner while node details are loading #691
- Deterministic coloring of nodes based on rank and label #694
Bug fixes:
- Mitigate one-line-of-nodes layouts (when graph has few connections), layout in rectangle instead #679
- When filtering unconnected nodes in the processes view, also filter nodes that are only connected to themselves. #706
- Correctly hide container based on docker labels on the container image. #705
- Show details for stopped container in the default view, by not applying filters to the node details endpoints. #704 #701
- Fix render issues in Safari #686
- Take default topology option if missing in URL #678
- Don't treat missing node as UI error #677
- Unset previous details when deselecting a node #675
- Add x to close details panel again #673
Documentation:
- Add basic security warning. #703
- Add basic kubernetes how-to to the readme #669
- Document debug options for developers #723
- Add 'getting help' section and update screenshot #709
Build improvements and cleanup:
- Don't go get weave, git clone it so weave build errors don't affect Scope. #743
- Reduce image size and build time by merging scope probe and app binaries. #732
- Cleaning up some dead code around edges and edgemetadata #730
- Make
make
build the UI #728 - Omit controls field from json if empty. #725
- JS to ES2015 #712
- Upgraded react to 0.14.3 #687
- Cleaned up node-details-table #676
- Fix react key warning #672
Notes:
- Due to the Scope UI now being able to start/stop/restart Docker containers, it is not wise to have it accessible to untrusted parties.
New features:
- Add lifecycle controls (start/stop/restart) for Docker containers #598 #642
- Add sparklines to the UI for some metrics #622
- Show a message when the selected topology is empty #505
Bug fixes:
- Change node layout incrementally to reduce re-layouts #593
- Improve responsiveness of UI updates to container state changes #628 #640
- Handle DNS Resolution to a set of names #639
- Correctly show node counts for sub-topologies #621
- Allow scope to start after being upgraded #617
- Prevent a stranded pseudo-nodes from appearing in the container view #627 #674
- Parallelise and improve the testing infrastructure #614 #618 #644
New features:
- Add basic Kubernetes views for pods and services #441
- Support for Weave 1.2 #574
- Add containers-by-hostname view #545
- Build using Go 1.5, with vendored dependencies #584
- Make
scope launch
work from remote hosts, with an appropriately defined DOCKER_HOST #524 - Increase DNS poll frequency such that Scope clusters more quickly #524
- Add
scope command
for printing the Docker commands used to run Scope #553 - Include some basic documentation on how to run Scope #572
- Warn if the user tries to run Scope on Docker versions <1.5.0 #557
- Add support for loading the Scope UI from https endpoints #572
- Add support for probe sending reports to https endpoints #575
Bug fixes:
- Correctly track short-lived connections from the internet #493
- Fix a corner case where short-lived connections between containers are incorrectly attributed #577
- Ensure service credentials are sent when doing initial probe<->app handshake #564
- Sort reverse-DNS-resolved names to mitigate some UI fluttering #562
- Don't leak goroutines in the probe #531
- Rerun background conntrack processes if they fail #581
- Build and test using Go 1.5 and vendor all dependencies #584
- Fix "close on nil channel" error on shutdown #599
New features:
- Show message in the UI when topologies exceed size limits. #474
- Provide container image information in detail pane for containers. #398
- When filtering out system containers, also filter out pseudo nodes, if they were only connected to system containers. #483
- Show number of filtered nodes in status pane. #509
Bug fixes:
- Prevent detail pane from hiding nodes on click-to-focus. #495
- Stop radial view from bouncing in some circumstances. #496
- Make NAT tracking component more resilient to failure. #506
- Prevent duplicate reports from reaching the same app. #463
- Improve consistency of edge directionality in some use-cases. #373
- Ensure probe, app, and container shut down cleanly. #424 #478
New features:
- Show short-lived connections in the containers view. #356 #447
- Details pane:
- Add more information:
- Docker labels. #400
- Weave IPs/hostnames/MACs and Docker IPs. #394 #396
- Host/container context when ambiguous. #387
- Present it in a more intuitive way:
- Allow filtering out system containers (e.g. Weave and Scope containers) and unconnected containers. System containers are filtered out by default. #420 #337 #454 #457
- Improve rendering by making edges' directions flow from client to server. #355
- Highlight selected node #473
- Animate Edges during UI transtions #445
- New status bar on the bottom left of the UI #487
- Show more information for pseudo nodes where possible - such as processes for uncontained, and connected to/from the internet. #249 #401 #426
- Truncate node names and text in the details pane. #429 #430
- Amazon ECS: Stop displaying mangled container names, display the original Container Definition name instead. #456
- Annotate processes in containers with the container name, in the Applications view. #331
- Improve graph transitions between updates. #379
- Reduce CPU usage of Scope probes #470 #484
- Make report propagation more reliable #459
- Support Weave 1.1 status interface #389
Bug fixes:
- Trying to reconnect.. in UI even though its connected. #392
- The Applications view goes blank after a few seconds. #442
- Frequently getting disconnected lines in UI #460
- Panic due to closing request body #480
New features:
- Probes now push data to the app, instead of the app pulling it. #342
- Allow probe and app to be started independently, via --no-app and --no-probe flags. #345
- Close details pane when changing topology view. #297
- Add support for --probe.foo=bar style flags, in addition to --probe.foo bar, which is already supported. #347
- Added X-Scope-Probe-ID header to identify probes when sending information to the app. #351
Bug fixes:
- Update scope script to work with master version of weave, where DNS has been embedded in the router. #321
- Fixed regression where process names weren't appearing for Darwin probes. #320
- Fixed rendering bug resulting in orphaned nodes. #339
- App now only logs to stderr, to match the probe. #343
- Use relative paths for all URLs in the UI. #344
- Removed temporary containers created by the scope script. #348
Experimental features:
- Added support for pcap based packet sniffing, to provide bandwidth usage information. It can be enabled via the --capture flag. When enabled the probe will monitor packets for a portion of the time, and estimate bandwidth usage. Network throughput will be affected if capture is enabled. #317
New features:
- Aggregate all connection information into a single table in the details dialog. #298
- Renamed binaries to scope-app and scope-probe #293
- Group containers topology by name only, and not version #291
- Make intra-scope communication traverse the weave network if present. #71
Bug fixes:
- Reduced memory usage #266
New features:
- Include kernel version and uptime in host details. #274
- Include command line and number of threads in process details. #272
- Include Docker port mapping, entrypoint, memory usage and creation date in container details. #262
- Order tables in details panel from least granular to most granular. #261
- Show all container images (even ones without active connections) in the containers-by-image view. #230
- Produce process and container views by merging endpoint topology with their respective topologies, such that the origins in the details panel always aggregate correctly. #228
- In containers view, show "Uncontained" nodes for each host if they have active connections. #127
- Show connection status in the UI. #162
Bug fixes:
- Reduce CPU usage by caching walks of /proc. #284
- Trim whitespace of process names such that the details panel functions correctly in the process-by-name view. #281
- Correctly scope addresses on Docker bridge such that processes on different hosts are not incorrectly shown as communicating. #264
- Correctly show connections between nodes which traverse a Docker port mapping. #245
- Make scope script fail if docker run fails. #214
- Prevent left over nodes in the UI when the connection is dropped or Scope is restarted. #162
- Show containers, even when they aren't communicating.
- Expand topology selectors more descriptive, and remove the grouping button.
- Fix overflow rendering bugs in the detail pane.
- Render pseudonodes with less saturation.
- Initial release.