Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@LinkedIn Agent MCPSearch for software engineer jobs in San Francisco"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
LinkedIn Agent MCP
Through this LinkedIn Agent MCP, AI assistants like Claude can connect to your LinkedIn. Access profiles and companies, search for jobs and people, manage saved jobs, update job-search profile settings, and inspect analytics.
Attribution
This project was originally bootstrapped from Daniel Sticker's LinkedIn MCP work and has since been extended into a broader LinkedIn automation and job-search manager. Credit for the original foundation goes to Daniel Sticker and the original linkedin-mcp-server project.
Related MCP server: LinkedIn Custom MCP Server
Installation Methods
👁 uvx
👁 Docker
👁 Install DXT Extension
👁 Development
https://github.com/user-attachments/assets/eb84419a-6eaf-47bd-ac52-37bc59c83680
Usage Examples
Research the background of this candidate https://www.linkedin.com/in/ayushkumar-exl/Get this company profile for partnership discussions https://www.linkedin.com/company/inframs/Suggest improvements for my CV to target this job posting https://www.linkedin.com/jobs/view/4252026496What has Anthropic been posting about recently? https://www.linkedin.com/company/anthropicresearch/Features & Tool Status
Tool | Description | Status |
| Get profile info with explicit section selection (experience, education, interests, honors, languages, contact_info) | Working |
| Extract company information with explicit section selection (posts, jobs) | Working |
| Get recent posts from a company's LinkedIn feed | Working |
| Search for jobs with keywords and location filters | Working |
| Get detailed information about a specific job posting | Working |
| Search LinkedIn members by keywords, current company, past company, and location; supports `match_mode=auto | strict |
| Find people at a target company with optional past-company and title filters | Working |
| Save a LinkedIn job to the current account's queue | Working |
| List the current account's saved jobs with pagination metadata | Working |
| Update the logged-in profile headline with preview support | Working |
| Enable or disable Open To Work preferences with preview support | Working |
| Add new skills to the logged-in profile with preview support | Working |
| Best-effort featured-skill ordering flow | Experimental |
| Read LinkedIn's personalized job recommendations feed | Working |
| Close browser session and clean up resources | Working |
Breaking change: LinkedIn recently made some changes to prevent scraping. The newest version uses Patchright with persistent browser profiles instead of Playwright with session files. Old session.json files and LINKEDIN_COOKIE env vars are no longer supported. Run --login again to create a new profile + cookie file that can be mounted in docker. 02/2026
Structured Helper Fields
Some tools return additive structured fields alongside the existing raw text output.
search_jobskeepssections.search_resultsand also returnsjobs, a structured list withtitle,company,location,job_id, andurlwhen those values can be resolved from the current LinkedIn DOM.search_peopleandget_company_peoplereturn paginatedresultsarrays with normalizedPersonCardfields andfilters_applied/warningsmetadata.search_people.match_modecontrols whether the tool stays strict, broadens automatically, or runs a broad company/background search immediately.get_saved_jobsandget_job_recommendationsreturn paginatedjobsarrays with normalizedJobCardfields.Profile-write tools (
update_profile_headline,set_open_to_work,add_profile_skills,set_featured_skills) support preview-first flows viadry_runorconfirm=falseand return structured write envelopes with additivedata.get_my_post_analyticsreturns the standard read envelope and exposes parsed posts atdata.posts. Each post object includesauthor,url,text_preview,time_ago,reactions,comments,reposts, andimpressions.
🚀 uvx Setup (Recommended - Universal)
Prerequisites: Install uv and run uvx patchright install chromium to set up the browser.
Installation
Step 1: Create a session (first time only)
uvx linkedin-scraper-mcp --loginThis opens a browser for you to log in manually (5 minute timeout for 2FA, captcha, etc.). The browser profile is saved to ~/.linkedin-mcp/profile/.
Step 2: Client Configuration:
{
"mcpServers": {
"linkedin": {
"command": "uvx",
"args": ["linkedin-scraper-mcp"]
}
}
}Sessions may expire over time. If you encounter authentication issues, runuvx linkedin-scraper-mcp --login again
uvx Setup Help
Transport Modes:
Default (stdio): Standard communication for local MCP servers
Streamable HTTP: For web-based MCP server
If no transport is specified, the server defaults to
stdioAn interactive terminal without explicit transport shows a chooser prompt
CLI Options:
--login- Open browser to log in and save persistent profile--no-headless- Show browser window (useful for debugging scraping issues)--log-level {DEBUG,INFO,WARNING,ERROR}- Set logging level (default: WARNING)--transport {stdio,streamable-http}- Optional: force transport mode (default: stdio)--host HOST- HTTP server host (default: 127.0.0.1)--port PORT- HTTP server port (default: 8000)--path PATH- HTTP server path (default: /mcp)--logout- Clear stored LinkedIn browser profile--timeout MS- Browser timeout for page operations in milliseconds (default: 5000)--user-data-dir PATH- Path to persistent browser profile directory (default: ~/.linkedin-mcp/profile)--chrome-path PATH- Path to Chrome/Chromium executable (for custom browser installations)
Basic Usage Examples:
# Create a session interactively
uvx linkedin-scraper-mcp --login
# Run with debug logging
uvx linkedin-scraper-mcp --log-level DEBUGHTTP Mode Example (for web-based MCP clients):
uvx linkedin-scraper-mcp --transport streamable-http --host 127.0.0.1 --port 8080 --path /mcpRuntime server logs are emitted by FastMCP/Uvicorn.
Test with mcp inspector:
Install and run mcp inspector
bunx @modelcontextprotocol/inspectorClick pre-filled token url to open the inspector in your browser
Select
Streamable HTTPasTransport TypeSet
URLtohttp://localhost:8080/mcpConnect
Test tools
Installation issues:
Ensure you have uv installed:
curl -LsSf https://astral.sh/uv/install.sh | shCheck uv version:
uv --version(should be 0.4.0 or higher)
Session issues:
Browser profile is stored at
~/.linkedin-mcp/profile/Make sure you have only one active LinkedIn session at a time
Login issues:
LinkedIn may require a login confirmation in the LinkedIn mobile app for
--loginYou might get a captcha challenge if you logged in frequently. Run
uvx linkedin-scraper-mcp --loginwhich opens a browser where you can solve it manually.
Timeout issues:
If pages fail to load or elements aren't found, try increasing the timeout:
--timeout 10000Users on slow connections may need higher values (e.g., 15000-30000ms)
Can also set via environment variable:
TIMEOUT=10000
Custom Chrome path:
If Chrome is installed in a non-standard location, use
--chrome-path /path/to/chromeCan also set via environment variable:
CHROME_PATH=/path/to/chrome
🐳 Docker Setup
Prerequisites: Make sure you have Docker installed and running.
Authentication
Docker runs headless (no browser window), so you need to create a browser profile locally first and mount it into the container.
Step 1: Create profile using uvx (one-time setup)
uvx linkedin-scraper-mcp --loginThis opens a browser window where you log in manually (5 minute timeout for 2FA, captcha, etc.). The browser profile is saved to ~/.linkedin-mcp/profile/.
Step 2: Configure Claude Desktop with Docker
{
"mcpServers": {
"linkedin": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"-v", "~/.linkedin-mcp:/home/pwuser/.linkedin-mcp",
"iushv/linkedin-agent-mcp:latest"
]
}
}
}Sessions may expire over time. If you encounter authentication issues, runuvx linkedin-scraper-mcp --login again locally.
Why can't I run --login in Docker? Docker containers don't have a display server. Create a profile on your host using the uvx setup and mount it into Docker.
Docker Setup Help
Transport Modes:
Default (stdio): Standard communication for local MCP servers
Streamable HTTP: For a web-based MCP server
If no transport is specified, the server defaults to
stdioAn interactive terminal without explicit transport shows a chooser prompt
CLI Options:
--log-level {DEBUG,INFO,WARNING,ERROR}- Set logging level (default: WARNING)--transport {stdio,streamable-http}- Optional: force transport mode (default: stdio)--host HOST- HTTP server host (default: 127.0.0.1)--port PORT- HTTP server port (default: 8000)--path PATH- HTTP server path (default: /mcp)--logout- Clear stored LinkedIn browser profile--timeout MS- Browser timeout for page operations in milliseconds (default: 5000)--user-data-dir PATH- Path to persistent browser profile directory (default: ~/.linkedin-mcp/profile)--chrome-path PATH- Path to Chrome/Chromium executable (rarely needed in Docker)
--login and --no-headless are not available in Docker (no display server). Use the uvx setup to create profiles.
HTTP Mode Example (for web-based MCP clients):
docker run -it --rm \
-v ~/.linkedin-mcp:/home/pwuser/.linkedin-mcp \
-p 8080:8080 \
iushv/linkedin-agent-mcp:latest \
--transport streamable-http --host 0.0.0.0 --port 8080 --path /mcpRuntime server logs are emitted by FastMCP/Uvicorn.
Test with mcp inspector:
Install and run mcp inspector
bunx @modelcontextprotocol/inspectorClick pre-filled token url to open the inspector in your browser
Select
Streamable HTTPasTransport TypeSet
URLtohttp://localhost:8080/mcpConnect
Test tools
Docker issues:
Make sure Docker is installed
Check if Docker is running:
docker ps
Login issues:
Make sure you have only one active LinkedIn session at a time
LinkedIn may require a login confirmation in the LinkedIn mobile app for
--loginYou might get a captcha challenge if you logged in frequently. Run
uvx linkedin-scraper-mcp --loginwhich opens a browser where you can solve captchas manually. See the uvx setup for prerequisites.
Timeout issues:
If pages fail to load or elements aren't found, try increasing the timeout:
--timeout 10000Users on slow connections may need higher values (e.g., 15000-30000ms)
Can also set via environment variable:
TIMEOUT=10000
Custom Chrome path:
If Chrome is installed in a non-standard location, use
--chrome-path /path/to/chromeCan also set via environment variable:
CHROME_PATH=/path/to/chrome
📦 Claude Desktop (DXT Extension)
Prerequisites: Claude Desktop and Docker installed & running
One-click installation for Claude Desktop users:
Download the DXT extension
Double-click to install into Claude Desktop
Create a session:
uvx linkedin-scraper-mcp --login
Sessions may expire over time. If you encounter authentication issues, runuvx linkedin-scraper-mcp --login again.
DXT Extension Setup Help
First-time setup timeout:
Claude Desktop has a ~60 second connection timeout
If the Docker image isn't cached, the pull may exceed this timeout
Fix: Pre-pull the image before first use:
docker pull iushv/linkedin-agent-mcp:2.3.0Then restart Claude Desktop
Docker issues:
Make sure Docker is installed
Check if Docker is running:
docker ps
Login issues:
Make sure you have only one active LinkedIn session at a time
LinkedIn may require a login confirmation in the LinkedIn mobile app for
--loginYou might get a captcha challenge if you logged in frequently. Run
uvx linkedin-scraper-mcp --loginwhich opens a browser where you can solve captchas manually. See the uvx setup for prerequisites.
Timeout issues:
If pages fail to load or elements aren't found, try increasing the timeout:
--timeout 10000Users on slow connections may need higher values (e.g., 15000-30000ms)
Can also set via environment variable:
TIMEOUT=10000
🐍 Local Setup (Develop & Contribute)
Prerequisites: Git and uv installed
Installation
# 1. Clone repository
git clone https://github.com/iushv/linkedin-agent-mcp
cd linkedin-agent-mcp
# 2. Install UV package manager (if not already installed)
curl -LsSf https://astral.sh/uv/install.sh | sh
# 3. Install dependencies
uv sync
uv sync --group dev
# 4. Install Patchright browser
uv run patchright install chromium
# 5. Install pre-commit hooks
uv run pre-commit install
# 6. Create a session (first time only)
uv run -m linkedin_mcp_server --login
# 7. Start the server
uv run -m linkedin_mcp_serverLocal Setup Help
CLI Options:
--login- Open browser to log in and save persistent profile--no-headless- Show browser window (useful for debugging scraping issues)--log-level {DEBUG,INFO,WARNING,ERROR}- Set logging level (default: WARNING)--transport {stdio,streamable-http}- Optional: force transport mode (default: stdio)--host HOST- HTTP server host (default: 127.0.0.1)--port PORT- HTTP server port (default: 8000)--path PATH- HTTP server path (default: /mcp)--logout- Clear stored LinkedIn browser profile--timeout MS- Browser timeout for page operations in milliseconds (default: 5000)--status- Check if current session is valid and exit--user-data-dir PATH- Path to persistent browser profile directory (default: ~/.linkedin-mcp/profile)--slow-mo MS- Delay between browser actions in milliseconds (default: 0, useful for debugging)--user-agent STRING- Custom browser user agent--viewport WxH- Browser viewport size (default: 1280x720)--chrome-path PATH- Path to Chrome/Chromium executable (for custom browser installations)--help- Show help
Note: Most CLI options have environment variable equivalents. See
.env.examplefor details.
HTTP Mode Example (for web-based MCP clients):
uv run -m linkedin_mcp_server --transport streamable-http --host 127.0.0.1 --port 8000 --path /mcpLive smoke test:
uv run -m linkedin_mcp_server --transport streamable-http --host 127.0.0.1 --port 8080 --path /mcp
uv run python scripts/test_live_tools.py --url http://127.0.0.1:8080/mcpTarget specific tools, add pacing, or retry read_conversation after timeouts:
uv run python scripts/test_live_tools.py \
--url http://127.0.0.1:8080/mcp \
--read-only \
--tool get_conversations \
--tool read_conversation \
--read-sleep 3 \
--read-conversation-retries 2 \
--retry-backoff-seconds 8 \
--json-out output/live-smoke.jsonRun only the write dry-run tools:
uv run python scripts/test_live_tools.py \
--url http://127.0.0.1:8080/mcp \
--write-onlyRun a focused read_conversation check against a known thread id:
uv run python scripts/test_live_tools.py \
--url http://127.0.0.1:8080/mcp \
--focus-read-conversation \
--thread-id abc123Claude Desktop:
{
"mcpServers": {
"linkedin": {
"command": "uv",
"args": ["--directory", "/path/to/linkedin-agent-mcp", "run", "-m", "linkedin_mcp_server"]
}
}
}stdio is used by default for this config.
Login issues:
Make sure you have only one active LinkedIn session at a time
LinkedIn may require a login confirmation in the LinkedIn mobile app for
--loginYou might get a captcha challenge if you logged in frequently. The
--logincommand opens a browser where you can solve it manually.
Scraping issues:
Use
--no-headlessto see browser actions and debug scraping problemsAdd
--log-level DEBUGto see more detailed logging
Session issues:
Browser profile is stored at
~/.linkedin-mcp/profile/Use
--logoutto clear the profile and start fresh
Python/Patchright issues:
Check Python version:
python --version(should be 3.12+)Reinstall Patchright:
uv run patchright install chromiumReinstall dependencies:
uv sync --reinstall
Timeout issues:
If pages fail to load or elements aren't found, try increasing the timeout:
--timeout 10000Users on slow connections may need higher values (e.g., 15000-30000ms)
Can also set via environment variable:
TIMEOUT=10000
Custom Chrome path:
If Chrome is installed in a non-standard location, use
--chrome-path /path/to/chromeCan also set via environment variable:
CHROME_PATH=/path/to/chrome
Feel free to open an issue or PR!
Acknowledgements
Built with FastMCP and Patchright.
⚠️ Use in accordance with LinkedIn's Terms of Service. Web scraping may violate LinkedIn's terms. This tool is for personal use only.
License
This project is licensed under the Apache 2.0 license.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/iushv/linkedin-agent-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server
