返回技能列表

deploy-searxng

pjt222
更新于 2 days ago
7 次查看
17
2
17
在 GitHub 上查看
文档general

关于

This skill deploys a self-hosted SearXNG instance using Docker Compose with an Nginx reverse proxy and custom search engine configuration. It focuses on privacy, performance, and interface customization for a private, aggregated search experience without tracking. Use it when you need a self-hosted alternative to commercial search engines.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/deploy-searxng

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档


name: deploy-searxng locale: es source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16 description: > Desplegar una instancia auto-alojada de SearXNG con Docker Compose, proxy inverso Nginx, y configuración personalizada de motores de búsqueda. Cubrir seguridad, rendimiento, y personalización de la interfaz. Usar cuando se necesite un metabuscador privado, búsqueda agregada sin rastreo, o una alternativa auto-alojada a buscadores comerciales. license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: containerization complexity: intermediate language: multi tags: searxng, search-engine, self-hosted, docker, privacy

Desplegar SearXNG

Desplegar un metabuscador SearXNG auto-alojado con Docker y configuración personalizada.

Cuándo Usar

  • Necesitando un metabuscador privado sin rastreo
  • Queriendo agregar resultados de múltiples motores de búsqueda
  • Desplegando una alternativa auto-alojada a buscadores comerciales
  • Requiriendo búsqueda personalizable para un equipo u organización
  • Integrando búsqueda privada con otras herramientas (MCP, API)

Entradas

  • Requerido: Servidor con Docker y Docker Compose instalados
  • Requerido: Nombre de dominio (para acceso externo) o acceso localhost
  • Opcional: Certificados TLS para HTTPS
  • Opcional: Configuración de motores de búsqueda preferidos
  • Opcional: Personalización de interfaz (tema, idioma)

Procedimiento

Paso 1: Configurar Estructura del Proyecto

mkdir -p searxng/{config,data}
cd searxng

Crear docker-compose.yml:

version: '3.8'

services:
  searxng:
    image: searxng/searxng:latest
    container_name: searxng
    ports:
      - "8080:8080"
    volumes:
      - ./config:/etc/searxng:rw
      - ./data:/var/log/searxng:rw
    environment:
      - SEARXNG_BASE_URL=https://busqueda.ejemplo.com/
      - SEARXNG_SECRET_KEY=clave_secreta_larga_y_aleatoria
    cap_drop:
      - ALL
    cap_add:
      - CHOWN
      - SETGID
      - SETUID
    restart: unless-stopped

Esperado: Estructura de directorios creada, docker-compose.yml configurado.

En caso de fallo: Verificar permisos de escritura en los directorios, asegurar que Docker está instalado.

Paso 2: Configurar SearXNG

Crear config/settings.yml:

use_default_settings: true

general:
  debug: false
  instance_name: "Mi Buscador"

search:
  safe_search: 0
  autocomplete: "google"
  default_lang: "es"

server:
  secret_key: "clave_secreta_larga_y_aleatoria"
  bind_address: "0.0.0.0"
  port: 8080
  limiter: true

ui:
  default_theme: simple
  default_locale: es
  query_in_title: true

engines:
  - name: google
    engine: google
    shortcut: g
    disabled: false

  - name: duckduckgo
    engine: duckduckgo
    shortcut: ddg
    disabled: false

  - name: wikipedia
    engine: wikipedia
    shortcut: wp
    disabled: false

Esperado: SearXNG configurado con motores de búsqueda, idioma predeterminado, y seguridad.

En caso de fallo: Validar sintaxis YAML, verificar que el secret_key es único y largo.

Paso 3: Configurar Proxy Inverso (Opcional)

Para acceso externo con HTTPS, configurar Nginx:

server {
    listen 443 ssl http2;
    server_name busqueda.ejemplo.com;

    ssl_certificate /etc/ssl/certs/cert.pem;
    ssl_certificate_key /etc/ssl/private/key.pem;

    location / {
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;

        # Limitar acceso (opcional)
        # allow 192.168.0.0/16;
        # deny all;
    }
}

Esperado: SearXNG accesible vía HTTPS a través de Nginx.

En caso de fallo: Verificar certificados TLS, comprobar que Nginx puede resolver el upstream.

Paso 4: Iniciar y Verificar

# Iniciar SearXNG
docker compose up -d

# Verificar estado
docker compose ps
docker compose logs searxng

# Probar búsqueda
curl "http://localhost:8080/search?q=test&format=json"

Esperado: SearXNG ejecutándose y respondiendo a consultas de búsqueda.

En caso de fallo: Revisar logs del contenedor, verificar configuración de motores de búsqueda, comprobar conectividad de red.

Validación

  • SearXNG se inicia sin errores
  • La interfaz web es accesible y funcional
  • Las búsquedas devuelven resultados de múltiples motores
  • El idioma predeterminado es el configurado
  • Las capacidades de seguridad están limitadas (cap_drop: ALL)
  • HTTPS funciona a través del proxy inverso (si está configurado)

Errores Comunes

  • Secret key débil o predeterminada: Usar una clave aleatoria larga. SearXNG rechaza claves débiles.
  • Rate limiting de motores: Los motores de búsqueda pueden bloquear IPs con muchas solicitudes. Habilitar el limiter integrado.
  • Motores deshabilitados silenciosamente: Algunos motores requieren configuración adicional. Verificar en la página de preferencias.
  • Permisos de directorio: Los directorios montados deben ser escribibles por el usuario del contenedor.
  • Base URL incorrecta: Debe coincidir exactamente con la URL de acceso, incluyendo el protocolo y la barra final.

Habilidades Relacionadas

  • configure-nginx - Configuración detallada de Nginx como proxy
  • configure-reverse-proxy - Patrones de proxy inverso con Traefik
  • setup-compose-stack - Stacks Docker Compose multi-servicio

GitHub 仓库

pjt222/agent-almanac
路径: i18n/es/skills/deploy-searxng
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

railway-docs

文档

Railway Docs Skill可实时获取最新的Railway官方文档,确保回答的准确性。当开发者询问Railway功能特性、工作原理或分享docs.railway.com链接时,应优先使用此技能。它通过专门的LLM优化文档源提供最新信息,避免依赖过时记忆来回答技术问题。

查看技能

n8n-code-python

文档

该Skill为在n8n平台的Python代码节点中编写代码提供专家指导,特别适用于需要使用_input/_json/_node语法、Python标准库或了解n8n中Python限制的场景。它强调JavaScript应作为首选方案,仅当需要特定Python功能或对Python语法更熟悉时才使用Python。Skill提供了快速入门模板和关键注意事项,帮助开发者在n8n中高效编写Python代码。

查看技能

archon

文档

Archon Skill为开发者提供了基于RAG的语义搜索和项目任务管理功能,可通过REST API访问知识库。它支持文档搜索、网站爬取、文件上传和版本控制,适用于技术文档查询和项目管理场景。首次使用时需要配置Archon主机地址,建议在处理外部文档时优先使用该Skill。

查看技能

n8n-code-javascript

文档

这个Skill为n8n工作流中的JavaScript代码节点提供专业指导,涵盖数据处理、HTTP请求和日期操作等核心场景。它详细解释了如何正确使用n8n特有的`$input`/`$json`语法、`$helpers`工具以及DateTime对象,并包含关键的错误排查和模式选择建议。开发者通过该Skill能快速掌握Code节点的正确返回格式、数据访问方法和常见陷阱解决方案。

查看技能