mirror of
https://github.com/ipfs/kubo.git
synced 2026-02-21 10:27:46 +08:00
feat: disable resource manager by default (#9003)
* feat: disable resource manager by default
We are disabling this by default for v0.13 as we work to improve the
UX around Resource Manager. It is still usable and can be enabled in
the IPFS config with "ipfs config --bool Swarm.ResourceMgr.Enabled true".
We intend to enable Resource Manager by default in a subsequent
release.
* docs(config): Swarm.ResourceMgr disabled by default
Co-authored-by: Marcin Rataj <lidel@lidel.org>
(cherry picked from commit b1c051d250)
This commit is contained in:
parent
87fca8f225
commit
0fe75d63ea
@ -74,16 +74,19 @@ To understand the wider context why we made these changes, read *Highlights* bel
|
||||
|
||||
*You can now easily bound how much resource usage libp2p consumes! This aids in protecting nodes from consuming more resources then are available to them.*
|
||||
|
||||
The [libp2p Network Resource Manager](https://github.com/libp2p/go-libp2p-resource-manager#readme) is enabled by default, but can be disabled via:
|
||||
The [libp2p Network Resource Manager](https://github.com/libp2p/go-libp2p-resource-manager#readme) is disabled by default, but can be enabled via:
|
||||
|
||||
`ipfs config --json Swarm.ResourceMgr.Enabled false`
|
||||
`ipfs config --json Swarm.ResourceMgr.Enabled true`
|
||||
|
||||
When enabled, it applies some safe defaults that can be inspected and adjusted with:
|
||||
|
||||
- `ipfs swarm stats --help`
|
||||
- `ipfs swarm limit --help`
|
||||
|
||||
User changes persist to config at [`Swarm.ResourceMgr`](https://github.com/ipfs/go-ipfs/blob/master/docs/config.md#swarmresourcemgr).
|
||||
|
||||
The Resource Manager will be enabled by default in a future release.
|
||||
|
||||
#### 🔃 Relay V2 client with auto discovery (`Swarm.RelayClient`)
|
||||
|
||||
*All the pieces are enabled for [hole-punching](https://blog.ipfs.io/2022-01-20-libp2p-hole-punching/) by default, improving connecting with nodes behind NATs and Firewalls!*
|
||||
|
||||
@ -31,7 +31,7 @@ func ResourceManager(cfg config.SwarmConfig) interface{} {
|
||||
var manager network.ResourceManager
|
||||
var opts Libp2pOpts
|
||||
|
||||
enabled := cfg.ResourceMgr.Enabled.WithDefault(true)
|
||||
enabled := cfg.ResourceMgr.Enabled.WithDefault(false)
|
||||
|
||||
/// ENV overrides Config (if present)
|
||||
switch os.Getenv("LIBP2P_RCMGR") {
|
||||
|
||||
@ -1637,7 +1637,7 @@ and tracking recource usage over time.
|
||||
Enables the libp2p Network Resource Manager and auguments the default limits
|
||||
using user-defined ones in `Swarm.ResourceMgr.Limits` (if present).
|
||||
|
||||
Default: `true`
|
||||
Default: `false`
|
||||
|
||||
Type: `flag`
|
||||
|
||||
|
||||
@ -656,10 +656,6 @@ leveldb_datastore_sync_latency_seconds_bucket
|
||||
leveldb_datastore_sync_latency_seconds_count
|
||||
leveldb_datastore_sync_latency_seconds_sum
|
||||
leveldb_datastore_sync_total
|
||||
libp2p_rcmgr_memory_allocations_allowed_total
|
||||
libp2p_rcmgr_memory_allocations_blocked_total
|
||||
libp2p_rcmgr_peer_blocked_total
|
||||
libp2p_rcmgr_peers_allowed_total
|
||||
process_cpu_seconds_total
|
||||
process_max_fds
|
||||
process_open_fds
|
||||
|
||||
@ -6,6 +6,25 @@ test_description="Test ipfs swarm ResourceMgr config and commands"
|
||||
|
||||
test_init_ipfs
|
||||
|
||||
# test correct behavior when resource manager is disabled (default behavior)
|
||||
test_launch_ipfs_daemon
|
||||
|
||||
test_expect_success 'Swarm limit should fail since RM is disabled' '
|
||||
test_expect_code 1 ipfs swarm limit system 2> actual &&
|
||||
test_should_contain "missing ResourceMgr" actual
|
||||
'
|
||||
|
||||
test_expect_success 'Swarm stats should fail since RM is disabled' '
|
||||
test_expect_code 1 ipfs swarm stats all 2> actual &&
|
||||
test_should_contain "missing ResourceMgr" actual
|
||||
'
|
||||
|
||||
test_kill_ipfs_daemon
|
||||
|
||||
test_expect_success 'Enable resource manager' '
|
||||
ipfs config --bool Swarm.ResourceMgr.Enabled true
|
||||
'
|
||||
|
||||
# swarm limit|stats should fail in offline mode
|
||||
|
||||
test_expect_success 'disconnected: swarm limit requires running daemon' '
|
||||
@ -127,23 +146,4 @@ test_expect_success 'Set limit for peer scope with an invalid peer ID' '
|
||||
|
||||
test_kill_ipfs_daemon
|
||||
|
||||
# test correct behavior when resource manager is disabled
|
||||
test_expect_success 'Disable resource manager' '
|
||||
ipfs config --bool Swarm.ResourceMgr.Enabled false
|
||||
'
|
||||
|
||||
test_launch_ipfs_daemon
|
||||
|
||||
test_expect_success 'Swarm limit should fail since RM is disabled' '
|
||||
test_expect_code 1 ipfs swarm limit system 2> actual &&
|
||||
test_should_contain "missing ResourceMgr" actual
|
||||
'
|
||||
|
||||
test_expect_success 'Swarm stats should fail since RM is disabled' '
|
||||
test_expect_code 1 ipfs swarm stats all 2> actual &&
|
||||
test_should_contain "missing ResourceMgr" actual
|
||||
'
|
||||
|
||||
test_kill_ipfs_daemon
|
||||
|
||||
test_done
|
||||
|
||||
Loading…
Reference in New Issue
Block a user