Executando o IronPDF no Linux: Guia de Configuração

This article was translated from English: Does it need improvement?
Translated
View the article in English

O IronPDF para Linux tem cerca de 280 MB (incluindo o código do IronPDF e todo o navegador Chrome). As imagens do Docker têm cerca de 500 MB.

O Chrome também requer alguns pacotes básicos que variam de acordo com a sua distribuição Linux. A maioria das distribuições Linux já possui esses pacotes instalados, pois eles são utilizados por diversos aplicativos e bibliotecas no Linux.

No entanto, se você estiver usando uma distribuição Linux básica, precisará instalar os pacotes Linux necessários para executar o Chrome no Linux.

Nota: Para facilitar a depuração, você pode definir estas opções:

// Enable detailed debugging for IronPdf
IronPdf.Logging.Logger.EnableDebugging = true;

// Specify the log file path
IronPdf.Logging.Logger.LogFilePath = "Default.log";

// Set the logging mode to capture all log data
IronPdf.Logging.Logger.LoggingMode = IronPdf.Logging.Logger.LoggingModes.All;
// Enable detailed debugging for IronPdf
IronPdf.Logging.Logger.EnableDebugging = true;

// Specify the log file path
IronPdf.Logging.Logger.LogFilePath = "Default.log";

// Set the logging mode to capture all log data
IronPdf.Logging.Logger.LoggingMode = IronPdf.Logging.Logger.LoggingModes.All;
' Enable detailed debugging for IronPdf
IronPdf.Logging.Logger.EnableDebugging = True

' Specify the log file path
IronPdf.Logging.Logger.LogFilePath = "Default.log"

' Set the logging mode to capture all log data
IronPdf.Logging.Logger.LoggingMode = IronPdf.Logging.Logger.LoggingModes.All
$vbLabelText   $csharpLabel

Como criar uma imagem Docker menor

1. Instalando pacotes em tempo de execução

Uma maneira de reduzir o tamanho é executar os comandos apt-get em tempo de execução, em vez de durante a construção da imagem do docker:

  1. Remova os comandos apt-get do seu Dockerfile.
  2. Defina Installation.LinuxAndDockerDependenciesAutoConfig = true; antes de inicializar o IronPdf ou renderizar um documento.
  3. Certifique-se de que sua aplicação seja executada com permissões suficientes para executar os comandos apt-get.

Nota: Sua primeira inicialização será mais lenta, pois os comandos apt-get devem ser concluídos antes de renderizar seu primeiro documento, e este processo se repetirá sempre que você tiver que reimplantar a imagem.

Observação: você deverá ver entradas no console/log indicando instalações de pacotes bem-sucedidas:

Executing command 'apt install -y libnss3' in '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Reading package lists...
Building dependency tree...
Reading state information...
The following additional packages will be installed:
  libnspr4
The following NEW packages will be installed:
  libnspr4 libnss3
0 upgraded, 2 newly installed, 0 to remove and 9 not upgraded.
Executing command 'apt install -y libnss3' in '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Reading package lists...
Building dependency tree...
Reading state information...
The following additional packages will be installed:
  libnspr4
The following NEW packages will be installed:
  libnspr4 libnss3
0 upgraded, 2 newly installed, 0 to remove and 9 not upgraded.
SHELL

2. Use o IronPdf.Slim

Você também pode optar por incluir apenas o arquivo IronPDF e baixar os arquivos necessários em tempo de execução.

  1. Remova o pacote NuGet IronPDF(e qualquer outro IronPDF ) do seu projeto e adicione o IronPDF.
  2. Defina Installation.AutomaticallyDownloadNativeBinaries = true; antes de inicializar o IronPdf ou renderizar um documento.
  3. Certifique-se de que seu Dockerfile conceda permissões de leitura e escrita para todo o diretório de trabalho da sua aplicação (por exemplo, altere RUN chmod +rwx /app/runtimes/linux-x64/native/IronCefSubprocess para RUN chmod +rwx /app/).

Observação: Sua primeira inicialização será mais lenta, pois o pacote NuGet será baixado e extraído antes da renderização do primeiro documento, e esse processo se repetirá sempre que você precisar reimplantar a imagem.

Observação: você deverá ver entradas no console/log indicando que o download e a extração foram bem-sucedidos:

Downloading NuGet package from 'https://www.nuget.org/api/v2/package/IronPdf.Native.Chrome.Linux/2023.1.11387'
Extracting package contents '/app/bin/Debug/netcoreapp3.1/IronPdf.Native.Chrome.Linux.2023.1.11387.nupkg/runtimes/linux-x64/native' to '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Successfully deployed NuGet package 'IronPdf.Native.Chrome.Linux' to '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Successfully located 'IronInterop' at '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Downloading NuGet package from 'https://www.nuget.org/api/v2/package/IronPdf.Native.Chrome.Linux/2023.1.11387'
Extracting package contents '/app/bin/Debug/netcoreapp3.1/IronPdf.Native.Chrome.Linux.2023.1.11387.nupkg/runtimes/linux-x64/native' to '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Successfully deployed NuGet package 'IronPdf.Native.Chrome.Linux' to '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
Successfully located 'IronInterop' at '/app/bin/Debug/netcoreapp3.1/runtimes/linux-x64/native'
SHELL

3. Conclusão

Em resumo, para reduzir o tamanho inicial do contêiner:

  • Utilize o pacote NuGet IronPDF .Slim.
  • Configurar IronPDF:
// Set installation options for Linux and Docker environments
Installation.LinuxAndDockerDependenciesAutoConfig = true;
Installation.AutomaticallyDownloadNativeBinaries = true;
// Set installation options for Linux and Docker environments
Installation.LinuxAndDockerDependenciesAutoConfig = true;
Installation.AutomaticallyDownloadNativeBinaries = true;
' Set installation options for Linux and Docker environments
Installation.LinuxAndDockerDependenciesAutoConfig = True
Installation.AutomaticallyDownloadNativeBinaries = True
$vbLabelText   $csharpLabel
  • Certifique-se de que o diretório do aplicativo tenha permissão de escrita/execução:
RUN chmod +rwx /app/

Uma imagem Docker muito enxuta, utilizando os pontos 1 e 2, deve reduzir o tamanho de aproximadamente 500 MB para aproximadamente 200 MB.

Se possível, você obterá o melhor desempenho se NÃO optar por uma implantação compacta.

Alguns ambientes de contêiner e em nuvem não são persistentes e, portanto, podem ter que rebaixar ocasionalmente dependências ou executar novamente os comandos apt-get, demorando até alguns minutos!

No entanto, compreendemos que alguns desenvolvedores podem estar sujeitos a requisitos de tamanho rigorosos para suas implantações.

Curtis Chau
Redator Técnico

Curtis Chau é bacharel em Ciência da Computação (Universidade Carleton) e se especializa em desenvolvimento front-end, com experiência em Node.js, TypeScript, JavaScript e React. Apaixonado por criar interfaces de usuário intuitivas e esteticamente agradáveis, Curtis gosta de trabalhar com frameworks modernos e criar manuais ...

Leia mais
Pronto para começar?
Nuget Downloads 18,318,263 | Versão: 2026.4 acaba de ser lançado
Still Scrolling Icon

Ainda está rolando a tela?

Quer provas rápidas? PM > Install-Package IronPdf
executar um exemplo Veja seu HTML se transformar em um PDF.