【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

这篇具有很好参考价值的文章主要介绍了【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本系列博文还在更新中,收录在专栏:#MS-SQL Server 专栏中。

本系列文章列表如下:

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作
【SQL Server】数据库开发指南(一)数据库设计的核心概念和基本步骤
【SQL Server】数据库开发指南(二)MSSQL数据库开发对于库、表、数据类型、约束等相关操作
【SQL Server】数据库开发指南(三)面向数据分析的 T-SQL 编程技巧与实践
[ 云原生 | Docker ] 构建高可用性的 SQL Server:Docker 容器下的主从同步实现指南
【SQL Server】数据库开发指南(五)T-SQL 高级查询综合应用与实战
【SQL Server】数据库开发指南(六)索引和视图的使用技巧、方法与综合应用
【SQL Server】数据库开发指南(七)MS-SQL存储过程全面解析:种类、优点和创建方法详解
【SQL Server】数据库开发指南(八)高级数据处理技术 MS-SQL 事务、异常和游标的深入研究
【SQL Server】数据库开发指南(九)详细讲解 MS-SQL 触发器的基础概念与应用场景

前言

SQLServer 虽然是微软开发的,但是目前已经支持 Windows、Linux、MACOS等。本文详细介绍在 Linux 环境下,如何对 SQL Server 进行安装、升级、回滚、卸载等操作。

一、Linux 下安装 MSSQL

文章演示的是在 CentOS8 环境,所使用的 SQL Server 版本是:SQL Server 2019。

1.1 添加 Microsoft 的 yum 存储库

在命令行中输入以下命令以添加 Microsoft 的 yum 存储库:

[root@hecs-69777 ~]# curl -o /etc/yum.repos.d/mssql-server.repo https://packages.microsoft.com/config/rhel/8/mssql-server-2019.repo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   231  100   231    0     0    363      0 --:--:-- --:--:-- --:--:--   363

1.2 查看repo文件,确认repo文件信息

[root@hecs-69777 ~]# cat /etc/yum.repos.d/mssql-server.repo
[packages-microsoft-com-mssql-server-2019]
name=packages-microsoft-com-mssql-server-2019
baseurl=https://packages.microsoft.com/rhel/8/mssql-server-2019/
enabled=1
gpgcheck=1
gpgkey=https://packages.microsoft.com/keys/microsoft.asc[root@hecs-69777 ~]#

1.3 使用以下命令安装 mssql-server 包

[root@hecs-69777 ~]# sudo yum install -y mssql-server
packages-microsoft-com-mssql-server-2019                                                                                                                         1.2 MB/s | 5.5 MB     00:04
Last metadata expiration check: 0:00:04 ago on Tue 28 Mar 2023 05:59:50 PM CST.
Dependencies resolved.
...
pilot process
...
+--------------------------------------------------------------+
Please run 'sudo /opt/mssql/bin/mssql-conf setup'
to complete the setup of Microsoft SQL Server
+--------------------------------------------------------------+
...
pilot process
...
Complete!

1.5 执行 SQL Server 初始化操作

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

1.6 选择所要安装的 SQL Server 版本

此步骤的安装版本不是MSSQL的版本号,而是如下图所示的,在所 1 ~ 8 选项中的某一个版本,其中包括license信息以及企业版本等相关的版本,本文为了演示选择安装的是免费的开发版本(无试用期限限制)。

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

1.7 设置 sa 账号密码

在选择完所要安装的MSSQL版本后,会出现确实是否接受试用协议,直接输入 y,表示接受相关协议,接下来在下一步输入sa账号密码,密码长度不能低于8个字符。

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

1.8 确认安装状态

进行完上述安装后,我们确认两点

  • 确认 SQL Server 的使用端口号:1433
  • 确认 SQL Server 服务状态
1.8.1 查看 SQL Server 监听端口

如果成功完成安装 SQL Server,在端口列表中,可以看到 1433 的端口号。

[root@hecs-69777 ~]# netstat -ntlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:1433            0.0.0.0:*               LISTEN      72597/sqlservr
tcp        0      0 127.0.0.1:1434          0.0.0.0:*               LISTEN      72597/sqlservr
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1627/sshd
tcp        0      0 127.0.0.1:1431          0.0.0.0:*               LISTEN      72597/sqlservr
tcp6       0      0 :::1433                 :::*                    LISTEN      72597/sqlservr
tcp6       0      0 ::1:1434                :::*                    LISTEN      72597/sqlservr
tcp6       0      0 :::22                   :::*                    LISTEN      1627/sshd
tcp6       0      0 ::1:1431                :::*                    LISTEN      72597/sqlservr

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

1.8.2 查看 SQL Server 服务状态

SQL Server 安装成功后,其服务状态为:active(running)状态。


[root@hecs-69777 ~]# systemctl status mssql-server
● mssql-server.service - Microsoft SQL Server Database Engine
   Loaded: loaded (/usr/lib/systemd/system/mssql-server.service; enabled; vendor preset: disabled)
   Active: active (running) since Tue 2023-03-28 18:12:45 CST; 4h 32min ago
     Docs: https://docs.microsoft.com/en-us/sql/linux
 Main PID: 72573 (sqlservr)
    Tasks: 159
   Memory: 774.0M
   CGroup: /system.slice/mssql-server.service
           ├─72573 /opt/mssql/bin/sqlservr
           └─72597 /opt/mssql/bin/sqlservr

Mar 28 18:18:02 hecs-69777 sqlservr[72573]: [195B blob data]

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

二、安装 SQL Server 客户端工具

如果在某一个 Linux 机器中,需要远程连接 SQL Server,需要安装客户端之后才可以进行连接,具体的操作步骤如下 。

2.1 下载客户端工具 yum 源文件

添加 Microsoft 的 SQL Server 客户端工具存储库。在终端中输入以下命令:

[root@hecs-69777 ~]# curl -o /etc/yum.repos.d/msprod.repo https://packages.microsoft.com/config/rhel/8/prod.repo
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   192  100   192    0     0    343      0 --:--:-- --:--:-- --:--:--   342

2.2 安装 SQL Server 客户端工具

[root@hecs-69777 ~]# sudo yum install -y mssql-tools unixODBC-devel
packages-microsoft-com-prod                                                                                                                                      671 kB/s | 6.0 MB     00:09
Last metadata expiration check: 0:00:09 ago on Tue 28 Mar 2023 11:40:11 PM CST.
Dependencies resolved.
...
pilot process
...
Do you accept the license terms? (Enter YES or NO)
yes
...
pilot process
...
Do you accept the license terms? (Enter YES or NO)
yes

Complete!

2.3 配置环境变量

为了我们可以在任意路径下可以执行 sqlcmd 命令进行本地连接,我们需要配置相关的环境变量。

客户端工具默认安装路径:/opt/mssql-tools/bin/

在终端中输入以下命令:

[root@hecs-69777 ~]# echo 'export PATH="$PATH:/opt/mssql-tools/bin"' >> ~/.bashrc
[root@hecs-69777 ~]# source ~/.bashrc
[root@hecs-69777 ~]# which sqlcmd
/opt/mssql-tools/bin/sqlcmd

三、连接测试

3.1 本地连接 SQL Server

本地登录使用参数 -S 指定 ip 地址,-U 指定用户,-P指定输入密码,不带-P则会进入输入密码交互模式。
登录成功显示1>,如果需要退出则可以使用quit:exit,此模式下除了go命令直接输入,其他命令则需要使用冒号开头,例如输入:help获取帮助。

[root@hecs-69777 ~]# sqlcmd -S 127.0.0.1 -U sa
Password:
1>
  • 查看数据库版本

本地连接状态下输入select @@version和go可以查看到版本信息。

[root@hecs-69777 ~]# sqlcmd -S 127.0.0.1 -U sa
Password:
1>
2>
3> select @@version
4> go

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

3.2 远程连接 SQL Server

3.2.1 开启远程连接权限
3.2.1.1 设置 SQL Server 远程链接权限

使用 sa 账号登陆进入 MSSQL,进入后执行如下语句,开启远程连接访问权限。

1> EXEC sp_configure 'remote access', 0;
2> GO
Configuration option 'remote access' changed from 1 to 0. Run the RECONFIGURE statement to install.
1> RECONFIGURE;
2> GO
3.2.1.2 设置防火墙白名单(如果有开启防火墙)

如果你的机器里有开启防火墙配置的话,那么需要添加 1433 端口在防火墙白名单内,具体执行如下命令:

[root@hecs-69777 ~]# sudo firewall-cmd --zone=public --add-port=1433/tcp --permanent
success
[root@hecs-69777 ~]# sudo firewall-cmd --reload
success
3.2.1.3 设置云服务器安全组规则(如果有)

注意:如果SQL Server 安装在某些云服务器中,注意设置其安全组的入出站规则,如果没有在安全组中设置1433的白名单,那么就会出现连接 SQL Server 失败的错误。

例如修改华为云的 HECS 安全组规则(如果有设置):

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

3.2.2 新建 SQL Server 连接

本文为了演示使用的是 Navicat 进行连接演示,根据个人习惯可以自行选择连接工具。
在数据库连接窗口中输入数据库 ip 地址,账户密码,管理员默认账户名sa。

【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

连接成功后,即可执行SQL语句。
【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作

五、其他操作

本部分非必要可以跳过,如果有一天有需要可以考虑来翻出来本文

5.1 完全卸载 SQL Server

5.1.1 停止 SQL Server 服务
sudo systemctl stop mssql-server
5.1.2 卸载 SQL Server 包

为了卸载 Linux 上运行的 mssql-server 包,使用如下命令:

sudo yum remove mssql-server
5.1.3 删除 SQL Server 数据文件

SQL Server 默认的数据文件存储在 /var/opt/mssql 目录下。可以使用以下命令来删除这些文件:

sudo rm -rf /var/opt/mssql
5.1.5 删除 SQL Server 配置文件

SQL Server 的配置文件位于 /etc/opt/mssql 目录下。可以使用以下命令来删除这些文件:

sudo rm -rf /etc/opt/mssql
5.1.6 删除 SQL Server 日志文件

SQL Server 的日志文件位于 /var/log/mssql 目录下。可以使用以下命令来删除这些文件:

sudo rm -rf /var/log/mssql

5.2 升级 mssql-server 包到最新版本

进行 SQL Server 升级操作的时候,可以直接使用如下命令:

sudo yum update mssql-server

该命令会下载并安装最新包,并替换 /opt/mssql/ 下的二进制文件。用户生成的数据库和系统数据库不会受该操作的影响。

5.3 回滚 SQL Server 到之前的某个版本

5.3.1 识别降版的版本号

识别你想降级到的 SQL Server 版本号。对应的版本号列表:点击这里(官方版本号)。

5.3.2 执行降版操作

执行如下命令进行降级到之前的某一个SQL Server版本。将<version_number>替换为上一步骤中的版本号。

sudo yum downgrade mssql-server-<version_number>.x86_64

注意:这个操作只支持降级到相同主版本内的某一个小版本,如某个大(主)版本号为:SQL Server 2017、SQL Server 2019、SQL Server 2022。

最后总结

用一个问答来总结该篇文章

为什么我要选择 SQL Server 数据库,而不是 Oracle,或者 MySQL?

完整回答请阅读以下文章:
https://www.sqlservercentral.com/forums/topic/why-should-i-go-for-ms-sql-server-not-for-oracle-and-mysql文章来源地址https://www.toymoban.com/news/detail-401493.html

到了这里,关于【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Linux CentOS系统安装SQL Server并结合内网穿透实现公网访问本地数据

    🔥 博客主页 : 小羊失眠啦. 🎥 系列专栏 : 《C语言》 《数据结构》 《C++》 《Linux》 《Cpolar》 ❤️ 感谢大家点赞👍收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 简单几步实现在Linux cento

    2024年02月19日
    浏览(49)
  • Linux centos安装SQL Server数据库,结合cpolar内网穿透实现公网访问

    简单几步实现在Linux centos环境下安装部署sql server数据库,并结合cpolar内网穿透工具,创建安全隧道将其映射到公网上,获取公网地址,实现在外异地远程连接家里/公司的sqlserver数据库,而无需公网IP,无需设置路由器,亦无需云服务器。 下载 SQL Server 2022 (16.x) Red Hat 存储库配

    2024年02月08日
    浏览(47)
  • windows平台下对dll进行数字签名

    DLL文件进行数字签名的好处包括以下几个方面: 确认文件的来源:数字签名可以验证DLL文件的发布者身份,确保该文件来自合法的发布者。 防止文件篡改:数字签名可以防止DLL文件被篡改或者损坏,确保该文件是原始的,没有被人为修改过。 提高软件安全性:数字签名可以

    2024年02月11日
    浏览(41)
  • 使用Python与SQL Server进行连接和交互

    获取数据的几种方式: cursor.fetchone() # 以元组形式返回一条记录,如果没有数据,则返回None cursor.fetchmany(num) # 以列表形式返回多条记录,列表每个元素都是一个元组,包含一条记录 cursor.fetchall() # 以列表形式返回所有记录,列表每个元素都是一个元组,包含一条记录 游标

    2024年02月16日
    浏览(41)
  • 数据库SQL Server实验报告 之 SQL语言进行简单查询(3/8)

    实验名称          SQL语言进行简单查询 注意:原版word在下载资源里面(免费下载) 实验目的及要求: 掌握各种查询的SQL脚本写法,包括SELECT、FROM、WHERE、GROUP BY、HAVING子句的用法,特别要求比较内连接、外连接的结果 在XSGL数据库中,使用各种查询条件完成指定的查询

    2024年02月02日
    浏览(63)
  • 【Sql Server】通过Sql语句批量处理数据,使用变量且遍历数据进行逻辑处理

    欢迎来到《小5讲堂》,大家好,我是全栈小5。 这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解, 特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。 温馨提示:博主能力有限,理解水

    2024年03月15日
    浏览(47)
  • RabbitMQ系列(19)--实现在RabbitMQ宕机的情况下对消息进行处理

    前言:在生产环境中由于一些不明原因,导致RabbitMQ重启的情况下,在RabbitMQ重启期间生产者投递消息失败,生产者发送的消息会丢失,那这时候就需要去想在极端的情况下,RabbitMQ集群不可用的时候,如果去处理投递失败的消息。 1、在config包里新建一个名为ConfirmConfig的类用

    2024年02月15日
    浏览(52)
  • SQL Server 创建链接服务器 链接mysql 进行数据同步

    一个项目的产品迭代,因为迭代过程中两套系统同时使用,两套系统设计使用的数据库不同,从Sqlserver改到mysql了,所以需要将sqlserver的业务数据定时同步到mysql中。 当问题产生了,作为一个合格的码农,第一时间就是想着做一个程序实现数据同步,但是处于自身不叫懒惰,

    2024年02月14日
    浏览(43)
  • Linux下对mmap封装使用

    mmap即memory map,是一种内存映射文件的技术。mmap可以将一个文件或者其它对象映射到进程的地址空间,进而实现磁盘地址和进程虚拟地址的一一对应关系。通过使用mmap技术,我们可以让不同进程通过映射到同一个普通文件的方式实现共享内存,普通文件被映射到进程地址空间

    2024年02月07日
    浏览(45)
  • 在Linux中进行OpenSSH升级

    由于OpenSSH有严重漏洞,因此需要升级OpenSSH到最新版本。 OpenSSL和OpenSSH都要更新,OpenSSH依赖于OpenSSL。 第一步,查看当前的OpenSSH服务版本。 命令:ssh -V 第二步,安装、启动telnet,关闭安全文件,防止因卸载OpenSSH而导致无法登录主机。 # 安装、启动telnet 命令:yum -y install te

    2024年04月10日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包