Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/willry/mongo-queue
Um gerenciador de filas com MongoDB, permitindo o uso de workers e número de tentativas de processamento em caso de erro
https://github.com/willry/mongo-queue
Last synced: about 1 month ago
JSON representation
Um gerenciador de filas com MongoDB, permitindo o uso de workers e número de tentativas de processamento em caso de erro
- Host: GitHub
- URL: https://github.com/willry/mongo-queue
- Owner: WillRy
- Created: 2022-04-30T00:06:14.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-09-13T03:44:37.000Z (over 2 years ago)
- Last Synced: 2024-10-17T10:31:01.338Z (3 months ago)
- Language: PHP
- Size: 40 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Mongo Queue
Uma biblioteca para criar filas e background jobs usando mongodb.
A biblioteca permite:
- Criação de multiplas filas
- Uso de vários workers (workers não pegam itens duplicados)
- Ao usar mongo como fila, ao invés do REDIS, é possível realizar pesquisas indexadas no payload dos itens da fila## Performance
Em testes realizados foi possível manter 600.000 itens na fila, com 9 workers processando com um delay de 2s no consumo,
com menos de 2.5% de CPU.## Utilização
A pasta **demo** contém demonstrações de como **publicar**, **consumir** e **excluir** itens velhos
### Publicar item na fila
```php
insert($i, [
'id' => $i,
"name" => "Fulano {$i}",
"description" => "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum semper ex in odio convallis, id dapibus ante ullamcorper. Nulla aliquet risus sapien, nec finibus mi pharetra ac. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas non sollicitudin lacus, sit amet volutpat sapien. Aliquam erat volutpat. Pellentesque suscipit venenatis rutrum.",
"email" => "fulano{$i}@teste.com"
], $requeue_on_error, $maxRetries);
}```
### Consumir item na fila
**Criar classe que processa o item na fila**
```php
ping();//fake error = Exceptions são detectadas e tratadas como nackError automaticamente
IF($parImpar) throw new Exception("Erro aleatório");$task->ack(); //marca como sucesso
/** marca como erro */
//$task->nackError();/** marca como cancelado */
// $task->nackCanceled();}
public function error($data = null, \Exception $error = null)
{}
}```
**Arquivo que consome a fila com a classe de worker**
```php
consume($worker);/** Consumir através de um loop (recomendado para supervisor e systemd) */
$mqueue->consumeLoop($worker, $delaySeconds);
```### Excluir item específico da fila
Excluir item da fila com base no ID
```php
deleteJobByCustomID(1);
```### Excluir item antigo na fila
Excluir itens processados em "N" dias atrás
```php
deleteJobByCustomID(1);
```### Usar conexão do mongo
```php
db;
```### Criar indices para pesquisa na fila
Para pesquisar itens na fila, com base em algum campo do payload, é possível criar um indice e em seguida usar o método
de pesquisa.**IMPORTANTE**
Deve criar os indices com base na ordem em que os campos são usados na pesquisa
```php
insert($i, [
'id' => $i,
"name" => "Fulano {$i}"
]);
}$page = filter_input(INPUT_GET, 'page', FILTER_SANITIZE_NUMBER_INT) ?? 1;
/** filtrar itens não processados que contenham o nome "fulano" no payload */
$filter = [
"startTime" => null,
"payload.name" => [
'$regex' => 'fulano', '$options' => 'i'
]
];
$mqueue->createIndex([
"startTime" => 1,
"payload.name" => 1
]);
$cursor = $mqueue->searchByPayload(
$page,
10,
$filter
);
$total = $mqueue->countByPayload($filter);$break = !empty($_SERVER["SERVER_NAME"]) ? "
" : PHP_EOL;print("Total: {$total}" . $break);
foreach ($cursor as $document) {
$data = $document->getArrayCopy();
print("ID: {$data["id"]}" . $break);
}
```## Configurar ambiente de produção
Em produção, o ideal é utilizar um supervisor para manter em execução
o processamento da fila com vários workers.### Instalar o supervisor
```shell
# instalar o supervisor
sudo apt-get install supervisor
```### Configurar arquivo do worker
Configurar em **/etc/supervisor/conf.d/mongo-worker.conf**
```text
[program:mongo-worker]
process_name=%(program_name)s_%(process_num)02d
command=php /var/www/consume.php
autostart=true
autorestart=true
stopasgroup=true
killasgroup=true
user=www-data
numprocs=2
redirect_stderr=true
stdout_logfile=/var/www/worker.log
stopwaitsecs=3600
```**command=** O caminho do script ou comando que vai fazer o consumo
**numprocs=** O número de workers
### Executar supervisor
```shell
sudo supervisorctl rereadsudo supervisorctl update
sudo supervisorctl start mongo-worker:*
```