<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: GrahamduesCN</title>
    <description>The latest articles on DEV Community by GrahamduesCN (@grahamduescn).</description>
    <link>https://dev.to/grahamduescn</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3942059%2F16b8d70b-1569-46d1-81de-63c48f003715.jpg</url>
      <title>DEV Community: GrahamduesCN</title>
      <link>https://dev.to/grahamduescn</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/grahamduescn"/>
    <language>en</language>
    <item>
      <title>3 MCP servers I actually use daily (and how to set them up)</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Tue, 09 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-1eni</link>
      <guid>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-1eni</guid>
      <description>&lt;p&gt;Not a hype list. These are the three MCP servers I have running right now in Claude Desktop.&lt;/p&gt;

&lt;h2&gt;
  
  
  1. Filesystem
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-filesystem
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;I use this to let Claude read project files directly instead of me copy-pasting code. Configure it to point at your project root.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Read the auth module and explain how the token validation works."&lt;/p&gt;

&lt;h2&gt;
  
  
  2. GitHub
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-github
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Lets Claude check issues, read PRs, and browse repos. I use it for code reviews.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Check what changed in the last 3 PRs and summarize."&lt;/p&gt;

&lt;h2&gt;
  
  
  3. PostgreSQL
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Direct database access from Claude. I run queries without leaving the conversation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Show me users who signed up this week but haven't logged in."&lt;/p&gt;

&lt;h2&gt;
  
  
  Setup
&lt;/h2&gt;

&lt;p&gt;Each one takes 2 minutes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; &amp;lt;server&amp;gt;
&lt;span class="c"&gt;# Add to claude_desktop_config.json&lt;/span&gt;
&lt;span class="c"&gt;# Restart Claude Desktop&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Warning
&lt;/h2&gt;

&lt;p&gt;The filesystem server can read your entire disk if you configure it that way. Be careful with paths.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;All servers verified on npm. &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt; CLI to discover more.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>MCP in 2026: The numbers behind the ecosystem explosion</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Mon, 08 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-46nb</link>
      <guid>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-46nb</guid>
      <description>&lt;p&gt;I spent an afternoon digging through the MCP ecosystem numbers. Here is what I found.&lt;/p&gt;

&lt;h2&gt;
  
  
  The numbers
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;13,000+ MCP servers&lt;/strong&gt; on npm and GitHub (as of May 2026)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;97 million monthly SDK downloads&lt;/strong&gt; — that is 3x from 6 months ago&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;400% YoY growth&lt;/strong&gt; in new server registrations&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Anthropic official servers&lt;/strong&gt; reach 48,500 downloads/month for filesystem alone&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  What this means
&lt;/h2&gt;

&lt;p&gt;MCP is not just a protocol anymore. It is becoming the standard way to give AI models access to tools — databases, APIs, file systems, everything.&lt;/p&gt;

&lt;p&gt;But here is the gap: discovery. Finding the right MCP server is still painful. You search npm with guesswork or dig through folders on GitHub.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I built
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search database
mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Six commands. Five official servers in the registry. Real packages, verified on npm.&lt;/p&gt;

&lt;h2&gt;
  
  
  What is next
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Private registries for enterprise teams&lt;/li&gt;
&lt;li&gt;Community submissions (open an issue if you want your server added)&lt;/li&gt;
&lt;li&gt;CI/CD integration for auto-publishing MCP servers&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;GitHub: &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;GrahamduesCN/mcp-platform&lt;/a&gt;&lt;/p&gt;




&lt;p&gt;&lt;em&gt;June 09, 2026 — update on MCP ecosystem growth.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>How to build your first MCP server in 10 minutes</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Sun, 07 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-2bk2</link>
      <guid>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-2bk2</guid>
      <description>&lt;p&gt;I built my first MCP server last week and it was way simpler than I expected. Here is exactly how, no fluff.&lt;/p&gt;

&lt;h2&gt;
  
  
  Prerequisites
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Node.js 20+&lt;/li&gt;
&lt;li&gt;10 minutes&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Step 1: Scaffold
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx create-mcp-server my-first-server
&lt;span class="nb"&gt;cd &lt;/span&gt;my-first-server
npm &lt;span class="nb"&gt;install&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This generates a complete TypeScript project with one example tool.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 2: Add your tool
&lt;/h2&gt;

&lt;p&gt;Open &lt;code&gt;src/index.ts&lt;/code&gt;. Replace the hello tool with whatever you want:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="nx"&gt;server&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;setRequestHandler&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;CallToolRequestSchema&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="k"&gt;async &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;arguments&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;args&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;params&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

  &lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;current_time&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;content&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;text&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;text&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Date&lt;/span&gt;&lt;span class="p"&gt;().&lt;/span&gt;&lt;span class="nf"&gt;toISOString&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;}]&lt;/span&gt;
    &lt;span class="p"&gt;};&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;

  &lt;span class="k"&gt;throw&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Error&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s2"&gt;`Unknown tool: &lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Step 3: Build and connect
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm run build
npm start
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Add to Claude Desktop config and you are done.&lt;/p&gt;

&lt;p&gt;The whole thing took me 8 minutes. Most of that was reading the docs.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I learned
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;The MCP SDK handles all the transport layer — you just define tools&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;StdioServerTransport&lt;/code&gt; means your server runs as a subprocess. No HTTP, no port conflicts&lt;/li&gt;
&lt;li&gt;Error handling is important. If your tool crashes, the whole MCP connection breaks&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Want to try it?
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search mcp
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;p&gt;&lt;em&gt;Built with &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt;. If this helps, &lt;a href="https://paypal.me/GrahamduesCN" rel="noopener noreferrer"&gt;buy me a coffee&lt;/a&gt;.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>3 MCP servers I actually use daily (and how to set them up)</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Sat, 06 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-3hkf</link>
      <guid>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-3hkf</guid>
      <description>&lt;p&gt;Not a hype list. These are the three MCP servers I have running right now in Claude Desktop.&lt;/p&gt;

&lt;h2&gt;
  
  
  1. Filesystem
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-filesystem
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;I use this to let Claude read project files directly instead of me copy-pasting code. Configure it to point at your project root.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Read the auth module and explain how the token validation works."&lt;/p&gt;

&lt;h2&gt;
  
  
  2. GitHub
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-github
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Lets Claude check issues, read PRs, and browse repos. I use it for code reviews.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Check what changed in the last 3 PRs and summarize."&lt;/p&gt;

&lt;h2&gt;
  
  
  3. PostgreSQL
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Direct database access from Claude. I run queries without leaving the conversation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Show me users who signed up this week but haven't logged in."&lt;/p&gt;

&lt;h2&gt;
  
  
  Setup
&lt;/h2&gt;

&lt;p&gt;Each one takes 2 minutes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight console"&gt;&lt;code&gt;&lt;span class="gp"&gt;mcp-hub install &amp;lt;server&amp;gt;&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="gp"&gt;#&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;Add to claude_desktop_config.json
&lt;span class="gp"&gt;#&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;Restart Claude Desktop
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Warning
&lt;/h2&gt;

&lt;p&gt;The filesystem server can read your entire disk if you configure it that way. Be careful with paths.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;All servers verified on npm. &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt; CLI to discover more.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>MCP in 2026: The numbers behind the ecosystem explosion</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Fri, 05 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-7oc</link>
      <guid>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-7oc</guid>
      <description>&lt;p&gt;I spent an afternoon digging through the MCP ecosystem numbers. Here is what I found.&lt;/p&gt;

&lt;h2&gt;
  
  
  The numbers
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;13,000+ MCP servers&lt;/strong&gt; on npm and GitHub (as of May 2026)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;97 million monthly SDK downloads&lt;/strong&gt; — that is 3x from 6 months ago&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;400% YoY growth&lt;/strong&gt; in new server registrations&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Anthropic official servers&lt;/strong&gt; reach 48,500 downloads/month for filesystem alone&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  What this means
&lt;/h2&gt;

&lt;p&gt;MCP is not just a protocol anymore. It is becoming the standard way to give AI models access to tools — databases, APIs, file systems, everything.&lt;/p&gt;

&lt;p&gt;But here is the gap: discovery. Finding the right MCP server is still painful. You search npm with guesswork or dig through folders on GitHub.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I built
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search database
mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Six commands. Five official servers in the registry. Real packages, verified on npm.&lt;/p&gt;

&lt;h2&gt;
  
  
  What is next
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Private registries for enterprise teams&lt;/li&gt;
&lt;li&gt;Community submissions (open an issue if you want your server added)&lt;/li&gt;
&lt;li&gt;CI/CD integration for auto-publishing MCP servers&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;GitHub: &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;GrahamduesCN/mcp-platform&lt;/a&gt;&lt;/p&gt;




&lt;p&gt;&lt;em&gt;June 06, 2026 — update on MCP ecosystem growth.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>How to build your first MCP server in 10 minutes</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Thu, 04 Jun 2026 18:00:02 +0000</pubDate>
      <link>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-iof</link>
      <guid>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-iof</guid>
      <description>&lt;p&gt;I built my first MCP server last week and it was way simpler than I expected. Here is exactly how, no fluff.&lt;/p&gt;

&lt;h2&gt;
  
  
  Prerequisites
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Node.js 20+&lt;/li&gt;
&lt;li&gt;10 minutes&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Step 1: Scaffold
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx create-mcp-server my-first-server
&lt;span class="nb"&gt;cd &lt;/span&gt;my-first-server
npm &lt;span class="nb"&gt;install&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This generates a complete TypeScript project with one example tool.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 2: Add your tool
&lt;/h2&gt;

&lt;p&gt;Open &lt;code&gt;src/index.ts&lt;/code&gt;. Replace the hello tool with whatever you want:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="nx"&gt;server&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;setRequestHandler&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;CallToolRequestSchema&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="k"&gt;async &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;arguments&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;args&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;params&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

  &lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;current_time&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;content&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;text&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;text&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Date&lt;/span&gt;&lt;span class="p"&gt;().&lt;/span&gt;&lt;span class="nf"&gt;toISOString&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;}]&lt;/span&gt;
    &lt;span class="p"&gt;};&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;

  &lt;span class="k"&gt;throw&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Error&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s2"&gt;`Unknown tool: &lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Step 3: Build and connect
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm run build
npm start
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Add to Claude Desktop config and you are done.&lt;/p&gt;

&lt;p&gt;The whole thing took me 8 minutes. Most of that was reading the docs.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I learned
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;The MCP SDK handles all the transport layer — you just define tools&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;StdioServerTransport&lt;/code&gt; means your server runs as a subprocess. No HTTP, no port conflicts&lt;/li&gt;
&lt;li&gt;Error handling is important. If your tool crashes, the whole MCP connection breaks&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Want to try it?
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search mcp
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;p&gt;&lt;em&gt;Built with &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt;. If this helps, &lt;a href="https://paypal.me/GrahamduesCN" rel="noopener noreferrer"&gt;buy me a coffee&lt;/a&gt;.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>3 MCP servers I actually use daily (and how to set them up)</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Wed, 03 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-3lam</link>
      <guid>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-3lam</guid>
      <description>&lt;p&gt;Not a hype list. These are the three MCP servers I have running right now in Claude Desktop.&lt;/p&gt;

&lt;h2&gt;
  
  
  1. Filesystem
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-filesystem
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;I use this to let Claude read project files directly instead of me copy-pasting code. Configure it to point at your project root.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Read the auth module and explain how the token validation works."&lt;/p&gt;

&lt;h2&gt;
  
  
  2. GitHub
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-github
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Lets Claude check issues, read PRs, and browse repos. I use it for code reviews.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Check what changed in the last 3 PRs and summarize."&lt;/p&gt;

&lt;h2&gt;
  
  
  3. PostgreSQL
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Direct database access from Claude. I run queries without leaving the conversation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Show me users who signed up this week but haven't logged in."&lt;/p&gt;

&lt;h2&gt;
  
  
  Setup
&lt;/h2&gt;

&lt;p&gt;Each one takes 2 minutes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; &amp;lt;server&amp;gt;
&lt;span class="c"&gt;# Add to claude_desktop_config.json&lt;/span&gt;
&lt;span class="c"&gt;# Restart Claude Desktop&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Warning
&lt;/h2&gt;

&lt;p&gt;The filesystem server can read your entire disk if you configure it that way. Be careful with paths.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;All servers verified on npm. &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt; CLI to discover more.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>MCP in 2026: The numbers behind the ecosystem explosion</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Tue, 02 Jun 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-4fkj</link>
      <guid>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-4fkj</guid>
      <description>&lt;p&gt;I spent an afternoon digging through the MCP ecosystem numbers. Here is what I found.&lt;/p&gt;

&lt;h2&gt;
  
  
  The numbers
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;13,000+ MCP servers&lt;/strong&gt; on npm and GitHub (as of May 2026)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;97 million monthly SDK downloads&lt;/strong&gt; — that is 3x from 6 months ago&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;400% YoY growth&lt;/strong&gt; in new server registrations&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Anthropic official servers&lt;/strong&gt; reach 48,500 downloads/month for filesystem alone&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  What this means
&lt;/h2&gt;

&lt;p&gt;MCP is not just a protocol anymore. It is becoming the standard way to give AI models access to tools — databases, APIs, file systems, everything.&lt;/p&gt;

&lt;p&gt;But here is the gap: discovery. Finding the right MCP server is still painful. You search npm with guesswork or dig through folders on GitHub.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I built
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search database
mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Six commands. Five official servers in the registry. Real packages, verified on npm.&lt;/p&gt;

&lt;h2&gt;
  
  
  What is next
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Private registries for enterprise teams&lt;/li&gt;
&lt;li&gt;Community submissions (open an issue if you want your server added)&lt;/li&gt;
&lt;li&gt;CI/CD integration for auto-publishing MCP servers&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;GitHub: &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;GrahamduesCN/mcp-platform&lt;/a&gt;&lt;/p&gt;




&lt;p&gt;&lt;em&gt;June 03, 2026 — update on MCP ecosystem growth.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>How to build your first MCP server in 10 minutes</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Mon, 01 Jun 2026 18:00:04 +0000</pubDate>
      <link>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-48i5</link>
      <guid>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-48i5</guid>
      <description>&lt;p&gt;I built my first MCP server last week and it was way simpler than I expected. Here is exactly how, no fluff.&lt;/p&gt;

&lt;h2&gt;
  
  
  Prerequisites
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Node.js 20+&lt;/li&gt;
&lt;li&gt;10 minutes&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Step 1: Scaffold
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx create-mcp-server my-first-server
&lt;span class="nb"&gt;cd &lt;/span&gt;my-first-server
npm &lt;span class="nb"&gt;install&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This generates a complete TypeScript project with one example tool.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 2: Add your tool
&lt;/h2&gt;

&lt;p&gt;Open &lt;code&gt;src/index.ts&lt;/code&gt;. Replace the hello tool with whatever you want:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="nx"&gt;server&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;setRequestHandler&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;CallToolRequestSchema&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="k"&gt;async &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;arguments&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;args&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;params&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

  &lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;current_time&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;content&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;text&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;text&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Date&lt;/span&gt;&lt;span class="p"&gt;().&lt;/span&gt;&lt;span class="nf"&gt;toISOString&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;}]&lt;/span&gt;
    &lt;span class="p"&gt;};&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;

  &lt;span class="k"&gt;throw&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Error&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s2"&gt;`Unknown tool: &lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Step 3: Build and connect
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm run build
npm start
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Add to Claude Desktop config and you are done.&lt;/p&gt;

&lt;p&gt;The whole thing took me 8 minutes. Most of that was reading the docs.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I learned
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;The MCP SDK handles all the transport layer — you just define tools&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;StdioServerTransport&lt;/code&gt; means your server runs as a subprocess. No HTTP, no port conflicts&lt;/li&gt;
&lt;li&gt;Error handling is important. If your tool crashes, the whole MCP connection breaks&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Want to try it?
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search mcp
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;p&gt;&lt;em&gt;Built with &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt;. If this helps, &lt;a href="https://paypal.me/GrahamduesCN" rel="noopener noreferrer"&gt;buy me a coffee&lt;/a&gt;.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>3 MCP servers I actually use daily (and how to set them up)</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Sun, 31 May 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-2h59</link>
      <guid>https://dev.to/grahamduescn/3-mcp-servers-i-actually-use-daily-and-how-to-set-them-up-2h59</guid>
      <description>&lt;p&gt;Not a hype list. These are the three MCP servers I have running right now in Claude Desktop.&lt;/p&gt;

&lt;h2&gt;
  
  
  1. Filesystem
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-filesystem
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;I use this to let Claude read project files directly instead of me copy-pasting code. Configure it to point at your project root.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Read the auth module and explain how the token validation works."&lt;/p&gt;

&lt;h2&gt;
  
  
  2. GitHub
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-github
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Lets Claude check issues, read PRs, and browse repos. I use it for code reviews.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Check what changed in the last 3 PRs and summarize."&lt;/p&gt;

&lt;h2&gt;
  
  
  3. PostgreSQL
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Direct database access from Claude. I run queries without leaving the conversation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Real usage&lt;/strong&gt;: "Show me users who signed up this week but haven't logged in."&lt;/p&gt;

&lt;h2&gt;
  
  
  Setup
&lt;/h2&gt;

&lt;p&gt;Each one takes 2 minutes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; &amp;lt;server&amp;gt;
&lt;span class="c"&gt;# Add to claude_desktop_config.json&lt;/span&gt;
&lt;span class="c"&gt;# Restart Claude Desktop&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Warning
&lt;/h2&gt;

&lt;p&gt;The filesystem server can read your entire disk if you configure it that way. Be careful with paths.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;All servers verified on npm. &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt; CLI to discover more.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>MCP in 2026: The numbers behind the ecosystem explosion</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Sat, 30 May 2026 18:00:03 +0000</pubDate>
      <link>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-3j72</link>
      <guid>https://dev.to/grahamduescn/mcp-in-2026-the-numbers-behind-the-ecosystem-explosion-3j72</guid>
      <description>&lt;p&gt;I spent an afternoon digging through the MCP ecosystem numbers. Here is what I found.&lt;/p&gt;

&lt;h2&gt;
  
  
  The numbers
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;13,000+ MCP servers&lt;/strong&gt; on npm and GitHub (as of May 2026)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;97 million monthly SDK downloads&lt;/strong&gt; — that is 3x from 6 months ago&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;400% YoY growth&lt;/strong&gt; in new server registrations&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Anthropic official servers&lt;/strong&gt; reach 48,500 downloads/month for filesystem alone&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  What this means
&lt;/h2&gt;

&lt;p&gt;MCP is not just a protocol anymore. It is becoming the standard way to give AI models access to tools — databases, APIs, file systems, everything.&lt;/p&gt;

&lt;p&gt;But here is the gap: discovery. Finding the right MCP server is still painful. You search npm with guesswork or dig through folders on GitHub.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I built
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search database
mcp-hub &lt;span class="nb"&gt;install&lt;/span&gt; @modelcontextprotocol/server-postgres
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Six commands. Five official servers in the registry. Real packages, verified on npm.&lt;/p&gt;

&lt;h2&gt;
  
  
  What is next
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Private registries for enterprise teams&lt;/li&gt;
&lt;li&gt;Community submissions (open an issue if you want your server added)&lt;/li&gt;
&lt;li&gt;CI/CD integration for auto-publishing MCP servers&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;GitHub: &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;GrahamduesCN/mcp-platform&lt;/a&gt;&lt;/p&gt;




&lt;p&gt;&lt;em&gt;May 31, 2026 — update on MCP ecosystem growth.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>How to build your first MCP server in 10 minutes</title>
      <dc:creator>GrahamduesCN</dc:creator>
      <pubDate>Fri, 29 May 2026 18:00:02 +0000</pubDate>
      <link>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-1koc</link>
      <guid>https://dev.to/grahamduescn/how-to-build-your-first-mcp-server-in-10-minutes-1koc</guid>
      <description>&lt;p&gt;I built my first MCP server last week and it was way simpler than I expected. Here is exactly how, no fluff.&lt;/p&gt;

&lt;h2&gt;
  
  
  Prerequisites
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Node.js 20+&lt;/li&gt;
&lt;li&gt;10 minutes&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Step 1: Scaffold
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx create-mcp-server my-first-server
&lt;span class="nb"&gt;cd &lt;/span&gt;my-first-server
npm &lt;span class="nb"&gt;install&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This generates a complete TypeScript project with one example tool.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 2: Add your tool
&lt;/h2&gt;

&lt;p&gt;Open &lt;code&gt;src/index.ts&lt;/code&gt;. Replace the hello tool with whatever you want:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="nx"&gt;server&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;setRequestHandler&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;CallToolRequestSchema&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="k"&gt;async &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;arguments&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;args&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;request&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;params&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

  &lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;current_time&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;content&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;text&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;text&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Date&lt;/span&gt;&lt;span class="p"&gt;().&lt;/span&gt;&lt;span class="nf"&gt;toISOString&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;}]&lt;/span&gt;
    &lt;span class="p"&gt;};&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;

  &lt;span class="k"&gt;throw&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Error&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s2"&gt;`Unknown tool: &lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Step 3: Build and connect
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm run build
npm start
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Add to Claude Desktop config and you are done.&lt;/p&gt;

&lt;p&gt;The whole thing took me 8 minutes. Most of that was reading the docs.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I learned
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;The MCP SDK handles all the transport layer — you just define tools&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;StdioServerTransport&lt;/code&gt; means your server runs as a subprocess. No HTTP, no port conflicts&lt;/li&gt;
&lt;li&gt;Error handling is important. If your tool crashes, the whole MCP connection breaks&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Want to try it?
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; mcp-hub
mcp-hub search mcp
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;p&gt;&lt;em&gt;Built with &lt;a href="https://github.com/GrahamduesCN/mcp-platform" rel="noopener noreferrer"&gt;mcp-hub&lt;/a&gt;. If this helps, &lt;a href="https://paypal.me/GrahamduesCN" rel="noopener noreferrer"&gt;buy me a coffee&lt;/a&gt;.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>mcp</category>
      <category>cli</category>
      <category>typescript</category>
      <category>tutorial</category>
    </item>
  </channel>
</rss>
