Docker y docker-compose
La instalación de A-Parser en Linux y MacOS a través de docker es el método recomendado, hemos preparado una imagen que incluye todas las dependencias y librerías necesarias para el funcionamiento de A-Parser y Headless Chrome
Antes de la instalación
[Antes de la instalación, es necesario registrar la IP en el Área de clientes.]
Docker
Es necesario instalar Docker en su sistema.
Instalación y ejecución
Descargue y descomprima la distribución de A-Parser:
curl -O https://a-parser.com/members/onetime/ce42f308eaa577b5/aparser-linux-x64.tar.gz
tar zxf aparser-linux-x64.tar.gz
rm -f aparser-linux-x64.tar.gz
La descarga se realiza mediante un enlace de un solo uso para Linux. Debe obtenerlo en el Área de clientes, pestaña A-Parser -> Descargas
Inicie utilizando el comando:
docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 -t aparser/runtime ./aparser -foreground
La opción -foreground muestra el contenido del archivo de registro directamente en la terminal:
Apr 27 07:06:53.10427 [master] foreground mode
Apr 27 07:06:54.06409 [master] Found local Chromium: /app/dist/nodejs/node_modules/puppeteer/.local-chromium/linux-856583/chrome-linux/chrome
Apr 27 07:06:55.36487 [master] NodeJS console: [Rank::CMS] total loaded 1446 apps
Apr 27 07:07:19.01377 [master] Start ProxyChecker nocheck
Apr 27 07:07:19.24418 [master] Start ProxyChecker default
Apr 27 07:07:19.62635 [master] A-Parser v1.2.1176-linux-x64 started, tasks: 0 / 2, memory total: 1989 MB, available: 610 MB
Después del inicio, A-Parser estará disponible en la dirección http://127.0.0.1:9091
Para ejecutar el contenedor en segundo plano, use el comando:
docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 -t -d aparser/runtime ./aparser
Optimización de Linux para un mayor número de hilos
Por defecto, dentro del contenedor también se aplica una restricción sobre el número de archivos/sockets abiertos. Para aumentar el límite a 10240 al iniciar a través de Docker, use la opción --ulimit:
docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 --ulimit nofile=10240:10240 -t -d aparser/runtime ./aparser
Se puede establecer una configuración similar en docker-compose.yml:
services:
a-parser:
image: aparser/runtime:latest
command: ./aparser
restart: always
volumes:
- ./aparser:/app
ports:
- 9091:9091
ulimits:
nofile:
soft: 10240
hard: 10240
Adicionalmente, se recomienda realizar la optimización de Linux para un mayor número de hilos en el sistema host.
Actualización de A-Parser
Detenga el contenedor:
docker stop aparser
Actualice A-Parser:
docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 -t aparser/runtime ./aparser -foreground -doupdate
Al finalizar la actualización, inicie A-Parser
También puede realizar la actualización a través de la interfaz o mediante un enlace de un solo uso
docker-compose
Descargue y descomprima la distribución de A-Parser:
curl -O https://a-parser.com/members/onetime/ce42f308eaa577b5/aparser.tar.gz
tar zxf aparser.tar.gz
rm -f aparser.tar.gz
Cree el archivo docker-compose.yml:
version: '3'
services:
a-parser:
image: aparser/runtime:latest
command: ./aparser
restart: always
volumes:
- ./aparser:/app
ports:
- 9091:9091
Inicie A-Parser:
docker compose up -d
TODO: (next) #### Conexión HTTPS a través de Let's Encrypt