一分钟搞定!CentOS 7.9上用Ansible自动化部署SQL Server 2019

不熟悉整个流程的朋友可以先看之前的部署文章,手动部署一遍

一步步教你在CentOS 7.9上安装SQL Server 2019

前言

这套Ansible脚本属于红帽官方出品,是一套mssql的自动化运维脚本,能够实现mssql的单实例部署和AlwaysOn集群的部署,它会自动判断当前操作系统的类型和版本,查找适合当前Linux系统安装的SQL Server版本, 然后更新相应的yum仓库,自动下载SQL Server安装包然后安装。

linux-system-roles脚本支持SQL Server 2017到SQL Server 2022。

因为这次部署的操作系统版本是CentOS7.9,所以只能安装的SQL Server最高版本是 SQL Server 2019,Ansible会自动安装好SQL Server 2019。

使用Ansible 2.9版本安装SQL Server

  • 0、查看当前的操作系统版本

可以看到当前版本是CentOS 7.9

[root@2_mssql_68 ~]# cat /etc/redhat-release 

CentOS Linux release 7.9.2009 (Core)
  • 1、确保控制机已经安装好Ansible

Ansible版本是2.9,Python版本是2.7.5,即使是旧机器,这套ansible脚本也可以使用!

[root@2_mssqll_68 ~]# ansible --version
ansible 2.9.27
  config file = /etc/ansible/ansible.cfg
  configured module search path = [u'/root/.ansible/plugins/modules', u'/usr/share/ansible/plugins/modules']
  ansible python module location = /usr/lib/python2.7/site-packages/ansible
  executable location = /usr/bin/ansible
  python version = 2.7.5 (default, Jun 28 2022, 15:30:04) [GCC 4.8.5 20150623 (Red Hat 4.8.5-44)]
  • 2、创建主机文件inventory,因为在本机安装,直接使用local
echo "[sqlgroup]" > myhosts
echo localhost ansible_connection=local >> myhosts [root@2_mssqll_68 ~]# cat myhosts
[sqlgroup]
localhost ansible_connection=local
  • 3、 测试被控机器的连通性
[root@2_mssqll_68 ~]# ansible all -i myhosts -m ping
localhost | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "changed": false,
    "ping": "pong"
}
  • 4、安装ansible角色

需要安装红帽官方的rhel-system-roles 角色

yum install -y ansible-collection-microsoft-sql rhel-system-roles
  • 5、编辑playbook文件mssql.yml

需要修改mssql.yml文件里的mssql_password和mssql_edition参数,实际上,还有其他的参数,参数比较多,文末会放出各个参数含义的文档,如果没有开启防火墙服务,那么需要去掉防火墙的那个play

mssql_edition的值有:Enterprise、Standard、Web、Developer、Express、Evaluation,或一个格式为 #####-#####-#####-#####-##### 的数据库产品密钥,其中 # 是数字或字母。如果要指定版本,可以使用参数mssql_version: 2019

vi mssql.yml
---
- hosts: localhost
vars:
mssql_accept_microsoft_odbc_driver_17_for_sql_server_eula: true
mssql_accept_microsoft_cli_utilities_for_sql_server_eula: true
mssql_accept_microsoft_sql_server_standard_eula: true
mssql_password: 'RedH@123!'
mssql_edition: 'Developer'
mssql_enable_sql_agent: true
mssql_install_fts: false
mssql_install_powershell: true
mssql_tune_for_fua_storage: true
mssql_datadir: "/data/mssql/1433/database"
mssql_logdir: "/data/mssql/1433/database" roles:
- microsoft.sql.server - hosts: localhost
tasks:
- firewalld:
service: mssql
permanent: yes
immediate: yes
state: enabled
  • 6、运行Playbook文件

在当前路径下执行,大概运行1分钟就安装完成,大概有30个任务tasks

[root@2_mssqll_68 ~]# ansible-playbook -vvv -i myhosts  mssql.yml 
TASK [microsoft.sql.server : Configure the forceencryption setting] ******************************
task path: /usr/share/ansible/collections/ansible_collections/microsoft/sql/roles/server/tasks/main.yml:472
skipping: [localhost] => {
    "changed": false, 
    "skip_reason": "Conditional result was False"
}
META: ran handlers
META: ran handlers PLAY RECAP ***************************************************************************************
localhost                  : ok=30   changed=0    unreachable=0    failed=0    skipped=41   rescued=0    ignored=0   
  • 7、查看SQL Server服务是否在运行

看到Active: active (running) 字样就表示SQL Server服务已经启动,安装成功

[root@2_mssqll_68 ~]# systemctl status mssql-server.service --no-pager
● 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 Sun 2025-02-09 11:36:06 CST; 4s ago
     Docs: https://docs.microsoft.com/en-us/sql/linux
 Main PID: 999 (sqlservr)
   CGroup: /system.slice/mssql-server.service
           └─999 /opt/mssql/bin/sqlservr Feb 09 11:36:06 2_mysql_68 systemd[1]: Started Microsoft SQL Server Database Engine.
  • 8、连接数据库并查看当前数据库版本

Ansible自动识别到当前操作系统版本是centos7.X,然后安装适配当前系统版本的最高SQL Server版本SQL Server 2019

/opt/mssql-tools/bin/sqlcmd -S localhost -U sa -P "RedH@123!"  -Q "SELECT @@VERSION"

  • 9、查看SQL Server实例的数据目录结构
  • 系统库和tempdb数据库都放在同一个目录下,如果是生产环境需要注意分开,/var/opt/mssql/secrets目录是用来存放证书文件,特别是在搭建AlwaysOn集群的时候
[root@2_mssqll_68 ~]#  tree /var/opt/mssql/
/var/opt/mssql/
├── data
│   ├── Entropy.bin
│   ├── master.mdf
│   ├── mastlog.ldf
│   ├── modellog.ldf
│   ├── model.mdf
│   ├── model_msdbdata.mdf
│   ├── model_msdblog.ldf
│   ├── model_replicatedmaster.ldf
│   ├── model_replicatedmaster.mdf
│   ├── msdbdata.mdf
│   ├── msdblog.ldf
│   ├── tempdb2.ndf
│   ├── tempdb3.ndf
│   ├── tempdb4.ndf
│   ├── tempdb.mdf
│   └── templog.ldf
├── log
│   ├── errorlog
│   ├── errorlog.1
│   ├── errorlog.2
│   ├── errorlog.3
│   ├── errorlog.4
│   ├── HkEngineEventFile_0_133835034943490000.xel
│   ├── HkEngineEventFile_0_133835034997660000.xel
│   ├── HkEngineEventFile_0_133835048280420000.xel
│   ├── HkEngineEventFile_0_133835457796360000.xel
│   ├── log_1.trc
│   ├── log_2.trc
│   ├── log_3.trc
│   ├── log.trc
│   ├── mssql-conf
│   │   └── mssql-conf.log
│   ├── sqlagent.1
│   ├── sqlagent.out
│   ├── sqlagentstartup.log
│   ├── system_health_0_133835034957910000.xel
│   ├── system_health_0_133835035001390000.xel
│   ├── system_health_0_133835048284420000.xel
│   └── system_health_0_133835457809610000.xel
├── mssql.conf
└── secrets
    └── machine-key 4 directories, 39 files

Playbook脚本中用到的参数解释和Playbook脚本源代码地址

需要解释的是,这套脚本可以完成mssql的单实例安装和AlwaysOn集群的部署,可以说红帽官方真的非常贴心!编写好Playbook脚本五分钟就可以部署好3个节点的AlwaysOn集群!

第一个网址有AlwaysOn搭建示例参考

  • https://github.com/linux-system-roles/mssql

  • https://github.com/redhat-cop/sqlserver-coi/tree/master/ansible

本文版权归作者所有,未经作者同意不得转载。

一分钟搞定!CentOS 7.9上用Ansible自动化部署SQL Server 2019的更多相关文章

  1. CENTOS --5分钟搞定Nginx安装的教程

    1. 安装gcc(centos 7之后一般已自带,可以在第6步失败后再安装) yum install gcc gcc-c++ 2. 安装pcre yum install -y pcre pcre-de ...

  2. JS组件系列——又一款MVVM组件:Vue(一:30分钟搞定前端增删改查)

    前言:关于Vue框架,好几个月之前就听说过,了解一项新技术之后,总是处于观望状态,一直在犹豫要不要系统学习下.正好最近有点空,就去官网了解了下,看上去还不错的一个组件,就抽空研究了下.最近园子里vue ...

  3. 一分钟搞定AlloyTouch图片轮播

      一分钟搞定AlloyTouch图片轮播 轮播图也涉及到触摸和触摸反馈,同时,AlloyTouch可以把惯性运动打开或者关闭,并且设置min和max为运动区域,超出会自动回弹.除了一般的竖向滚动,A ...

  4. 五分钟搞定Go.js

    五分钟搞定Go.js  1.基于html5~因为Go.js是一个依赖于HTML5特性的JavaScript库,所以需要确保您的页面声明它是一个HTML5文档,当然需要加载库 <!DOCTYPE ...

  5. Spring Boot 返回 XML 数据,一分钟搞定!

    Spring Boot 返回 XML 数据,前提必须已经搭建了 Spring Boot 项目,所以这一块代码就不贴了,可以点击查看之前分享的 Spring Boot 返回 JSON 数据,一分钟搞定! ...

  6. zookeeper-架构设计与角色分工-《每日五分钟搞定大数据》

    本篇文章阅读时间5分钟左右 点击看<每日五分钟搞定大数据>完整思维导图   zookeeper作为一个分布式协调系统,很多组件都会依赖它,那么此时它的可用性就非常重要了,那么保证可用性的同 ...

  7. zookeeper核心-zab协议-《每日五分钟搞定大数据》

    上篇文章<paxos与一致性>说到zab是在paxos的基础上做了重要的改造,解决了一系列的问题,这一篇我们就来说下这个zab. zab协议的全称是ZooKeeper Atomic Bro ...

  8. windows+mysql集群搭建-三分钟搞定集群

    注:本文来源:  陈晓婵   <  windows+mysql集群搭建-三分钟搞定集群   > 一:mysql集群搭建教程-基础篇 计算机一级考试系统要用集群,目标是把集群搭建起来,保证一 ...

  9. 转载-30分钟搞定后台登录界面(103个后台PSD源文件、素材网站)

    原文:30分钟搞定后台登录界面(103个后台PSD源文件.素材网站)   目录 一.界面预览 二.PSD源文件预览 三.工具分享 四.资源说明 五.素材下载网站 六.下载 去年八月时要做一个OA系统为 ...

  10. 【转】让你10分钟搞定Mac--最简单快速的虚拟安装

    文章出处:让你10分钟搞定Mac--最简单快速的虚拟安装http://bbs.itheima.com/thread-106643-1-1.html (出处: 黑马程序员训练营论坛) 首先说明一下. 第 ...

随机推荐

  1. Linux C/C++编程中的多线程编程基本概念

    8.2.1  操作系统和多线程 要在应用程序中实现多线程,必须有操作系统的支持.Linux 32位或64位操作系统对应用程序提供了多线程的支持,所以Windows NT/2000/XP/7/8/10是 ...

  2. springgateway 路由转发

    有些情况下,我们希望不直接访问后端地址,这个时候可以通过springgateway网关进行处理.下面只是一个简单的例子. 至于URL,变化,我们可以通过编写程序逻辑来实现. 实现步骤: 1.新建项目 ...

  3. AFL分析与实战

    文章一开始发表在微信公众号 https://mp.weixin.qq.com/s?__biz=MzUyNzc4Mzk3MQ==&mid=2247486292&idx=1&sn= ...

  4. ArkTs布局入门05——栅格布局(GridRow/GridCol)

    1.概述 栅格布局是一种通用的辅助定位工具,对移动设备的界面设计有较好的借鉴作用.主要优势包括: 提供可循的规律:栅格布局可以为布局提供规律性的结构,解决多尺寸多设备的动态布局问题.通过将页面划分为等 ...

  5. 为什么C#越来越恶心

    看看这个 再看这些 more 老子声明个空函数,没有访问数据请改为 static,真是越来越智障 为什么一个活泼的语言越搞越像 C++? C# 发明了各种可爱的小玩意儿,尤其是 async/await ...

  6. [Blazor] 一文理清 Blazor Identity 鉴权验证

    一文理清 Blazor Identity 鉴权验证 摘要 在现代Web应用程序中,身份认证与授权是确保应用安全性和用户数据保护的关键环节.Blazor作为基于C#和.NET的前端框架,提供了丰富的身份 ...

  7. 即时通讯技术文集(第26期):实时音视频技术合集(Part1) [共16篇]

    为了更好地分类阅读 52im.net 总计1000多篇精编文章,我将在每周三推送新的一期技术文集,本次是第26 期. [- 1 -] 实时语音聊天中的音频处理与编码压缩技术简述 [链接] http:/ ...

  8. 再制作个WCH-LINK下载器

    用CH549可以制作成支持两种模式的WCH-LINK下载器,两种模式指的是RISC-V和DAPLINK模式. 如果用于沁恒的CH32V203等芯片,我们可以将这个下载器设置成RISC-V下载模式. 如 ...

  9. Solution -「CF 1366E2」Chiori and Doll Picking (hard version)

    \(\mathscr{Description}\)   Link.   给定 \(\{a_n\}\), 值域 \([0,2^m)\). 对于每个 \(i\in[0,m]\), 求有多少个 \(\{a_ ...

  10. Flume架构与源码分析-整体架构

    最近在学习Flume源码,所以想写一份Flume源码学习的笔记供需要的朋友一起学习参考. 1.Flume介绍 Flume是cloudera公司开源的一款分布式.可靠地进行大量日志数据采集.聚合和并转移 ...