为SQL Server配置连接加密

这篇具有很好参考价值的文章主要介绍了为SQL Server配置连接加密。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言
很多客户在对数据库做安全审计时要求配置连接加密,本文就如何配置加密以及使用证书做一个系统的整理。

连接加密


首先,连接加密不是透明数据加密,很多人经常把两个概念混淆。连接加密是指客户端程序和SQL Server通信时的加密,保护数据在传输过程中的安全。

连接加密是SQL Server的TDS协议和TLS协议结合完成的,是在客户端驱动程序(ADO.NET、JDBC、OLEDB等)和SQL Server服务端实现的,对于上层的应用程序是透明的。

服务器端配置


打开SQL Server配置管理器,在SQL Server网络配置节点下,选择要启用加密连接的实例,右键,选择“属性”,在弹出的窗口中配置强行加密。确定后,重启SQL Server服务。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

通过视图sys.dm_exec_connections的encrypt_option属性可以看到所有的连接都已经加密了。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

说明:如果是SQL Server故障转移群集或者AlwaysOn,每个节点都需要配置。

客户端配置


在服务器端启动强制加密是最简单的方法,如果前端应用程序使用非常老的数据库驱动程序,不支持TLS协议,无法正常连接数据库,例如低版本的PB、DELPHI等。另外,基于网络抓包分析的审计软件也无法工作。在这种情况下,可以在客户端进行有选择性地配置。

通过在数据库连接字符串中增加Encrypt和TrustServerCertificate两个关键词来实现。

ADO.NET

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

JDBC

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

SQL Server Management Studio

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

老版本SQL Server Management Studio

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

配置证书


无论是在服务端还是客户端配置连接加密,都需要使用证书。默认情况下,SQL Server会生成自签名证书,在ERROR_LOG中可以看到一条“已成功加载自行生成的证书以进行加密”的日志。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

大多数情况下,使用自签名证书就足够了。如果想使用CA机构颁发的第三方证书,可按照以下步骤配置。

运行mmc打开控制台,添加证书管理。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

在“个人”节点下按照向导导入证书。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

注意:导入证书的使用者属性必须与服务器的完全限定域名 (FQDN) 一致。如果是SQL Server故障转移群集,要和虚拟服务器的FQDN一致。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

为SQL Server启动账号配置权限。在SQL Server配置管理器中查看启动账号。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档
sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

在SQL Server配置管理器中,选择证书并重启SQL Server服务。注意:SQL Server 配置管理器中只能显示与服务器FQDN一致的证书,所以显示不出为SQL Server故障转移群集虚拟服务器名称创建的证书。需要通过修改注册表的方式配置,具体步骤见“SQL Server故障转移群集下配置证书”。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

通过ERROR_LOG可以看到SQL Server使用的证书。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

SQL Server故障转移群集下配置证书


首先按照上面的步骤在所有节点导入证书,然后复制出证书的指纹。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

在所有的节点中打开注册表,找到HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft \Microsoft SQL Server\MSSQL.1\MSSQLServer\SuperSocketNetLib\Certificate项(注意替换成实际的版本和实例名),填写复制的指纹数据,在填写时去掉数据中的空格。

sqlserver加密连接,性能,运维,数据库,数据库,服务器,运维,sqlserver,性能优化,Powered by 金山文档

最后,依次切换每个节点,验证SQL Server服务能否正常启动,并验证前端应用是否能正常连接。

北京格瑞趋势科技有限公司是聚焦于数据服务的高新技术企业,成立于2008年,创始团队及核心技术人员来自微软和雅虎。微软数据平台金牌合作伙伴,卫宁健康数据平台战略合作伙伴。通过产品+服务双轮驱动的业务模式,14年间累计服务4000+客户,覆盖互联网、市政、交通、电信、医疗、教育、电力、制造业等各个领域。文章来源地址https://www.toymoban.com/news/detail-655943.html

到了这里,关于为SQL Server配置连接加密的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包