如何用 C# 从 Gotenberg 迁移到 IronPDF
从高登堡迁移到 IronPDF:完整的 C# 迁移指南。
从高登堡迁移到IronPDF可将您的 .NET PDF 工作流程从基于 Docker 的微服务架构与 HTTP API 调用转换为进程内的本地 C# 库。 本指南为专业的 .NET 开发人员提供了一个全面的、循序渐进的迁移路径,消除了基础架构开销、网络延迟和容器管理的复杂性。
为什么要从高登堡迁移到 IronPDF.
哥登堡架构问题
Gotenberg 是一种基于 Docker 的 PDF 生成微服务架构。 虽然功能强大且灵活,但它为 C# 应用程序带来了很大的复杂性:
1.基础设施开销:需要 Docker、容器协调(Kubernetes/Docker Compose)、服务发现和负载平衡。 每次部署都会变得更加复杂。
2.网络延迟:每个 PDF 操作都需要对单独的服务进行 HTTP 调用,每次请求会增加10-100 毫秒以上。在大容量应用场景中,这种延迟会迅速加剧。
3.冷启动问题:容器启动会使首次请求时间延长 2-5 秒。 每次 pod 重启、每次扩展事件和每次部署都会触发冷启动。
4.操作复杂性:您必须将容器的健康状况、扩展、日志记录和监控与主应用程序分开管理。
5.多部分表单数据:每个请求都需要构建多部分/表单数据有效载荷--冗长、容易出错且维护繁琐。
6.故障点:网络超时、服务不可用和容器崩溃都需要您负责处理。
7.版本管理:Gotenberg 图像与您的应用程序分开更新; API 的更改可能会意外破坏集成。
高登堡与IronPDF对比
| 方面 | 高登堡 | IronPDF |
|---|---|---|
| 部署 | Docker 容器 + 协调 | 单个 NuGet 软件包 |
| 结构 | 微服务(REST API) | 在建库 |
| 每次请求的延迟 | 10-100ms+(网络往返) | < 1ms 开销 |
| 冷启动 | 2-5 秒(容器启动) | 1-2 秒(仅限首次呈现) |
| 基础设施 | Docker、Kubernetes、负载平衡器 | 无要求 |
| 失败模式 | 网络、容器、服务故障 | .NET 标准例外情况 |
| API 风格 | REST 多art/表单数据 | 本地 C# 方法调用 |
| 缩放 | 横向(更多容器) | 纵向(处理中) |
| 调试 | 需要分布式跟踪 | 标准调试器 |
| 版本控制 | 容器图像标签 | NuGet 软件包版本 |
对于计划在 2025 年和 2026 年之前采用 .NET 10 和 C# 14 的团队来说,IronPDF 提供了一个面向未来的基础,零基础设施依赖性,可与现代 .NET 模式原生集成。
迁移复杂性评估
按功能估算的工作量
| 特征 | 迁移复杂性 | 备注 |
|---|---|---|
| HTML 至 PDF | 极低 | 直接方法替换 |
| URL 至 PDF | 极低 | 直接方法替换 |
| 定制纸张大小 | 低 | 基于属性的配置 |
| 边距 | 低 | 单位换算(英寸 → 毫米) |
| PDF 合并 | 低 | 静态方法调用 |
| 页眉/页脚 | 语言 | 不同的占位符语法 |
| 等待延迟 | 低 | 字符串到毫秒 |
| PDF/A 转换 | 低 | 方法调用代替参数 |
范式转换
此次高登堡迁移的根本转变是从带有多部分表单数据的 HTTP API 调用到 原生 C# 方法调用:
高登堡: 向 Docker 容器发送 HTTP POST 多址/表单数据
IronPdf: 在 C# 对象上直接调用方法开始之前
前提条件
1..NET版本:IronPDF支持.NET Framework 4.6.2+ 和 .NET Core 3.1+ / .NET 5/6/7/8/9+ 。 2.许可证密钥:从 ironpdf.com 获取IronPDF许可证密钥。 3.基础设施拆除计划:记录高登贝尔格容器在迁移后的退役情况
识别所有高登堡用法
# Find direct HTTP calls to Gotenberg
grep -r "gotenberg\|/forms/chromium\|/forms/libreoffice\|/forms/pdfengines" --include="*.cs" .
# Find GotenbergSharpApiClient usage
grep -r "GotenbergSharpClient\|Gotenberg.Sharp\|ChromiumRequest" --include="*.cs" .
# Find Docker/Kubernetes高登堡configuration
grep -r "gotenberg/gotenberg\|gotenberg:" --include="*.yml" --include="*.yaml" .# Find direct HTTP calls to Gotenberg
grep -r "gotenberg\|/forms/chromium\|/forms/libreoffice\|/forms/pdfengines" --include="*.cs" .
# Find GotenbergSharpApiClient usage
grep -r "GotenbergSharpClient\|Gotenberg.Sharp\|ChromiumRequest" --include="*.cs" .
# Find Docker/Kubernetes高登堡configuration
grep -r "gotenberg/gotenberg\|gotenberg:" --include="*.yml" --include="*.yaml" .NuGet 软件包变更
# Remove高登堡client (if using)
dotnet remove package Gotenberg.Sharp.API.Client
# Install IronPDF
dotnet add package IronPdf# Remove高登堡client (if using)
dotnet remove package Gotenberg.Sharp.API.Client
# Install IronPDF
dotnet add package IronPdf快速启动迁移
步骤 1:更新许可配置
之前(高登堡):
Gotenberg 不需要许可证,但需要带有容器 URL 的 Docker 基础设施。
private readonly string _gotenbergUrl = "http://localhost:3000";private readonly string _gotenbergUrl = "http://localhost:3000";IRON VB CONVERTER ERROR developers@ironsoftware.comAfter (IronPDF):
// Set once at application startup
IronPdf.License.LicenseKey = "YOUR-IRONPDF-LICENSE-KEY";// Set once at application startup
IronPdf.License.LicenseKey = "YOUR-IRONPDF-LICENSE-KEY";IRON VB CONVERTER ERROR developers@ironsoftware.com步骤 2:更新名称空间导入
// Before (Gotenberg)
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
// After (IronPDF)
using IronPdf;
using IronPdf.Rendering;// Before (Gotenberg)
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
// After (IronPDF)
using IronPdf;
using IronPdf.Rendering;IRON VB CONVERTER ERROR developers@ironsoftware.com完整的 API 参考
戈登堡端点到IronPDF的映射
| 哥登堡路线 | IronPdf 同等产品 | 备注 |
|---|---|---|
| <代码>POST /forms/chromium/convert/html</ 代码 | <代码>ChromePdfRenderer.RenderHtmlAsPdf()</代码 | 将 HTML 字符串转换为 PDF |
POST /forms/chromium/convert/url | <代码>ChromePdfRenderer.RenderUrlAsPdf()</代码 | URL 至 PDF |
POST /forms/pdfengines/merge</ 代码 | <代码>PdfDocument.Merge()</代码 | 合并多个 PDF |
POST /forms/pdfengines/convert</ 代码 | <代码>pdf.SaveAs()</代码>设置 | PDF/A 转换 |
| <代码>获取 /health</ 代码 | 不适用 | 无需外部服务 |
表单参数到渲染选项映射
| 高登贝格参数 | IronPdf 属性 | 转换注意事项 |
|---|---|---|
| <代码>纸张宽度</代码>(英寸) | <代码>RenderingOptions.PaperSize</代码 | 使用枚举或自定义大小 |
| <代码>纸张高度</代码>(英寸) | <代码>RenderingOptions.PaperSize</代码 | 使用枚举或自定义大小 |
| <代码>marginTop</代码>(英寸) | <代码>RenderingOptions.MarginTop</代码 | 毫米数乘以 25.4 |
| <代码>marginBottom</代码>(英寸) | <代码>RenderingOptions.MarginBottom</代码 | 毫米数乘以 25.4 |
| <代码>打印背景</代码 | <代码>RenderingOptions.PrintHtmlBackgrounds</代码 | 布尔 |
| <代码>景观</代码 | <代码>RenderingOptions.PaperOrientation</代码 | Landscape 枚举 |
| <代码>waitDelay</代码 | <代码>RenderingOptions.RenderDelay</代码 | 转换为毫秒 |
代码迁移示例
示例 1:将基本 HTML 转换为 PDF.
之前(高登堡):
using System;
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
class GotenbergExample
{
static async Task Main()
{
var gotenbergUrl = "http://localhost:3000/forms/chromium/convert/html";
using var client = new HttpClient();
using var content = new MultipartFormDataContent();
var html = "<html><body><h1>Hello from Gotenberg</h1></body></html>";
content.Add(new StringContent(html), "files", "index.html");
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
await File.WriteAllBytesAsync("output.pdf", pdfBytes);
Console.WriteLine("PDF generated successfully");
}
}using System;
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
class GotenbergExample
{
static async Task Main()
{
var gotenbergUrl = "http://localhost:3000/forms/chromium/convert/html";
using var client = new HttpClient();
using var content = new MultipartFormDataContent();
var html = "<html><body><h1>Hello from Gotenberg</h1></body></html>";
content.Add(new StringContent(html), "files", "index.html");
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
await File.WriteAllBytesAsync("output.pdf", pdfBytes);
Console.WriteLine("PDF generated successfully");
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comAfter (IronPDF):
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class IronPdfExample
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var html = "<html><body><h1>Hello from IronPDF</h1></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
Console.WriteLine("PDF generated successfully");
}
}// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class IronPdfExample
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var html = "<html><body><h1>Hello from IronPDF</h1></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
Console.WriteLine("PDF generated successfully");
}
}IRON VB CONVERTER ERROR developers@ironsoftware.com两者之间的差别很大:Gotenberg 需要构建一个 HttpClient 、构建 MultipartFormDataContent 、向运行中的 Docker 容器进行异步 HTTP POST 以及处理字节数组响应。IronPDF通过ChromePdfRenderer方法调用将其缩减为三行--无网络开销、无容器依赖性、无异步复杂性。 有关其他渲染选项,请参阅 HTML to PDF 文档。
示例 2:URL 到 PDF 的转换
之前(高登堡):
using System;
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
class GotenbergUrlToPdf
{
static async Task Main()
{
var gotenbergUrl = "http://localhost:3000/forms/chromium/convert/url";
using var client = new HttpClient();
using var content = new MultipartFormDataContent();
content.Add(new StringContent("https://example.com"), "url");
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
await File.WriteAllBytesAsync("webpage.pdf", pdfBytes);
Console.WriteLine("PDF from URL generated successfully");
}
}using System;
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
class GotenbergUrlToPdf
{
static async Task Main()
{
var gotenbergUrl = "http://localhost:3000/forms/chromium/convert/url";
using var client = new HttpClient();
using var content = new MultipartFormDataContent();
content.Add(new StringContent("https://example.com"), "url");
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
await File.WriteAllBytesAsync("webpage.pdf", pdfBytes);
Console.WriteLine("PDF from URL generated successfully");
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comAfter (IronPDF):
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class IronPdfUrlToPdf
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://example.com");
pdf.SaveAs("webpage.pdf");
Console.WriteLine("PDF from URL generated successfully");
}
}// NuGet: Install-Package IronPdf
using System;
using IronPdf;
class IronPdfUrlToPdf
{
static void Main()
{
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf("https://example.com");
pdf.SaveAs("webpage.pdf");
Console.WriteLine("PDF from URL generated successfully");
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comGotenberg 方法要求使用不同的端点(/forms/chromium/convert/url),将 URL 作为表单字段构建多部分内容,并处理异步 HTTP 响应。IronPDF的 RenderUrlAsPdf() 方法直接接受 URL 并同步返回 PdfDocument 对象。 了解有关 URL 至 PDF 转换的更多信息。
示例 3:自定义纸张大小和页边距
之前(高登堡):
using System;
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
class GotenbergCustomSize
{
static async Task Main()
{
var gotenbergUrl = "http://localhost:3000/forms/chromium/convert/html";
using var client = new HttpClient();
using var content = new MultipartFormDataContent();
var html = "<html><body><h1>Custom Size PDF</h1></body></html>";
content.Add(new StringContent(html), "files", "index.html");
content.Add(new StringContent("8.5"), "paperWidth");
content.Add(new StringContent("11"), "paperHeight");
content.Add(new StringContent("0.5"), "marginTop");
content.Add(new StringContent("0.5"), "marginBottom");
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
await File.WriteAllBytesAsync("custom-size.pdf", pdfBytes);
Console.WriteLine("Custom size PDF generated successfully");
}
}using System;
using System.Net.Http;
using System.Threading.Tasks;
using System.IO;
class GotenbergCustomSize
{
static async Task Main()
{
var gotenbergUrl = "http://localhost:3000/forms/chromium/convert/html";
using var client = new HttpClient();
using var content = new MultipartFormDataContent();
var html = "<html><body><h1>Custom Size PDF</h1></body></html>";
content.Add(new StringContent(html), "files", "index.html");
content.Add(new StringContent("8.5"), "paperWidth");
content.Add(new StringContent("11"), "paperHeight");
content.Add(new StringContent("0.5"), "marginTop");
content.Add(new StringContent("0.5"), "marginBottom");
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
await File.WriteAllBytesAsync("custom-size.pdf", pdfBytes);
Console.WriteLine("Custom size PDF generated successfully");
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comAfter (IronPDF):
// NuGet: Install-Package IronPdf
using System;
using IronPdf;
using IronPdf.Rendering;
class IronPdfCustomSize
{
static void Main()
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.PaperSize = PdfPaperSize.Letter;
renderer.RenderingOptions.MarginTop = 50;
renderer.RenderingOptions.MarginBottom = 50;
var html = "<html><body><h1>Custom Size PDF</h1></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("custom-size.pdf");
Console.WriteLine("Custom size PDF generated successfully");
}
}// NuGet: Install-Package IronPdf
using System;
using IronPdf;
using IronPdf.Rendering;
class IronPdfCustomSize
{
static void Main()
{
var renderer = new ChromePdfRenderer();
renderer.RenderingOptions.PaperSize = PdfPaperSize.Letter;
renderer.RenderingOptions.MarginTop = 50;
renderer.RenderingOptions.MarginBottom = 50;
var html = "<html><body><h1>Custom Size PDF</h1></body></html>";
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("custom-size.pdf");
Console.WriteLine("Custom size PDF generated successfully");
}
}IRON VB CONVERTER ERROR developers@ironsoftware.comGotenberg 要求将基于字符串的参数("8.5"、"11"、"0.5")添加到多部分表单数据中--没有类型安全性,没有 IntelliSense,容易打错。IronPDF通过 PdfPaperSize 枚举和数字页边距值提供强类型属性。 请注意,IronPdf 页边距以毫米为单位(50 毫米≈ 2 英寸),而高登堡使用英寸。
关键迁移说明
单位转换
此次高登堡迁移中最重要的转换是保证金单位:
// Gotenberg: margins in inches
content.Add(new StringContent("0.5"), "marginTop"); // 0.5 inches
content.Add(new StringContent("1"), "marginBottom"); // 1 inch
// IronPDF: margins in millimeters
renderer.RenderingOptions.MarginTop = 12.7; // 0.5 inches × 25.4 = 12.7mm
renderer.RenderingOptions.MarginBottom = 25.4; // 1 inch × 25.4 = 25.4mm// Gotenberg: margins in inches
content.Add(new StringContent("0.5"), "marginTop"); // 0.5 inches
content.Add(new StringContent("1"), "marginBottom"); // 1 inch
// IronPDF: margins in millimeters
renderer.RenderingOptions.MarginTop = 12.7; // 0.5 inches × 25.4 = 12.7mm
renderer.RenderingOptions.MarginBottom = 25.4; // 1 inch × 25.4 = 25.4mmIRON VB CONVERTER ERROR developers@ironsoftware.com换算公式:<代码>毫米 = 英寸 × 25.4</代码
同步与异步
由于 HTTP 通信,Gotenberg 需要异步操作:
// Gotenberg: Forced async due to network calls
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
// IronPDF: Synchronous in-process execution
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
// IronPDF: Async wrapper if needed
var pdf = await Task.Run(() => renderer.RenderHtmlAsPdf(html));// Gotenberg: Forced async due to network calls
var response = await client.PostAsync(gotenbergUrl, content);
var pdfBytes = await response.Content.ReadAsByteArrayAsync();
// IronPDF: Synchronous in-process execution
var pdf = renderer.RenderHtmlAsPdf(html);
pdf.SaveAs("output.pdf");
// IronPDF: Async wrapper if needed
var pdf = await Task.Run(() => renderer.RenderHtmlAsPdf(html));IRON VB CONVERTER ERROR developers@ironsoftware.com错误处理
// Gotenberg: HTTP error handling
try
{
var response = await client.PostAsync(gotenbergUrl, content);
response.EnsureSuccessStatusCode(); // What if 500? 503? Timeout?
}
catch (HttpRequestException ex) { /* Network error */ }
catch (TaskCanceledException ex) { /* Timeout */ }
// IronPDF: Standard .NET exceptions
try
{
var pdf = renderer.RenderHtmlAsPdf(html);
}
catch (Exception ex)
{
Console.WriteLine($"PDF generation failed: {ex.Message}");
}// Gotenberg: HTTP error handling
try
{
var response = await client.PostAsync(gotenbergUrl, content);
response.EnsureSuccessStatusCode(); // What if 500? 503? Timeout?
}
catch (HttpRequestException ex) { /* Network error */ }
catch (TaskCanceledException ex) { /* Timeout */ }
// IronPDF: Standard .NET exceptions
try
{
var pdf = renderer.RenderHtmlAsPdf(html);
}
catch (Exception ex)
{
Console.WriteLine($"PDF generation failed: {ex.Message}");
}IRON VB CONVERTER ERROR developers@ironsoftware.com基础架构移除
迁移后,从您的基础架构中移除 Gotenberg:
# REMOVE from docker-compose.yml:
# services:
# gotenberg:
# image: gotenberg/gotenberg:8
# ports:
# - "3000:3000"
# deploy:
# resources:
# limits:
# memory: 2G# REMOVE from docker-compose.yml:
# services:
# gotenberg:
# image: gotenberg/gotenberg:8
# ports:
# - "3000:3000"
# deploy:
# resources:
# limits:
# memory: 2G性能考虑
延迟比较
| 手术 | 哥登堡(温暖) | 高登堡(冷启动) | IronPdf (初渲染) | IronPdf (后续) |
|---|---|---|---|---|
| 简单的 HTML | 150-300 毫秒 | 2-5 秒 | 1-2 秒 | 50-150ms |
| 复杂的 HTML | 500-1500ms | 3-7 秒 | 1.5-3 秒 | 200-800ms |
| URL 渲染 | 1-5 秒 | 3-10 秒 | 1-5 秒 | 500ms-3s |
消除基础设施成本
| 资源 | 高登堡 | IronPDF |
|---|---|---|
| 所需容器 | 1-N(缩放) | 0 |
| 每个容器的内存 | 512MB-2GB | 不适用 |
| 每次请求的网络开销 | 10-100 毫秒 | 0ms |
| 健康检查终点 | 要求 | 不需要 |
| 负载平衡器 | 经常需要 | 不需要 |
故障排除
问题 1:不需要 HttpClient 模式
问题:代码仍在使用 HttpClient 和 MultipartFormDataContent.
解决方案:完全替换为 ChromePdfRenderer:
// Remove all of this:
// using var client = new HttpClient();
// using var content = new MultipartFormDataContent();
// content.Add(new StringContent(html), "files", "index.html");
// var response = await client.PostAsync(url, content);
// Replace with:
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);// Remove all of this:
// using var client = new HttpClient();
// using var content = new MultipartFormDataContent();
// content.Add(new StringContent(html), "files", "index.html");
// var response = await client.PostAsync(url, content);
// Replace with:
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(html);IRON VB CONVERTER ERROR developers@ironsoftware.com问题 2:边距单位错误
问题:迁移后 PDF 的页边距不正确。
解决方案:将英寸转换为毫米:
//高登堡used inches: "0.5"
//IronPDFuses millimeters: 0.5 × 25.4 = 12.7
renderer.RenderingOptions.MarginTop = 12.7;//高登堡used inches: "0.5"
//IronPDFuses millimeters: 0.5 × 25.4 = 12.7
renderer.RenderingOptions.MarginTop = 12.7;IRON VB CONVERTER ERROR developers@ironsoftware.com问题 3:容器 URL 引用
问题:代码包含 http://gotenberg:3000 或类似 URL。
解决方案:删除所有容器 URL 引用--IronPdf 在进程中运行:
// Remove:
// private readonly string _gotenbergUrl = "http://gotenberg:3000";
//IronPDFneeds no URL - it's in-process
var renderer = new ChromePdfRenderer();// Remove:
// private readonly string _gotenbergUrl = "http://gotenberg:3000";
//IronPDFneeds no URL - it's in-process
var renderer = new ChromePdfRenderer();IRON VB CONVERTER ERROR developers@ironsoftware.com迁移清单
迁移前
- [ ] 清点代码库中的所有高登堡HTTP 调用
- [ ] 记录当前的高登堡配置(超时、页边距、纸张大小)
- [确定所有 Docker/Kubernetes高登堡配置
- [ ] 获取 IronPdf 许可证密钥
- [ ] 计划基础设施退役
代码迁移
- [ ] 安装 IronPdf NuGet 软件包:<代码>dotnet 添加软件包 IronPdf</ 代码
- [ ] 删除高登堡客户端软件包
- [ ] 将对高登堡的所有 HTTP 调用替换为IronPDF方法调用
- [ ] 将边距单位从英寸转换为毫米
- [ ] 更新错误处理(HTTP 错误 → .NET 异常)
- [ ] 在启动时添加许可证密钥初始化
基础架构迁移
- [ ] 从 Docker Compose / Kubernetes 中移除 Gotenberg
- [ ] 更新 CI/CD 管道(删除高登堡图像拉取)
- [ ] 删除高登堡健康检查
- [ ] 从配置中删除高登堡URL
测试
- [ ] 测试 HTML 到 PDF 的转换
- [ ] 测试 URL 到 PDF 的转换
- [ ] 核实页边距和大小的准确性
- [ ] 负载下的性能测试
- [ ] 测试初学者预热时间
后迁移
- [ ] 删除高登堡容器部署
- [ ] 存档高登堡配置文件
- [ ] 更新文档
- [ ] 监控应用程序内存使用情况
- [ ] 验证无孤儿网络连接
结论
从高登堡迁移到IronPDF可消除 Docker 基础架构的复杂性,消除每次 PDF 操作的网络延迟,并以简洁、类型安全的 C# 方法调用取代冗长的多部分表单数据构建。 这样做的结果是部署更简单、延迟更低、故障点更少、调试更容易,同时通过IronPDF的嵌入式 Chromium 引擎保持完整的 HTML/CSS/JavaScript 渲染功能。
本次迁移的主要变化有 1.架构:REST API 调用 → 本地 C# 方法 2.基础设施:Docker 容器 → NuGet 软件包 3.单位:英寸 → 毫米(用于页边距 4.错误处理:HTTP 状态代码 → .NET 异常 5.延迟:网络往返 → 进程内执行






