Ir al contenido principal

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
nota

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

nota

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