Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

README_pt_br.md 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388
  1. <div align="center">
  2. <a href="https://demo.ragflow.io/">
  3. <img src="web/src/assets/logo-with-text.png" width="520" alt="ragflow logo">
  4. </a>
  5. </div>
  6. <p align="center">
  7. <a href="./README.md"><img alt="README in English" src="https://img.shields.io/badge/English-DFE0E5"></a>
  8. <a href="./README_zh.md"><img alt="简体中文版自述文件" src="https://img.shields.io/badge/简体中文-DFE0E5"></a>
  9. <a href="./README_tzh.md"><img alt="繁體版中文自述文件" src="https://img.shields.io/badge/繁體中文-DFE0E5"></a>
  10. <a href="./README_ja.md"><img alt="日本語のREADME" src="https://img.shields.io/badge/日本語-DFE0E5"></a>
  11. <a href="./README_ko.md"><img alt="한국어" src="https://img.shields.io/badge/한국어-DFE0E5"></a>
  12. <a href="./README_id.md"><img alt="Bahasa Indonesia" src="https://img.shields.io/badge/Bahasa Indonesia-DFE0E5"></a>
  13. <a href="./README_pt_br.md"><img alt="Português(Brasil)" src="https://img.shields.io/badge/Português(Brasil)-DBEDFA"></a>
  14. </p>
  15. <p align="center">
  16. <a href="https://x.com/intent/follow?screen_name=infiniflowai" target="_blank">
  17. <img src="https://img.shields.io/twitter/follow/infiniflow?logo=X&color=%20%23f5f5f5" alt="seguir no X(Twitter)">
  18. </a>
  19. <a href="https://demo.ragflow.io" target="_blank">
  20. <img alt="Badge Estático" src="https://img.shields.io/badge/Online-Demo-4e6b99">
  21. </a>
  22. <a href="https://hub.docker.com/r/infiniflow/ragflow" target="_blank">
  23. <img src="https://img.shields.io/docker/pulls/infiniflow/ragflow?label=Docker%20Pulls&color=0db7ed&logo=docker&logoColor=white&style=flat-square" alt="docker pull infiniflow/ragflow:v0.20.0">
  24. </a>
  25. <a href="https://github.com/infiniflow/ragflow/releases/latest">
  26. <img src="https://img.shields.io/github/v/release/infiniflow/ragflow?color=blue&label=Última%20Relese" alt="Última Versão">
  27. </a>
  28. <a href="https://github.com/infiniflow/ragflow/blob/main/LICENSE">
  29. <img height="21" src="https://img.shields.io/badge/License-Apache--2.0-ffffff?labelColor=d4eaf7&color=2e6cc4" alt="licença">
  30. </a>
  31. <a href="https://deepwiki.com/infiniflow/ragflow">
  32. <img alt="Ask DeepWiki" src="https://deepwiki.com/badge.svg">
  33. </a>
  34. </p>
  35. <h4 align="center">
  36. <a href="https://ragflow.io/docs/dev/">Documentação</a> |
  37. <a href="https://github.com/infiniflow/ragflow/issues/4214">Roadmap</a> |
  38. <a href="https://twitter.com/infiniflowai">Twitter</a> |
  39. <a href="https://discord.gg/NjYzJD3GM3">Discord</a> |
  40. <a href="https://demo.ragflow.io">Demo</a>
  41. </h4>
  42. #
  43. <details open>
  44. <summary><b>📕 Índice</b></summary>
  45. - 💡 [O que é o RAGFlow?](#-o-que-é-o-ragflow)
  46. - 🎮 [Demo](#-demo)
  47. - 📌 [Últimas Atualizações](#-últimas-atualizações)
  48. - 🌟 [Principais Funcionalidades](#-principais-funcionalidades)
  49. - 🔎 [Arquitetura do Sistema](#-arquitetura-do-sistema)
  50. - 🎬 [Primeiros Passos](#-primeiros-passos)
  51. - 🔧 [Configurações](#-configurações)
  52. - 🔧 [Construir uma imagem docker sem incorporar modelos](#-construir-uma-imagem-docker-sem-incorporar-modelos)
  53. - 🔧 [Construir uma imagem docker incluindo modelos](#-construir-uma-imagem-docker-incluindo-modelos)
  54. - 🔨 [Lançar serviço a partir do código-fonte para desenvolvimento](#-lançar-serviço-a-partir-do-código-fonte-para-desenvolvimento)
  55. - 📚 [Documentação](#-documentação)
  56. - 📜 [Roadmap](#-roadmap)
  57. - 🏄 [Comunidade](#-comunidade)
  58. - 🙌 [Contribuindo](#-contribuindo)
  59. </details>
  60. ## 💡 O que é o RAGFlow?
  61. [RAGFlow](https://ragflow.io/) é um mecanismo RAG (Geração Aumentada por Recuperação) de código aberto baseado em entendimento profundo de documentos. Ele oferece um fluxo de trabalho RAG simplificado para empresas de qualquer porte, combinando LLMs (Modelos de Linguagem de Grande Escala) para fornecer capacidades de perguntas e respostas verídicas, respaldadas por citações bem fundamentadas de diversos dados complexos formatados.
  62. ## 🎮 Demo
  63. Experimente nossa demo em [https://demo.ragflow.io](https://demo.ragflow.io).
  64. <div align="center" style="margin-top:20px;margin-bottom:20px;">
  65. <img src="https://raw.githubusercontent.com/infiniflow/ragflow-docs/refs/heads/image/image/chunking.gif" width="1200"/>
  66. <img src="https://raw.githubusercontent.com/infiniflow/ragflow-docs/refs/heads/image/image/agentic-dark.gif" width="1200"/>
  67. </div>
  68. ## 🔥 Últimas Atualizações
  69. - 01-08-2025 Suporta o fluxo de trabalho agêntico.
  70. - 23-05-2025 Adicione o componente executor de código Python/JS ao Agente.
  71. - 05-05-2025 Suporte a consultas entre idiomas.
  72. - 19-03-2025 Suporta o uso de um modelo multi-modal para entender imagens dentro de arquivos PDF ou DOCX.
  73. - 28-02-2025 combinado com a pesquisa na Internet (T AVI LY), suporta pesquisas profundas para qualquer LLM.
  74. - 18-12-2024 Atualiza o modelo de Análise de Layout de Documentos no DeepDoc.
  75. - 22-08-2024 Suporta conversão de texto para comandos SQL via RAG.
  76. ## 🎉 Fique Ligado
  77. ⭐️ Dê uma estrela no nosso repositório para se manter atualizado com novas funcionalidades e melhorias empolgantes! Receba notificações instantâneas sobre novos lançamentos! 🌟
  78. <div align="center" style="margin-top:20px;margin-bottom:20px;">
  79. <img src="https://github.com/user-attachments/assets/18c9707e-b8aa-4caf-a154-037089c105ba" width="1200"/>
  80. </div>
  81. ## 🌟 Principais Funcionalidades
  82. ### 🍭 **"Qualidade entra, qualidade sai"**
  83. - Extração de conhecimento baseada em [entendimento profundo de documentos](./deepdoc/README.md) a partir de dados não estruturados com formatos complicados.
  84. - Encontra a "agulha no palheiro de dados" de literalmente tokens ilimitados.
  85. ### 🍱 **Fragmentação baseada em templates**
  86. - Inteligente e explicável.
  87. - Muitas opções de templates para escolher.
  88. ### 🌱 **Citações fundamentadas com menos alucinações**
  89. - Visualização da fragmentação de texto para permitir intervenção humana.
  90. - Visualização rápida das referências chave e citações rastreáveis para apoiar respostas fundamentadas.
  91. ### 🍔 **Compatibilidade com fontes de dados heterogêneas**
  92. - Suporta Word, apresentações, excel, txt, imagens, cópias digitalizadas, dados estruturados, páginas da web e mais.
  93. ### 🛀 **Fluxo de trabalho RAG automatizado e sem esforço**
  94. - Orquestração RAG simplificada voltada tanto para negócios pessoais quanto grandes empresas.
  95. - Modelos LLM e de incorporação configuráveis.
  96. - Múltiplas recuperações emparelhadas com reclassificação fundida.
  97. - APIs intuitivas para integração sem problemas com os negócios.
  98. ## 🔎 Arquitetura do Sistema
  99. <div align="center" style="margin-top:20px;margin-bottom:20px;">
  100. <img src="https://github.com/infiniflow/ragflow/assets/12318111/d6ac5664-c237-4200-a7c2-a4a00691b485" width="1000"/>
  101. </div>
  102. ## 🎬 Primeiros Passos
  103. ### 📝 Pré-requisitos
  104. - CPU >= 4 núcleos
  105. - RAM >= 16 GB
  106. - Disco >= 50 GB
  107. - Docker >= 24.0.0 & Docker Compose >= v2.26.1
  108. - [gVisor](https://gvisor.dev/docs/user_guide/install/): Necessário apenas se você pretende usar o recurso de executor de código (sandbox) do RAGFlow.
  109. > [!TIP]
  110. > Se você não instalou o Docker na sua máquina local (Windows, Mac ou Linux), veja [Instalar Docker Engine](https://docs.docker.com/engine/install/).
  111. ### 🚀 Iniciar o servidor
  112. 1. Certifique-se de que `vm.max_map_count` >= 262144:
  113. > Para verificar o valor de `vm.max_map_count`:
  114. >
  115. > ```bash
  116. > $ sysctl vm.max_map_count
  117. > ```
  118. >
  119. > Se necessário, redefina `vm.max_map_count` para um valor de pelo menos 262144:
  120. >
  121. > ```bash
  122. > # Neste caso, defina para 262144:
  123. > $ sudo sysctl -w vm.max_map_count=262144
  124. > ```
  125. >
  126. > Essa mudança será resetada após a reinicialização do sistema. Para garantir que a alteração permaneça permanente, adicione ou atualize o valor de `vm.max_map_count` em **/etc/sysctl.conf**:
  127. >
  128. > ```bash
  129. > vm.max_map_count=262144
  130. > ```
  131. 2. Clone o repositório:
  132. ```bash
  133. $ git clone https://github.com/infiniflow/ragflow.git
  134. ```
  135. 3. Inicie o servidor usando as imagens Docker pré-compiladas:
  136. > [!CAUTION]
  137. > Todas as imagens Docker são construídas para plataformas x86. Atualmente, não oferecemos imagens Docker para ARM64.
  138. > Se você estiver usando uma plataforma ARM64, por favor, utilize [este guia](https://ragflow.io/docs/dev/build_docker_image) para construir uma imagem Docker compatível com o seu sistema.
  139. > O comando abaixo baixa a edição `v0.20.0-slim` da imagem Docker do RAGFlow. Consulte a tabela a seguir para descrições de diferentes edições do RAGFlow. Para baixar uma edição do RAGFlow diferente da `v0.20.0-slim`, atualize a variável `RAGFLOW_IMAGE` conforme necessário no **docker/.env** antes de usar `docker compose` para iniciar o servidor. Por exemplo: defina `RAGFLOW_IMAGE=infiniflow/ragflow:v0.20.0` para a edição completa `v0.20.0`.
  140. ```bash
  141. $ cd ragflow/docker
  142. # Use CPU for embedding and DeepDoc tasks:
  143. $ docker compose -f docker-compose.yml up -d
  144. # To use GPU to accelerate embedding and DeepDoc tasks:
  145. # docker compose -f docker-compose-gpu.yml up -d
  146. ```
  147. | Tag da imagem RAGFlow | Tamanho da imagem (GB) | Possui modelos de incorporação? | Estável? |
  148. | --------------------- | ---------------------- | ------------------------------- | ------------------------ |
  149. | v0.20.0 | ~9 | :heavy_check_mark: | Lançamento estável |
  150. | v0.20.0-slim | ~2 | ❌ | Lançamento estável |
  151. | nightly | ~9 | :heavy_check_mark: | _Instável_ build noturno |
  152. | nightly-slim | ~2 | ❌ | _Instável_ build noturno |
  153. 4. Verifique o status do servidor após tê-lo iniciado:
  154. ```bash
  155. $ docker logs -f ragflow-server
  156. ```
  157. _O seguinte resultado confirma o lançamento bem-sucedido do sistema:_
  158. ```bash
  159. ____ ___ ______ ______ __
  160. / __ \ / | / ____// ____// /____ _ __
  161. / /_/ // /| | / / __ / /_ / // __ \| | /| / /
  162. / _, _// ___ |/ /_/ // __/ / // /_/ /| |/ |/ /
  163. /_/ |_|/_/ |_|\____//_/ /_/ \____/ |__/|__/
  164. * Rodando em todos os endereços (0.0.0.0)
  165. ```
  166. > Se você pular essa etapa de confirmação e acessar diretamente o RAGFlow, seu navegador pode exibir um erro `network anormal`, pois, nesse momento, seu RAGFlow pode não estar totalmente inicializado.
  167. 5. No seu navegador, insira o endereço IP do seu servidor e faça login no RAGFlow.
  168. > Com as configurações padrão, você só precisa digitar `http://IP_DO_SEU_MÁQUINA` (**sem** o número da porta), pois a porta HTTP padrão `80` pode ser omitida ao usar as configurações padrão.
  169. 6. Em [service_conf.yaml.template](./docker/service_conf.yaml.template), selecione a fábrica LLM desejada em `user_default_llm` e atualize o campo `API_KEY` com a chave de API correspondente.
  170. > Consulte [llm_api_key_setup](https://ragflow.io/docs/dev/llm_api_key_setup) para mais informações.
  171. _O show está no ar!_
  172. ## 🔧 Configurações
  173. Quando se trata de configurações do sistema, você precisará gerenciar os seguintes arquivos:
  174. - [.env](./docker/.env): Contém as configurações fundamentais para o sistema, como `SVR_HTTP_PORT`, `MYSQL_PASSWORD` e `MINIO_PASSWORD`.
  175. - [service_conf.yaml.template](./docker/service_conf.yaml.template): Configura os serviços de back-end. As variáveis de ambiente neste arquivo serão automaticamente preenchidas quando o contêiner Docker for iniciado. Quaisquer variáveis de ambiente definidas dentro do contêiner Docker estarão disponíveis para uso, permitindo personalizar o comportamento do serviço com base no ambiente de implantação.
  176. - [docker-compose.yml](./docker/docker-compose.yml): O sistema depende do [docker-compose.yml](./docker/docker-compose.yml) para iniciar.
  177. > O arquivo [./docker/README](./docker/README.md) fornece uma descrição detalhada das configurações do ambiente e dos serviços, que podem ser usadas como `${ENV_VARS}` no arquivo [service_conf.yaml.template](./docker/service_conf.yaml.template).
  178. Para atualizar a porta HTTP de serviço padrão (80), vá até [docker-compose.yml](./docker/docker-compose.yml) e altere `80:80` para `<SUA_PORTA_DE_SERVIÇO>:80`.
  179. Atualizações nas configurações acima exigem um reinício de todos os contêineres para que tenham efeito:
  180. > ```bash
  181. > $ docker compose -f docker-compose.yml up -d
  182. > ```
  183. ### Mudar o mecanismo de documentos de Elasticsearch para Infinity
  184. O RAGFlow usa o Elasticsearch por padrão para armazenar texto completo e vetores. Para mudar para o [Infinity](https://github.com/infiniflow/infinity/), siga estas etapas:
  185. 1. Pare todos os contêineres em execução:
  186. ```bash
  187. $ docker compose -f docker/docker-compose.yml down -v
  188. ```
  189. Note: `-v` irá deletar os volumes do contêiner, e os dados existentes serão apagados.
  190. 2. Defina `DOC_ENGINE` no **docker/.env** para `infinity`.
  191. 3. Inicie os contêineres:
  192. ```bash
  193. $ docker compose -f docker-compose.yml up -d
  194. ```
  195. > [!ATENÇÃO]
  196. > A mudança para o Infinity em uma máquina Linux/arm64 ainda não é oficialmente suportada.
  197. ## 🔧 Criar uma imagem Docker sem modelos de incorporação
  198. Esta imagem tem cerca de 2 GB de tamanho e depende de serviços externos de LLM e incorporação.
  199. ```bash
  200. git clone https://github.com/infiniflow/ragflow.git
  201. cd ragflow/
  202. docker build --platform linux/amd64 --build-arg LIGHTEN=1 -f Dockerfile -t infiniflow/ragflow:nightly-slim .
  203. ```
  204. ## 🔧 Criar uma imagem Docker incluindo modelos de incorporação
  205. Esta imagem tem cerca de 9 GB de tamanho. Como inclui modelos de incorporação, depende apenas de serviços externos de LLM.
  206. ```bash
  207. git clone https://github.com/infiniflow/ragflow.git
  208. cd ragflow/
  209. docker build --platform linux/amd64 -f Dockerfile -t infiniflow/ragflow:nightly .
  210. ```
  211. ## 🔨 Lançar o serviço a partir do código-fonte para desenvolvimento
  212. 1. Instale o `uv`, ou pule esta etapa se ele já estiver instalado:
  213. ```bash
  214. pipx install uv pre-commit
  215. ```
  216. 2. Clone o código-fonte e instale as dependências Python:
  217. ```bash
  218. git clone https://github.com/infiniflow/ragflow.git
  219. cd ragflow/
  220. uv sync --python 3.10 --all-extras # instala os módulos Python dependentes do RAGFlow
  221. uv run download_deps.py
  222. pre-commit install
  223. ```
  224. 3. Inicie os serviços dependentes (MinIO, Elasticsearch, Redis e MySQL) usando Docker Compose:
  225. ```bash
  226. docker compose -f docker/docker-compose-base.yml up -d
  227. ```
  228. Adicione a seguinte linha ao arquivo `/etc/hosts` para resolver todos os hosts especificados em **docker/.env** para `127.0.0.1`:
  229. ```
  230. 127.0.0.1 es01 infinity mysql minio redis sandbox-executor-manager
  231. ```
  232. 4. Se não conseguir acessar o HuggingFace, defina a variável de ambiente `HF_ENDPOINT` para usar um site espelho:
  233. ```bash
  234. export HF_ENDPOINT=https://hf-mirror.com
  235. ```
  236. 5. Se o seu sistema operacional não tiver jemalloc, instale-o da seguinte maneira:
  237. ```bash
  238. # ubuntu
  239. sudo apt-get install libjemalloc-dev
  240. # centos
  241. sudo yum instalar jemalloc
  242. ```
  243. 6. Lance o serviço de back-end:
  244. ```bash
  245. source .venv/bin/activate
  246. export PYTHONPATH=$(pwd)
  247. bash docker/launch_backend_service.sh
  248. ```
  249. 7. Instale as dependências do front-end:
  250. ```bash
  251. cd web
  252. npm install
  253. ```
  254. 8. Lance o serviço de front-end:
  255. ```bash
  256. npm run dev
  257. ```
  258. _O seguinte resultado confirma o lançamento bem-sucedido do sistema:_
  259. ![](https://github.com/user-attachments/assets/0daf462c-a24d-4496-a66f-92533534e187)
  260. 9. Pare os serviços de front-end e back-end do RAGFlow após a conclusão do desenvolvimento:
  261. ```bash
  262. pkill -f "ragflow_server.py|task_executor.py"
  263. ```
  264. ## 📚 Documentação
  265. - [Quickstart](https://ragflow.io/docs/dev/)
  266. - [Configuration](https://ragflow.io/docs/dev/configurations)
  267. - [Release notes](https://ragflow.io/docs/dev/release_notes)
  268. - [User guides](https://ragflow.io/docs/dev/category/guides)
  269. - [Developer guides](https://ragflow.io/docs/dev/category/developers)
  270. - [References](https://ragflow.io/docs/dev/category/references)
  271. - [FAQs](https://ragflow.io/docs/dev/faq)
  272. ## 📜 Roadmap
  273. Veja o [RAGFlow Roadmap 2025](https://github.com/infiniflow/ragflow/issues/4214)
  274. ## 🏄 Comunidade
  275. - [Discord](https://discord.gg/NjYzJD3GM3)
  276. - [Twitter](https://twitter.com/infiniflowai)
  277. - [GitHub Discussions](https://github.com/orgs/infiniflow/discussions)
  278. ## 🙌 Contribuindo
  279. O RAGFlow prospera por meio da colaboração de código aberto. Com esse espírito, abraçamos contribuições diversas da comunidade.
  280. Se você deseja fazer parte, primeiro revise nossas [Diretrizes de Contribuição](https://ragflow.io/docs/dev/contributing).