百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

探索SQL Server 2022在Ubuntu 20.04上的安装、配置、备份与常见问题

nanshan 2025-03-11 19:21 11 浏览 0 评论

最近新项目要上线,考虑成本,放弃云数据库,选择自行安装,数据库选择SQL Server 2022,系统选择Ubuntu 20.04。

//SQL Server 2022文档地址https://learn.microsoft.com/zh-cn/sql/sql-server/?view=sql-server-ver16

SQL Server 2022 安装

SQL Server 2022先决条件:服务器内存至少需要2 GB 。

1、导入公共存储库 GPG 密钥

$ wget -qO- https://packages.microsoft.com/keys/microsoft.asc | sudo tee /etc/apt/trusted.gpg.d/microsoft.asc

2、注册 SQL Server Ubuntu 存储库

sudo add-apt-repository "$(wget -qO- https://packages.microsoft.com/config/ubuntu/20.04/mssql-server-2022.list)"

3、运行以下命令以安装 SQL Server

sudo apt-get updatesudo apt-get install -y mssql-server

4、等待安装完成后,运行 mssql-conf setup

按照提示选择数据库版本及设置 SA 密码。其中数据库版本Evaluation、Developer 和 Express 版为免费版本。

sudo /opt/mssql/bin/mssql-conf setup

注意:SA 账户密码需要最小长度为 8 个字符,包括大写和小写字母、十进制数字和/或非字母数字符号。

此时如果正常,那恭喜您!但我尝试了好几次,都卡在了这里,系统提示:error while loading shared libraries: liblber-2.4.so.2

网上查了一堆资料,最终找到了解决办法:

下载安装libldap-2.4-2_2.4.47+dfsg.4-1+eagle_amd64包

wget https://community-packages.deepin.com/deepin/pool/main/o/openldap/libldap-2.4-2_2.4.47%2Bdfsg.4-1%2Beagle_amd64.debsudo dpkg -i libldap-2.4-2_2.4.47+dfsg.4-1+eagle_amd64.deb

再次运行 mssql-conf setup,继续设置,再次遇到问题,系统提示:error while loading shared libraries: libssl1.1,解决办法:

下载安装libssl1.1_1.1.1-1ubuntu2.1~18.04.23_amd64包

wget http://security.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1-1ubuntu2.1~18.04.23_amd64.debsudo dpkg -i libssl1.1_1.1.1-1ubuntu2.1~18.04.23_amd64.deb

最后运行 mssql-conf setup,完成设置,没再报错。

5、验证服务是否正常运行

systemctl status mssql-server --no-pager

此时SQL Server 已在 Ubuntu 上正常运行。

6、打开 SQL Server TCP 端口(默认值为 1433)

开启内网远程访问,我们使用的是腾讯云,需要设置安全组,内网放行1433端口。

SQL Server 2022 配置

SQL Server 数据库安装完成后,还需要进行一些常规配置。

1、启用 SQL Server 代理

为了进行日常数据备份等任务,我们需要开启代理:

sudo /opt/mssql/bin/mssql-conf set sqlagent.enabled true//重启服务生效sudo systemctl restart mssql-server

2、更改默认数据或日志目录位置

使用 filelocation.defaultdatadir 和 filelocation.defaultlogdir 设置可更改创建新数据库和日志文件的位置。默认路径为:/var/opt/mssql/data。可以使用以下步骤进行修改:

//为新的数据库数据和日志文件创建目标目录sudo mkdir /home/d/mssql/data
//将目录的所有者和组更改为 mssql 用户sudo chown mssql /home/d/mssql/datasudo chgrp mssql /home/d/mssql/data
//使用 mssql-conf 通过 set 命令更改默认数据目录sudo /opt/mssql/bin/mssql-conf set filelocation.defaultdatadir /home/d/mssql/data
//使用 mssql-conf 通过 set 命令更改默认日志文件目录sudo /opt/mssql/bin/mssql-conf set filelocation.defaultlogdir /home/d/mssql/data
//重启服务生效sudo systemctl restart mssql-server

3、更改生成备份文件的默认位置

使用 filelocation.defaultbackupdir 设置可更改生成备份文件位置。默认路径为:/var/opt/mssql/data。可以使用以下步骤进行修改:

//为新的备份文件创建目标目录sudo mkdir /home/d/mssql/bak/ -p
//将目录的所有者和组更改为 mssql 用户sudo chown mssql /home/d/mssql/backupsudo chgrp mssql /home/d/mssql/backup
//使用 mssql-conf 通过 set 命令更改默认备份目录sudo /opt/mssql/bin/mssql-conf set filelocation.defaultbackupdir /home/d/mssql/backup
//重启 SQL Server 服务sudo systemctl restart mssql-server

更多配置请查看文档:

https://learn.microsoft.com/zh-cn/sql/linux/sql-server-linux-configure-mssql-conf?view=sql-server-ver16

4、设置数据库自动备份

备份是保护数据的唯一方法,为了防止数据丢失和保障业务的持续性,需要对数据进行备份。这里采用的方案是按天进行完整备份,按小时进行差异备份,在还原数据时,只需要选择完全备份和差异备份集,打上勾后进行还原即可

完整备份是指备份整个数据库,包括表、索引、视图和存储过程等所有数据库对象,完整备份所需时间较长,占用空间也最多,但恢复数据时只需还原单个文件,因此最为简单和快速。

差异备份是针对上一次完全备份来说的,它只备份自上次完全备份之后发生更改的数据。因此,差异备份比完全备份小,还原也比完全备份快且对性能影响最小。

我使用 SQL Server 代理中提供的作业来执行计划,新建两个作业,一个执行完整备份任务,一个执行差异备份任务。如下图所示


首先、设置作业的步骤,我们可以在步骤中添加执行备份务的脚本。

然后、设置作业计划,指定脚本执行的时间周期及间隔。

这样就可以了,以上为演示截图。

SQL Server 完整备份脚本:

DECLARE @Path NVARCHAR(50) = '/home/d/mssql/bak/test_';SET @Path= CONCAT(@Path,CONVERT(NVARCHAR(10),GETDATE() ,120),'.bak');

BACKUP DATABASE test TO DISK = @Path WITH FORMAT; GO

这段脚本的功能是将名为 test 的数据库备份到指定路径下的文件,备份文件的路径是 /home/d/mssql/bak/test_YYYYMMDD.bak,其中 YYYYMMDD 是当前日期的形式。执行备份时,会覆盖原有备份文件,重新备份。

SQL Server 差异备份脚本:

DECLARE @Path NVARCHAR(50) = '/home/d/mssql/bak/test_';SET @Path= CONCAT(@Path,CONVERT(NVARCHAR(10),GETDATE() ,120),'.bak');
BACKUP DATABASE test TO DISK = @Path WITH DIFFERENTIAL; GO

这段代码的功能是在 test 数据库上一次完整备份的基础上,进行差异备份,通过 TO DISK = @Path 指定完整备份路径。执行备份时,SQL Server 会把差异备份的文件追加到有备份文件中。

在脚本中使用 EXPIREDATE 指令可以设置备份的过期日期,当备份文件超出指定的备份的过期日期时,SQL Server 将清除备份集中满足日期束缚的备份作业。例如:

DECLARE @Path NVARCHAR(50) = '/home/d/mssql/bak/test_';SET @Path= CONCAT(@Path,CONVERT(NVARCHAR(10),GETDATE() ,120),'.bak');
DECLARE @ExpiryTime DATETIME2(7)=DATEADD(mm, 1, GETDATE());
BACKUP DATABASE test TO DISK = @Path WITH EXPIREDATE =@ExpiryTime;GO

同时在脚本中使用 COMPRESSION 指令可设置备份文件自动压缩,还可以指定压缩的算法例如:

//参考文档:https://learn.microsoft.com/zh-cn/sql/relational-databases/integrated-acceleration/use-integrated-acceleration-and-offloading?view=sql-server-ver15
//使用默认MS_XPRESS压缩选项WITH COMPRESSION (ALGORITHM = MS_XPRESS);

SQL Server 数据库的备份和还原文档:

https://learn.microsoft.com/zh-cn/sql/relational-databases/backup-restore/back-up-and-restore-of-sql-server-databases?view=sql-server-ver16

Linux 上的 SQL Server 的性能最佳做法和配置指南:

https://learn.microsoft.com/zh-cn/sql/linux/sql-server-linux-performance-best-practices?view=sql-server-linux-ver16


文章出自猿惑豁微信公众号

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: