Pular para o conteúdo principal

Docker e docker-compose

A instalação do A-Parser no Linux e MacOS via docker é o método recomendado, preparamos uma imagem que inclui todas as dependências e bibliotecas necessárias para o funcionamento do A-Parser e Headless Chrome

Antes da instalação

Antes da instalação, você deve registrar o IP na Área de Membros.

Docker

É necessário instalar o Docker em seu sistema.

Instalação e inicialização

Baixe e descompacte a distribuição do 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

O download ocorre através de um link de uso único para Linux. Você deve obtê-lo na Área de Membros, aba A-Parser -> Downloads

Inicie usando o comando:

docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 -t aparser/runtime ./aparser -foreground

A opção -foreground exibe o conteúdo do arquivo de log diretamente no 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

Após a inicialização, o A-Parser estará disponível no endereço http://127.0.0.1:9091

Para iniciar o contêiner em segundo plano, use o comando:

docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 -t -d aparser/runtime ./aparser

Ajuste do Linux para maior número de threads

Por padrão, dentro do contêiner também existe uma restrição no número de arquivos/sockets abertos. Para aumentar o limite para 10240 ao iniciar via Docker, use a opção --ulimit:

docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 --ulimit nofile=10240:10240 -t -d aparser/runtime ./aparser

Uma configuração análoga pode ser definida no 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, recomenda-se realizar o ajuste do Linux para maior número de threads no sistema hospedeiro.

Atualização do A-Parser

Pare o contêiner:

docker stop aparser

Atualize o A-Parser:

docker run --rm --name aparser -v $(pwd)/aparser:/app -p 9091:9091 -t aparser/runtime ./aparser -foreground -doupdate

Após a conclusão da atualização, inicie o A-Parser

nota

Você também pode utilizar a atualização pela interface ou por link de uso único

docker-compose

Baixe e descompacte a distribuição do A-Parser:

curl -O https://a-parser.com/members/onetime/ce42f308eaa577b5/aparser.tar.gz
tar zxf aparser.tar.gz
rm -f aparser.tar.gz

Crie o arquivo docker-compose.yml:

version: '3'

services:
a-parser:
image: aparser/runtime:latest
command: ./aparser
restart: always
volumes:
- ./aparser:/app
ports:
- 9091:9091

Inicie o A-Parser:

docker compose up -d

TODO: (next) #### Conexão HTTPS via Let's Encrypt