当前位置: 首页 > article >正文

SQLServer跨平台迁移实战:从Windows备份到Linux还原的完整指南

1. 迁移前的准备工作跨平台迁移数据库就像搬家前的打包工作需要提前确认好物品清单和运输工具。我经历过多次SQL Server从Windows到Linux的迁移发现90%的问题都出在准备阶段。以下是必须检查的关键点Windows端必备条件确保源数据库版本在SQL Server 2017及以上这是官方支持跨平台迁移的最低版本安装最新版SQL Server Management Studio建议18.0以上检查数据库兼容性级别SELECT compatibility_level FROM sys.databases WHERE name YourDB特别提醒如果使用TDE加密的数据库需要提前备份证书和密钥Linux端环境配置# 以Ubuntu为例的安装命令 sudo apt-get update sudo apt-get install -y mssql-server sudo /opt/mssql/bin/mssql-conf setup安装完成后务必验证服务状态systemctl status mssql-server --no-pager重要提示建议Windows和Linux端的SQL Server版本完全一致。我遇到过因小版本差异导致备份文件无法识别的情况最终不得不重新搭建环境。2. Windows端数据库备份实战备份是迁移过程中最关键的步骤这里分享两种经过验证的备份方法以及我踩坑后总结的优化方案。2.1 图形化界面备份SSMS新手推荐使用SSMS的图形界面操作直观且不易出错右键目标数据库 → 任务 → 备份备份类型选择完整备份目标选择磁盘点击添加指定备份路径建议使用.bak扩展名在介质选项中勾选验证备份这是很多教程忽略的关键步骤备份优化技巧大型数据库超过50GB建议启用压缩BACKUP DATABASE YourDB TO DISKC:\backup\YourDB.bak WITH COMPRESSION超大型数据库1TB考虑使用文件组分批备份2.2 T-SQL命令备份对于需要自动化的场景T-SQL命令更灵活。这是我优化过的备份脚本DECLARE backupPath NVARCHAR(255) C:\backup\ DECLARE dbName NVARCHAR(255) YourDB DECLARE fileName NVARCHAR(255) backupPath dbName _ REPLACE(CONVERT(NVARCHAR, GETDATE(), 112) CONVERT(NVARCHAR, GETDATE(), 108), :, ) .bak BACKUP DATABASE dbName TO DISK fileName WITH NAME N完整数据库备份, STATS 10, CHECKSUM, CONTINUE_AFTER_ERROR GO关键参数解析STATS10每完成10%显示进度CHECKSUM验证页校验和强烈建议开启CONTINUE_AFTER_ERROR遇到错误仍继续适用于有损坏的数据库3. 跨系统文件传输方案备份文件传输是Windows到Linux迁移的特有挑战这里提供三种经过实战检验的方案。3.1 SCP安全传输推荐这是最可靠的传输方式我在生产环境多次使用# Windows PowerShell执行 scp C:\backup\YourDB.bak usernamelinux_server:/tmp/如果遇到连接问题按这个顺序排查确认Linux端SSH服务运行sudo systemctl status sshd检查防火墙规则sudo ufw allow 22/tcp测试网络连通性ping linux_server_ip3.2 共享文件夹方案对于超大备份文件100GB建议使用Samba共享# Linux端安装Samba客户端 sudo apt-get install -y cifs-utils sudo mkdir /mnt/win_share sudo mount -t cifs //windows_ip/share /mnt/win_share -o usernamewin_user3.3 传输完整性验证无论采用哪种方式传输后务必验证# Linux端检查文件完整性 md5sum /tmp/YourDB.bak与Windows端生成的MD5对比Get-FileHash C:\backup\YourDB.bak -Algorithm MD54. Linux端数据库还原4.1 备份文件预处理SQL Server在Linux上有严格的权限要求需要将备份文件移动到特定目录sudo mkdir -p /var/opt/mssql/backup sudo chown mssql:mssql /var/opt/mssql/backup sudo mv /tmp/YourDB.bak /var/opt/mssql/backup/4.2 使用sqlcmd还原这是最基础的还原方法适合大多数场景sqlcmd -S localhost -U sa -Q RESTORE DATABASE YourDB FROM DISK/var/opt/mssql/backup/YourDB.bak WITH MOVE YourDB TO /var/opt/mssql/data/YourDB.mdf, MOVE YourDB_log TO /var/opt/mssql/data/YourDB_log.ldf高级还原场景处理包含多个数据文件的情况RESTORE DATABASE YourDB FROM DISK/path/to/backup.bak WITH MOVE datafile1 TO /var/opt/mssql/data/file1.mdf, MOVE datafile2 TO /var/opt/mssql/data/file2.ndf, MOVE logfile TO /var/opt/mssql/data/log.ldf4.3 验证还原结果执行这些检查命令确保数据库完整-- 检查数据库状态 SELECT name, state_desc FROM sys.databases; -- 验证表数据 USE YourDB SELECT COUNT(*) FROM sys.objects; -- 检查文件路径 SELECT name, physical_name FROM sys.master_files;5. 常见问题排查手册根据我的实战经验这些问题最高频出现问题1备份文件无法识别Error: The media family on device /var/opt/mssql/backup/YourDB.bak is incorrectly formed解决方案检查备份时是否启用了压缩但Linux端未安装压缩功能尝试在Windows端重新备份并禁用压缩问题2权限不足Error: Cannot open backup device /var/opt/mssql/backup/YourDB.bak解决方案sudo chown mssql:mssql /var/opt/mssql/backup/YourDB.bak问题3磁盘空间不足Error: There is insufficient free space on disk volume /var to create the database解决方案使用WITH MOVE重定向到其他分区清理日志文件sudo /opt/mssql/bin/mssql-conf traceflag 1806 on问题4字符集冲突Error: Cannot resolve the collation conflict between SQL_Latin1_General_CP1_CI_AS and Latin1_General_CI_AS解决方案RESTORE DATABASE YourDB FROM DISK/path/to/backup.bak WITH MOVE ..., COLLATE SQL_Latin1_General_CP1_CI_AS6. 性能优化建议迁移完成后这些优化能让数据库在Linux上跑得更快内存配置调整sudo /opt/mssql/bin/mssql-conf set memory.memorylimitmb 8192 sudo systemctl restart mssql-serverTempDB优化-- 根据CPU核心数添加TempDB文件 ALTER DATABASE tempdb MODIFY FILE (NAME tempdev, SIZE 4GB); GO DECLARE i INT 1; WHILE i 4 -- 根据核心数调整 BEGIN EXEC(ALTER DATABASE tempdb ADD FILE (NAME tempdev i , FILENAME /var/opt/mssql/data/tempdb i .ndf, SIZE 4GB)); SET i 1; ENDLinux内核参数调优# 编辑/etc/sysctl.conf vm.swappiness 1 vm.dirty_ratio 3 vm.dirty_background_ratio 2记得每次修改配置后都要重启服务sudo systemctl restart mssql-server7. 迁移后的验证清单为确保迁移成功建议执行以下验证步骤基础验证检查所有表数量是否一致验证关键存储过程是否正常执行测试应用程序连接数据一致性检查-- 在源库执行 SELECT OBJECT_NAME(object_id), rowcnt FROM sys.dm_db_partition_stats WHERE index_id 2; -- 在目标库执行相同查询对比结果性能基准测试记录关键查询在原环境的执行时间在新环境执行相同查询对比使用以下DMV检查等待统计SELECT wait_type, wait_time_ms/1000 as wait_time_sec FROM sys.dm_os_wait_stats ORDER BY wait_time_ms DESC;日志监控# 查看错误日志 sudo cat /var/opt/mssql/log/errorlog | grep -i error8. 进阶技巧与注意事项对于复杂迁移场景这些经验可能帮到你超大数据库迁移方案使用WITH STANDBY选项创建热备用数据库考虑使用Always On可用性组实现最小停机迁移对于TB级数据库先迁移架构再使用BCP导出数据特殊对象处理链接服务器需要重新创建SQL Agent作业需要手动迁移数据库邮件配置需重新设置监控建议# 实时监控还原进度另开终端执行 watch -n 5 sudo grep Processed /var/opt/mssql/log/errorlog | tail -n 1回退方案保留原环境至少48小时准备快速回退脚本记录所有配置变更迁移完成后建议运行DBCC检查USE YourDB DBCC CHECKDB WITH NO_INFOMSGS;记得在业务低峰期执行最终切换并提前通知相关团队。根据我的经验完善的沟通计划比技术方案更能确保迁移成功。

相关文章:

SQLServer跨平台迁移实战:从Windows备份到Linux还原的完整指南

1. 迁移前的准备工作 跨平台迁移数据库就像搬家前的打包工作,需要提前确认好物品清单和运输工具。我经历过多次SQL Server从Windows到Linux的迁移,发现90%的问题都出在准备阶段。以下是必须检查的关键点: Windows端必备条件: 确保…...

树莓派4B上跑YOLOv8n:用NCNN实现实时目标检测的完整C++代码与踩坑实录

树莓派4B上跑YOLOv8n:用NCNN实现实时目标检测的完整C代码与踩坑实录 在边缘计算设备上部署深度学习模型一直是开发者面临的挑战,尤其是像树莓派4B这样资源有限的平台。本文将分享如何在树莓派4B上使用NCNN框架部署YOLOv8n模型,并实现实时目标…...

英飞凌TC397芯片深度解析:从规格表到应用实战

1. TC397芯片的硬件架构解析 第一次拿到英飞凌TC397芯片的规格书时,我被密密麻麻的参数表格吓了一跳。作为一款面向汽车电子领域的高性能多核MCU,它的硬件架构设计确实有很多独到之处。经过几个实际项目的磨合,我发现理解这些参数背后的设计逻…...

2026届必备的AI写作神器实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 这会儿,AI正凭借一种从来没有过的态势深切改变着毕业论文的创作生态&#xff0c…...

3个突破性技术让文件传输速度提升280-420%:开源下载工具ctfileGet全解析

3个突破性技术让文件传输速度提升280-420%:开源下载工具ctfileGet全解析 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 当你尝试下载5GB数据集时,是否遇到过进度条停滞在15%的绝…...

别只盯着去噪!拆解DnCNN中的BatchNorm:为什么它能让残差学习在PyTorch里又快又稳?

别只盯着去噪!拆解DnCNN中的BatchNorm:为什么它能让残差学习在PyTorch里又快又稳? 当我们在PyTorch中实现DnCNN时,往往会把注意力集中在残差学习的巧妙设计上,却忽略了BatchNorm(BN)这个看似普通…...

让Windows任务栏呼吸起来:透明美学与智能动态的完美结合

让Windows任务栏呼吸起来:透明美学与智能动态的完美结合 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB 你是否曾盯着Windows…...

深入Java多线程进阶:从锁策略到并发工具全解析

带你深入了解更高级的多线程知识,包括各种锁策略、CAS机制、synchronized原理、JUC工具类等核心内容。这些知识是成为Java高级开发者的必经之路,也是面试中经常考察的重点。1. 常见的锁策略乐观锁 vs 悲观锁这是两种截然不同的并发控制思路:悲…...

从NumPy ndarray到Mojo Tensor:零拷贝内存共享的3层协议解析(Intel XPU/Ampere GPU双平台实测延迟<87ns)

第一章&#xff1a;从NumPy ndarray到Mojo Tensor&#xff1a;零拷贝内存共享的3层协议解析&#xff08;Intel XPU/Ampere GPU双平台实测延迟<87ns&#xff09;零拷贝内存共享并非简单指针传递&#xff0c;而是由硬件抽象层、内存描述符协商层与运行时绑定层共同构成的三重协…...

2026-04-07 GitHub 热点项目精选

/* 全局样式 */* { margin: 0; padding: 0; box-sizing: border-box; }body { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;max-width: 900px; margin: 0 auto; padding: 30px 20px; line-height: 1.7; color: #2d3748;backgro…...

GaussDB /openGauss 与 MySQL、Oracle、PostgreSQL 核心对比表

GaussDB /openGauss 与 MySQL、Oracle、PostgreSQL 核心对比表&#xff08;偏选型实用版&#xff0c;重点看业务适配、迁移成本、国产化、性能&#xff09;一、整体定位对比表格数据库定位适用场景国产化属性GaussDB企业级分布式关系库&#xff0c;软硬协同金融核心、政务、高并…...

Python AOT编译不再依赖LLVM:2026插件如何实现纯Python源码→本地机器码直编?下载链接+SHA3-512校验值全公开

第一章&#xff1a;Python 原生 AOT 编译方案 2026 插件下载与安装Python 原生 AOT&#xff08;Ahead-of-Time&#xff09;编译方案 2026 是 CPython 官方实验性扩展项目&#xff0c;旨在为 Python 提供无需运行时解释器即可生成独立可执行文件的能力。该方案基于 PEP 712 和 L…...

FastAPI 2.0流式响应必须立即升级的4项配置——PyPI最新2.0.10已强制校验,旧版部署将在Q3自动降级为同步模式

第一章&#xff1a;FastAPI 2.0流式响应架构演进与强制校验机制解析FastAPI 2.0 对流式响应&#xff08;StreamingResponse&#xff09;进行了底层重构&#xff0c;将 ASGI 生命周期与 Pydantic v2 的严格校验深度耦合&#xff0c;彻底分离了响应生成与序列化阶段。这一演进使开…...

3分钟打造专业数据大屏:DataRoom开源可视化设计器终极指南

3分钟打造专业数据大屏&#xff1a;DataRoom开源可视化设计器终极指南 【免费下载链接】DataRoom &#x1f525;基于SpringBoot、MyBatisPlus、ElementUI、G2Plot、Echarts等技术栈的大屏设计器&#xff0c;具备目录管理、DashBoard设计、预览能力&#xff0c;支持MySQL、Oracl…...

Zotero PDF Translate:让学术研究跨越语言边界的智能翻译解决方案

Zotero PDF Translate&#xff1a;让学术研究跨越语言边界的智能翻译解决方案 【免费下载链接】zotero-pdf-translate Translate PDF, EPub, webpage, metadata, annotations, notes to the target language. Support 20 translate services. 项目地址: https://gitcode.com/…...

自动驾驶仿真新手必看:OpenSCENARIO 1.0标准场景搭建实战(附51Sim-One配置指南)

自动驾驶仿真实战&#xff1a;从零搭建OpenSCENARIO 1.0标准场景 当一辆自动驾驶汽车在虚拟世界中完成百万公里测试时&#xff0c;背后是无数标准化场景的精确还原。OpenSCENARIO作为自动驾驶仿真领域的"通用语言"&#xff0c;正在改变行业各自为战的局面。本文将带…...

ES6——数组的扩展详解

数组的扩展详解1、Array.from()2、Array.of()3、数组实例的copyWithin()4、数组实例的find()和findIndex()5、数组实例的fill()6、数组实例的entries()、keys()和values()8、数组的空位9、数组推导1、Array.from() Array.from方法用于将两类对象转为真正的数组&#xff1a;类似…...

拉普拉斯变换:从傅里叶到复频域的系统分析利器

1. 从傅里叶到拉普拉斯&#xff1a;为什么我们需要复频域&#xff1f; 第一次接触傅里叶变换时&#xff0c;你可能被它"时域转频域"的魔法惊艳到了——直到遇到一个尴尬问题&#xff1a;当信号不满足绝对可积条件时&#xff08;比如指数增长的信号e^t&#xff09;&am…...

PHP如何利用Redis缓存提升性能?Redis缓存机制在PHP中的实现与优化

将PHP应用中频繁查询的数据库结果、动态内容或资源存储在Redis中&#xff0c;通过直接访问内存而非数据库来显著减少页面加载时间&#xff0c;例如使用phpredis扩展连接Redis并设置缓存键值来优化。例如&#xff0c;代码示例&#xff1a;if ($cachedData $redis->get(user_…...

RePKG技术指南:Wallpaper Engine资源文件解析与转换工具深度解析

RePKG技术指南&#xff1a;Wallpaper Engine资源文件解析与转换工具深度解析 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg RePKG是一款专门为Wallpaper Engine设计的C#开源工具&a…...

多租户下的系统业务开发过程探讨痛

一、背景与问题缘起 MySQL 5.6.51 版本下 2000 万行核心业务表开展新增字段操作&#xff0c;需求为新增BIGINT(19) NOT NULL DEFAULT 0 COMMENT 注释&#xff08;因业务实际需要存储大数值关联字段&#xff09;。 表的核心特性为Java 多线程密集读写&#xff0c;业务请求持续高…...

技术判断力之AI三问涌

认识Pass层级结构 Pass范围从上到下一共分为5个层级&#xff1a; 模块层级&#xff1a;单个.ll或.bc文件 调用图层级&#xff1a;函数调用的关系。 函数层级&#xff1a;单个函数。 基本块层级&#xff1a;单个代码块。例如C语言中{}括起来的最小代码。 指令层级&#xff1a;单…...

文件(内部/外部)存储

Android 文件存储主要分为**内部存储**、**外部存储**(现在叫分区存储)和**其他介质**(如 SD 卡、USB)。理解它们的区别对开发很重要,特别是 Android 10+ 引入的**分区存储**机制。 1. 内部存储 (Internal Storage) 特点:私有、安全、随应用卸载而删除。其他应用和用户…...

从安防到自动驾驶:红外-可见光融合技术落地避坑指南

从安防到自动驾驶&#xff1a;红外-可见光融合技术落地避坑指南 在智能安防和自动驾驶领域&#xff0c;夜间或恶劣天气条件下的视觉感知一直是技术难点。红外与可见光图像融合&#xff08;IVIF&#xff09;技术通过结合两种模态的优势——可见光的高分辨率纹理和红外成像的环境…...

比迪丽LoRA部署教程:WSL2+Windows本地GPU环境全适配方案

比迪丽LoRA部署教程&#xff1a;WSL2Windows本地GPU环境全适配方案 你是不是也想在本地电脑上运行AI绘画&#xff0c;生成自己喜欢的动漫角色&#xff1f;特别是像《龙珠》里的比迪丽这样的经典角色&#xff0c;如果能用自己的电脑随时生成&#xff0c;那该多方便。 今天我就…...

MATLAB伯德图进阶:精准标注谐振点与-3dB带宽的实现方法

1. 伯德图基础与谐振点概念解析 伯德图是控制系统工程师最常用的频率特性分析工具之一&#xff0c;它由幅频特性和相频特性两条曲线组成。我第一次接触伯德图是在研究生阶段的自动控制原理课上&#xff0c;当时教授在黑板上画出的那条神奇的曲线&#xff0c;让我对频率响应分析…...

如何用Python+Neo4j构建医疗知识图谱?从数据清洗到因果推断实战

医疗知识图谱实战&#xff1a;用PythonNeo4j实现药品副作用因果推断 在医疗AI领域&#xff0c;知识图谱正成为连接海量医学数据与临床决策的桥梁。当一位患者同时服用多种药物时&#xff0c;如何准确预测潜在的药物相互作用&#xff1f;当流行病学研究发现某种症状与基因突变相…...

忍者像素绘卷企业应用:游戏公司快速产出像素风角色立绘的落地实践

忍者像素绘卷企业应用&#xff1a;游戏公司快速产出像素风角色立绘的落地实践 1. 像素艺术在游戏行业的价值与挑战 像素艺术作为一种独特的视觉风格&#xff0c;近年来在游戏行业迎来了复兴。从独立游戏到3A大作&#xff0c;越来越多的开发者选择用像素风格唤起玩家的怀旧情感…...

Python数据库编程全面指南:从SQL到NoSQL

Python数据库编程全面指南&#xff1a;从SQL到NoSQL 1. 背景介绍 数据库是现代应用程序的核心组件之一&#xff0c;用于存储和管理数据。Python作为一种广泛使用的编程语言&#xff0c;提供了丰富的库和工具来与各种数据库进行交互。本文将全面介绍Python数据库编程&#xff0c…...

从零搭建Chiplet系统?保姆级梳理UCIe实战中的那些“坑”:Sideband流控、时钟门控与多模块链路

从零搭建Chiplet系统&#xff1a;UCIe实战中的关键挑战与解决方案 在半导体行业追求更高性能、更低功耗的今天&#xff0c;Chiplet技术已成为突破传统单芯片设计瓶颈的重要路径。作为连接不同Chiplet的"桥梁"&#xff0c;UCIe(Universal Chiplet Interconnect Expres…...