个性化配置你的SQL Server on Linux

问题引入

这天老鸟满面春风找到菜鸟:“鸟儿啊,看你最近研究SQL Server On Linux如鱼得水,干得不错啊。不过呢,这是一个张扬个性的年代,要创新,要与众不同,那你怎么在Linux平台对SQL Server做个性化的配置吧?比如,我们数据库文件存放的路径,备份文件存放的路径,排序规则等等”。
“鸟哥,今天心情不错啊,捡到金子啦?得了,这就按您的指示办去”。

问题分析

老鸟这个需求还是很有现实意义的,比如在Windows平台,我们会标准化SQL Server数据库文件存放的路径,定制化排序规则等。比如:mdf文件会存放在D:\DATA\DBName\SQL目录,ldf文件会存放在D:\DATA\DBName\LOG目录下。让我们看看SQL Server On Linux是怎么张扬它的个性化配置的。

个性化配置

在个性化配置之前,让我们来看SQL Server On Linux的默认配置是什么样子。

数据存放位置和排序规则

查看数据库物理文件的存放位置,只需要访问视图sys.master_files,默认排序规则访问视图sys.databases。脚本如下:

USE masterGOSELECT database_name = db_name(database_id) ,file_name = name,physical_name 
FROM sys.master_filesSELECT database_name = name, collation_name 
FROM sys.databases;  

查询结果截图如下:

这里必须要吐槽,不吐不快,从SSMS查看数据库的物理位置,有两点很难理解,当然不知道微软后续的发版会不会改善:
Windows是使用反斜线“\”来划分目录结构,而Linux系统使用的是正斜线“/”。
查询出来的结果集目录中会强制添加C:盘地址。
最终的对应关系是:Linux上的/var/opt/mssql/data对应于Windows上的目录C:\var\opt\mssql\data。吐槽截图如下:

个性化配置脚本

在最开始做个性化配置脚本时候,我所有的这些目录是放在/var/opt/mssql/data/这个根目录下,后来发现这种做法有一个很大的坑,后面的“一个深坑”错误处理时会讲到。后来,我把根目录放到/data/下,算是踩过了这个坑。这么大的一个深坑,微软的攻城狮,你出来,我们聊聊,我保证不打残你。

# vim reconfMSSQLOnLinux.sh#!/bin/sh# --------------------------------------------## purpose: # this script is for MSSQL on Linux# reconfiguration.## --------------------------------------------# change mssql-server listen on 1435 from 1433echo "change mssql-server listen port to 1435"/opt/mssql/bin/mssql-conf set tcpport 1435# Change the default data directory locationecho "change mssql-server default data directory location"mkdir /data/SQL
chown mssql /data/SQL && chgrp mssql /data/SQL/opt/mssql/bin/mssql-conf set defaultdatadir /data/SQL# Change the default log directory locationecho "change mssql-server default log directory location"mkdir /data/LOG
chown mssql /data/LOG && chgrp mssql /data/LOG/opt/mssql/bin/mssql-conf set defaultlogdir /data/LOG# Change the default dump directory locationecho "change mssql-server default dump directory location"mkdir /data/DUMP
chown mssql /data/DUMP && chgrp mssql /data/DUMP/opt/mssql/bin/mssql-conf set defaultdumpdir /data/DUMP# Change the default backup directory locationecho "change mssql-server default backup direcotry location"mkdir /data/BACKUP
chown mssql /data/BACKUP && chgrp mssql /data/BACKUP/opt/mssql/bin/mssql-conf set defaultbackupdir /data/BACKUP# Enable/Disable traceflagsecho "mssql-server trace flag 1222 & 1204 enabled"/opt/mssql/bin/mssql-conf traceflag 1222 1204 on# Change the SQL Server collationecho "change mssql-server default collation"/opt/mssql/bin/mssql-conf set-collation[root@localhost ~]# chmod +x reconfMSSQLOnLinux.sh

执行配置脚本

仔细看这个返回结果,也是在根目录/data/前加了盘符C:,始终觉得怪怪的。最后,输入新的排序规则确认后,一会儿SQL Server就会完成个性化的设置并重启。

# sh reconfMSSQLOnLinux.shchange mssql-server listen port to 1435Applying value '1435' to 'tcpport'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
change mssql-server default data directory location
Applying value 'C:\data\SQL' to 'defaultdatadir'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
change mssql-server default log directory location
Applying value 'C:\data\LOG' to 'defaultlogdir'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
change mssql-server default dump directory location
Applying value 'C:\data\DUMP' to 'defaultdumpdir'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
change mssql-server default backup direcotry location
Applying value 'C:\data\BACKUP' to 'defaultbackupdir'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
mssql-server trace flag 1222 & 1204 enabled
Applying traceflag '1222'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
Applying traceflag '1204'.
Restart of SQL Server is required to apply this setting. Please run 'systemctl restart mssql-server.service' when ready.
change mssql-server default collation
This option will change the collation for SQL Server and RESTART the server. Continue [Yes/No]: Yes
Enter the collation: Chinese_PRC_CI_AS

一个深坑

在最开始测试过程中,所有目录放到根目录/var/opt/mssql/data/下,执行会出现以下异常信息,无法创建tempdb,错误的原因是在C:\data\SQL\目录下不存在tempdb.mdf文件。第一反应是,什么东西啊?C:\data\SQL\tempdb.mdf?我没有配置任何文件放到这个目录啊,还C盘呢?你以为是你的Windows操作系统吗?
最后聪明伶俐,人见人爱,车间车爆胎的菜鸟,大胆猜测,小心求证,终于搞明白了。反过来猜想,估计微软这帮攻城狮只截取了最后两层目录,比如/var/opt/mssql/data/SQL,他们会把/data/SQL做为数据库数据文件的存放目录,实在是令人着急。来看看错误信息:

2016-12-14 09:24:35.40 spid6s      Error: 5123, Severity: 16, State: 1.
2016-12-14 09:24:35.40 spid6s      CREATE FILE encountered operating system error 31(A device attached to the system is not functioning.) while attempting to open or create the physical file 'C:\data\SQL\tempdb.mdf'.2016-12-14 09:24:35.44 spid6s      Error: 17204, Severity: 16, State: 1.2016-12-14 09:24:35.44 spid6s      FCB::Open failed: Could not open file C:\data\SQL\tempdb.mdf for file number 1.  OS error: 2(The system cannot find the file specified.).2016-12-14 09:24:35.44 spid6s      Error: 5120, Severity: 16, State: 101.2016-12-14 09:24:35.44 spid6s      Unable to open the physical file "C:\data\SQL\tempdb.mdf". Operating system error 2: "2(The system cannot find the file specified.)".2016-12-14 09:24:35.45 spid6s      Error: 1802, Severity: 16, State: 4.2016-12-14 09:24:35.45 spid6s      CREATE DATABASE failed. Some file names listed could not be created. Check related errors.2016-12-14 09:24:35.45 spid6s      Could not create tempdb. You may not have enough disk space available. Free additional disk space by deleting other files on the tempdb drive and then restart SQL Server. Check for additional errors in the operating system error log that may indicate why the tempdb files could not be initialized.

截个图留恋,证明下:

有了这层意思的精神领会以后,解决问题的方法就So easy了。

# mkdir -p /data/SQL# mkdir -p /data/LOG# chown mssql -R /data# chgrp mssql -R /data

再次重试个性化配置脚本sh reconfMSSQLOnLinux.sh,这次总算成功了,谢天谢地。

打开防火墙

为了让外部客户端SSMS连接重新配置后的实例,请打开防火墙1435端口

[root@localhost ~]# firewall-cmd --zone=public --add-port=1435/tcp --permanentsuccess[root@localhost ~]# firewall-cmd --reloadsuccess

再次检查数据存放位置

重新配置完成后,接下来做如下测试:
创建数据:看看数据库mdf和ldf文件会不会放到/data/SQL和/data/LOG目录下。
备份数据库:看看数据库备份文件会不会放到/data/BACKUP目录。
排序规则检查:检查数据库是否是新的排序规则Chinese_PRC_CI_AS

create database TestDB2;
GOBACKUP DATABASE [TestDB2] TO DISK = N'TestDB2_full_20161213.bak' WITH NOFORMAT, NOINIT, NAME = 'TestDB2-full', SKIP, NOREWIND, NOUNLOAD, STATS = 10BACKUP LOG [TestDB2] TO  DISK = N'TestDB2_LogBackup_20161213.bak' WITH NOFORMAT
, NOINIT,  NAME = N'TestDB2_LogBackup_2016-12-13', NOSKIP, NOREWIND, NOUNLOAD ,  STATS = 5GOUSE masterGOSELECT database_name = db_name(database_id) ,file_name = name,physical_name 
FROM sys.master_filesSELECT database_name = name, collation_name 
FROM sys.databases;  

查询结果展示如下:

使用Linux的tree命令看看/data目录文件结构,如下图展示:

从SSMS查询结果和Linux目录结构来看,所有现象都满足预期,菜鸟对SQL Server On Linux进行了个性化配置。

写在最后

过程历经艰辛,但最终我们到达了成功的彼岸,总算对SQL Server On Linux进行了个性化的配置。就像我们最开始研究Linux版SQL Server说的那样,他还是只个刚出生的孩子,还有很多不完善的地方,甚至看起来还有点怪异。但是,让我们充满期望,给予宽容和友善让他茁壮成长。

 

相关文章: 

  • SQL Server 急救包(First Responder Kit)入门教程

  • SQL Server on Linux 理由浅析

  • SQLServer On Linux Package List on CentOS

  • SQL Server on Linux的文件和目录结构

原文地址:https://yq.aliyun.com/articles/67204


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326800.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

idea查看读取的那个nacos配置和yaml配置 naocos 日志

logging.level.com.alibaba.cloud.nacos.client.NacosPropertySourceBuilderdebug

二叉树的前中后序查找+思路分析

思路分析 代码实现 package com.atguigu.tree;/*** 创建人 wdl* 创建时间 2021/3/24* 描述*/ public class BinaryTreeDemo {public static void main(String[] args) {//先需要创建一颗二叉树BinaryTree binaryTree new BinaryTree();//创建需要的节点HeroNode root new He…

spark sql uv_使用Spark Streaming SQL进行PV/UV统计

作者:关文选,花名云魄,阿里云E-MapReduce 高级开发工程师,专注于流式计算,Spark Contributor1.背景介绍PV/UV统计是流式分析一个常见的场景。通过PV可以对访问的网站做流量或热点分析,例如广告主可以通过PV…

二叉树删除节点+思路分析

思路分析 代码实现 ![在这里插入代码片](https://img-blog.csdnimg.cn/20210325193201194.png?x-oss-processimage/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1NzgzNjYw,size_16,color_FFFFFF,t_70)

ddm模型公式_简单判断目前行情——从股利贴现模型切入

本文目录:1.介绍股利贴现模型;2.以贵州茅台为例根据现有情况估计模型内部各参数;3.得出结论;一、股利贴现模型(DDM)我们知道给一项资产定价最朴素的想法是将它未来产生的所有现金流以一定的贴现率贴现至当前…

分布式事务与一致性算法Paxos amp; raft amp; zab

1.CAP原理 要想数据高可用,就得写多份数据写多分数据就会导致数据一致性问题数据一致性问题会引起性能问题 2.一致性模型 弱一致性最终一致性(一段时间达到一致性)强一致 1、2 异步冗余;3是同步冗余 3. 扩展服务的方案 数据分区&…

打开数据库_数据库客户端navicat遇到问题怎么办?

前面的文章介绍了:mysql数据库如何安装,客户端navicat如何安装。下面是客户端navicat使用过程中常见问题的解决办法。【问】使用navicat连接数据库报错信息:12511251Client does not support authentication protocol requested by server,co…

遍历线索化二叉树+图解

图解 代码实现 package com.atguigu.tree.threadedbinarytree;/*** 创建人 wdl* 创建时间 2021/3/25* 描述*/ public class ThreadedBinaryTreeDemo {public static void main(String[] args) {//测试一把中序线索化二叉树的功能HeroNode root new HeroNode(1, "tom&quo…

JS实现星星评分功能实例代码(两种方法)

转载自 JS实现星星评分功能实例代码(两种方法) 一、方法1 1、用到图片 2、结构和样式 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Document</title><style>ul {padding-left: 0;…

SQL on Linux Run on Docker

摘要 SQL Server 2016以及SQL on Linux版本已经支持跑在Docker容器中&#xff0c;也展示微软拥抱开源的决心和勇气。这篇博文就是以SQL on Linux为例&#xff0c;看看如何将SQL Server实例部署在Docker容器中。 背景 大概在两个月之前&#xff0c;在SQL On Linux刚发布预览版本…

三条中线分的六个三角形_八年级数学上册:三角形已知两条边如何求第三边

三角形一、定义&#xff1a;由不在同一条直线上的三条线段首尾顺次相接所组成的平面图形叫做三角形。1、三角形的内角&#xff1a;三角形的没两条边所组成的角叫做三角形的内角2、三角形的外角&#xff1a;三角形的任意一边与另一边的反向延长线所组成的角叫做三角形的外角。二…

Xamarin的坑 - 绑定(二) - 高德iOS SDK(.Framework)绑定的一些事

编者语&#xff1a;入门总是用一个hello world&#xff0c;总会让人觉得写code会是很容易的事。开篇绑定了一下微信SDK,不会有太多的难点&#xff0c;可是接下来的这个例子如果欠缺一些耐心&#xff0c;估计你整个人就崩溃了(我从来不会放弃任何的事)。ps这里得谢谢CSDN回帖的人…

android 监听安装来源_Flutter插件开发之APK自动安装

点击上方的终端研发部&#xff0c;右上角选择“设为星标”每日早9点半&#xff0c;技术文章准时送上公众号后台回复“学习”&#xff0c;获取作者独家秘制精品资料往期文章记五月的一个Android面试经今日头条屏幕适配方案落地研究图解算法&#xff1a;说一道字节跳动的算法题除…

JavaScript学习总结(一)——JavaScript基础

转载自 JavaScript学习总结(一)——JavaScript基础 一、JavaScript语言特点 1.1、JavaScript是基于对象和事件驱动的(动态的) 它可以直接对用户或客户输入做出响应&#xff0c;无须经过Web服务程序。它对用户的响应&#xff0c;是采用以事件驱动的方式进行的。所谓事件驱动…

idea下使用springinitializr创建项目时 初始化失败的解决

idea自带的地址无使用使用阿里的就可以了 idea下使用springinitializr创建项目时 初始化失败的解决 周山 关注 2020.08.05 13:32:26字数 10阅读 1,085 image.png 修改初始化创建时Custom处 https://start.aliyun.com/ image.png

如何使Mac Docker支持SQL on Linux容器Volume特性

问题引入 这天老鸟火急火燎的找到菜鸟&#xff1a;“鸟儿啊&#xff0c;按照你之前的文章SQL on Linux Run on Docker&#xff0c;当我销毁SQL on Linux Docker容器以后&#xff0c;我容器中的所有数据库数据丢失啦&#xff0c;怎么办&#xff0c;怎么办啊&#xff1f;”。菜鸟…

JavaScript学习总结(二)——逻辑Not运算符详解

转载自 JavaScript学习总结(二)——逻辑Not运算符详解 在JavaScript 中&#xff0c;逻辑NOT运算符与C和Java中的逻辑 NOT 运算符相同&#xff0c;都由感叹号&#xff08;!&#xff09;表示。与逻辑 OR 和逻辑 AND 运算符不同的是&#xff0c;逻辑 NOT 运算符返回的一定是 Boo…

赫夫曼树+图解

图解 代码实现 package com.atguigu.huffmanTree;import javax.swing.*; import java.awt.geom.RoundRectangle2D; import java.util.ArrayList; import java.util.Collections; import java.util.List;/*** 创建人 wdl* 创建时间 2021/3/26* 描述*/ public class HuffmanTree…

四足爬行机器人运动_有自我意识机器人横空出世,还能自我复制,专家表示需警惕其失控...

有自我意识是什么样的&#xff1f;人类自身其实就是有自我意识的生命体&#xff0c;那作为有自我意识的生命体&#xff0c;你想过自我意识是指哪些特征吗&#xff1f;指尖科技说小编先跟你探讨一下&#xff1a;1.主动做事情。就是说在没有其他人控制的情况下&#xff0c;它可以…

微软AirSim,一个无人机和机器人的模拟器

微软开发并开源了AirSim&#xff0c;一个用于模拟无人机在全世界的飞行的工具。这个模拟器基于虚幻引擎&#xff08;Unreal Engine&#xff09;构建&#xff0c;微软很快会增加对机器人和其它类型移动设备的支持。 微软在内部开发了航空信息系统和机器人平台&#xff0c;这个研…