Commit 043fd84
fix: configure_logging uses named 'mcp' logger instead of root logger (#2527)
Previously configure_logging() called logging.basicConfig(), which adds a
RichHandler at INFO level to the **root** logger. This caused every library
(httpx, urllib3, openai, …) to emit INFO records through Rich → stderr. In
stdio MCP servers spawned by Node.js hosts (Claude Desktop, Cline, …) the
kernel's stderr SNDBUF (8 KB on macOS) fills under modest log volume, and
write(2) blocks the asyncio event loop, deadlocking the server.
Changes:
- configure_logging() now targets logging.getLogger("mcp") instead of the
root logger via basicConfig.
- Sets mcp_logger.propagate = False so records don't reach any root handlers.
- Made idempotent: skips setup if the mcp logger already has handlers,
allowing application code to configure logging before MCPServer.__init__.
- Default log level changed from "INFO" to "WARNING" to reduce noise from
MCP's own internals in production/stdio deployments.
- MCPServer.__init__ log_level parameter default also changed to "WARNING".
- Added regression tests in tests/issues/test_2527_fastmcp_logger_pollution.py.
Fixes #2527
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>1 parent 3d7b311 commit 043fd84
3 files changed
Lines changed: 116 additions & 10 deletions
File tree
- src/mcp/server/mcpserver
- utilities
- tests/issues
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
142 | 142 | | |
143 | 143 | | |
144 | 144 | | |
145 | | - | |
| 145 | + | |
146 | 146 | | |
147 | 147 | | |
148 | 148 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
| 20 | + | |
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
24 | 35 | | |
25 | | - | |
| 36 | + | |
26 | 37 | | |
27 | | - | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
28 | 44 | | |
29 | 45 | | |
30 | 46 | | |
31 | 47 | | |
32 | | - | |
| 48 | + | |
33 | 49 | | |
34 | | - | |
35 | | - | |
36 | | - | |
37 | | - | |
| 50 | + | |
38 | 51 | | |
39 | | - | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
0 commit comments