PuppeteerSharp を使用して、ユーザーがアプリケーションの PDF をダウンロードできる機能を追加します。残念ながら、膨大な数の Chromium プロセスが開始され、サーバーを再起動するまで停止しないことがあります。
通常、ユーザーが PDF をダウンロードすると、5 つの chromium プロセスが開始され、ダウンロードが完了するとそれらのプロセスは消えます。
これは私たちのコードです:
private static LaunchOptions launchOptions = new LaunchOptions
{
ExecutablePath = chromepath,
Headless = true,
DefaultViewport = ViewPortOptions
};
public static void ExportPdf(string url, string location)
{
try
{
Task<string> task = Task.Run<string>(async () => await ExportPdfASync(url, location)));
task.Wait();
}
catch (Exception)
{
// Exception handling
}
}
public static async Task<string> ExportPdfASync(string url, string location)
{
using (var browser = await Puppeteer.LaunchAsync(LaunchOptions))
using (var page = await browser.NewPageAsync())
{
await page.SetViewportAsync(new ViewPortOptions() { Width = 1440, Height = 990, IsMobile = false, DeviceScaleFactor = 1.0 });
await page.SetJavaScriptEnabledAsync(true);
await page.GoToAsync(url);
await page.WaitForTimeoutAsync(1500);
var marginOptions = new MarginOptions()
{
Top = "10mm",
Left = "10mm",
Right = "10mm",
Bottom = "10mm"
};
var pdfOptions = new PdfOptions()
{
PrintBackground = true,
Format = PaperFormat.A4,
MarginOptions = marginOptions,
Landscape = landscape
};
await page.PdfAsync(location, pdfOptions);
}
return "";
}
ブラウザとページは using ブロックにあるため、エラーが発生しても破棄する必要があります。
誰でもこの問題の解決策を持っていますか? 私たちと私たちのサーバーはとても幸せです;)