星途物语 星途物语
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
记一言
留言板
归档
GitHub (opens new window)

星途物语

尚记时,记之
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
记一言
留言板
归档
GitHub (opens new window)
  • 随手记录

    • QPS优化记录
    • 阿里云SLB演示
    • DDOS预防
    • Linux内核优化
    • rsync同步守护进程
    • NFS文件同步
    • Tomcat升级
    • 编译安装mysql后添加到systemd管理
    • 防火墙笔记
    • python自动化巡检服务器
    • redis集群升级
    • nacosV2.5.1数据库脚本
    • Coze本地部署and接入大模型
    • 本地部署Affine
    • Doris2.1.7单机部署-dockercompose
  • 故障处理

    • 处理防MIME攻击后出现的问题解决
    • windows server 2008 R2系统崩溃后PE修复
    • sqlserver连接问题
      • sql server 2008连接问题
        • 问题1:SSMS连接sql server 2008时报错
        • 处理
        • 解释
        • 问题2:远程Java应用连接sql server 2008时报错
        • 处理
    • U盘在服务器安装CentOS7的问题and解决
  • MySQL学习笔记

    • MySQL5.7安装
    • MySQL常用操作语句
    • MySQL主从架构实施
    • MySQL主主架构实施
    • MySQL MHA高可用实施
    • MyCat读写分离
    • MySQL创建用户时的授权
    • MySQL备份
    • MySQL通配符
    • Ubuntu22.04安装mysql
  • Nginx学习笔记

    • 状态码含义
    • 匹配优先级
    • Nginx常用操作
    • 添加第三方模块
    • 关于路径匹配
    • 转发和重写
    • 内置变量
    • Nginx配置文件结构
  • Tomcat学习笔记

    • 部署Tomcat
    • 修改发布目录
    • Tomcat调优
  • Redis学习笔记

    • 通过 tar.gz 包安装部署 redis
    • redis 配置文件
    • 哨兵集群
    • redis常用命令
    • 虚拟机安装 redis.tar.gz 遇到的问题
  • Ansible学习笔记

    • 部署和使用 ansible
    • ansible 自带的密码认证参数
    • 批量免密操作:批量分发公钥
    • 配置主机清单
    • ansible 小知识
    • 模块介绍
    • 剧本
    • 一键部署 rsync 环境
    • 批量安装一个tomcat
    • 批量安装一个nginx
    • 批量安装 zabbix-agent
  • Zabbix学习笔记

    • 部署 zabbix 服务端、客户端
    • 自定义监控
    • 触发器
    • 监控项类型
    • 简单检查模式
    • zabbix web 界面结构信息
    • 邮件报警
    • 微信报警
    • snmp 监控网络设备
    • 部署 zabbix 服务端、客户端
    • jmx 监控 java 应用
    • ipmi 监控硬件
    • 自动化注册
    • 监控项的主要项和相关项
    • percona 监控 mysql
  • Git学习笔记

    • 配置 git
    • 常用命令
  • GitLab学习笔记

    • 环境准备
    • 安装 gitlab
    • gitlab 忘记 root 管理员密码的处理办法
  • Jenkins学习笔记

    • 安装部署
    • jenkins 使用脚本完成项目构建
    • jenkins 自动构建最新项目
    • 将 jenkins 自动部署的结果返回给 gitlab
    • jenkins 上线 java 项目
    • jenkins pipeline
  • Docker学习笔记

    • 安装 docker
    • 配置 docker 源
    • docker 中的常见名词
    • 镜像管理命令
    • 容器管理命令
    • 创建容器
    • 数据卷
    • docker network
    • 搭建 LNMP
    • Dockerfile
    • Dockerfile 搭建 tomcat
    • docker 镜像磁盘扩容
    • docker composer
    • Harbor 私有镜像仓库
    • docker 面试题
    • docker desktop 运行时与虚拟机冲突
    • docker离线安装
  • Nexus学习笔记
  • Prometheus学习笔记

    • 核心组件
    • 工作原理
    • 安装和配置
    • 启动 Prometheus
    • PromQL 使用
    • 数据模型
    • Exporter
    • 演示服务
    • Grafana 数据可视化
    • Prometheus 告警
  • Kubernetes学习笔记

    • K8S(v1.18.0)的介绍
    • K8S(v1.18.0)集群环境的搭建
    • K8S(v1.18.0)资源管理
    • K8S(v1.18.0)的实战入门
    • K8S(v1.18.0)的Pod详解
    • K8S(v1.18.0)的Pod控制器详解
    • K8S(v1.18.0)的Service详解
    • K8S(v1.18.0)的数据存储
  • 运维
  • 故障处理
星途物语
2025-08-15
目录

sqlserver连接问题

# sql server 2008连接问题

其实是同一个问题,我这里拆解为两个问题

都是HW结束后启动服务器后发现的,HW前没有任何问题;至今也没找到具体发生的原因是什么

# 问题1:SSMS连接sql server 2008时报错

描述1:HW前是可以正常连接的

描述2:SSMS和sql server都部署在同一台机器,属于是本地连接

问题截图1(连接报错):

7a38c29d45a69457a918fda6a214e1d4

问题截图2(windows 日志):

image-20250815145733910

具体原因解释:客户端和服务器的加密算法没有交集,导致握手失败;在 TLS 1.0 协议下,服务器和客户端的加密算法不匹配

# 处理

在 Windows Server(尤其是 Server 2008 R2、SQL Server 2008 等老系统)里,TLS 1.0 下的默认加密套件是比较少的

直接去组策略编辑器中加上一些旧的 Cipher Suite

  1. 打开组策略编辑器(gpedit.msc)
  2. 来到计算机配置 → 管理模板 → 网络 → SSL 配置设置
  3. 双击SSL 加密套件顺序
  4. 重写策略内容如下
  5. 重启服务器
TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256_P256,TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256_P384,TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256_P521,TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384_P384,TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384_P521,TLS_RSA_WITH_AES_128_CBC_SHA256,TLS_RSA_WITH_AES_256_CBC_SHA256,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P384,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P521,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P521,TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256_P256,TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256_P384,TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256_P521,TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384_P384,TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384_P521,TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,TLS_RSA_WITH_AES_256_GCM_SHA384,TLS_RSA_WITH_AES_128_GCM_SHA256,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_AES_256_CBC_SHA,TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_3DES_EDE_CBC_SHA
1

重启服务器后再次用SSMS连接,成功了

# 解释

原来的 Cipher Suite 全是 ECDHE/ECDSA 和 ECDHE/RSA 的套件,而且几乎都是 TLS 1.2+ 的 GCM 或 CBC 高级算法, TLS 1.0 根本用不到这些套件,所以当客户端发 TLS 1.0 请求时,服务器找不到匹配的算法,就报了 36874

# 问题2:远程Java应用连接sql server 2008时报错

描述1:和上面的问题是一样的

此项目Tomcat启动时报错《数据库连接不上》,我的排错方式:

  • 确定数据库服务器能正常通信:ping、telnet 数据库服务器,发现都是通的
  • 查看Java应用本地错误日志:过滤 Tomcat 各种错误日志,寻找错误:发现关键问题【The driver could not establish a secure connection to SQL Server by using Secure Sockets Layer (SSL) encryption. Error: "SQL Server 未返回响应。连接已关闭。"】,可以确保的是能连接到数据库服务器,也可以正常访问数据库,但是因为算法的问题导致没有连接上
  • 排错服务器端windows日志:从上面的排错来看,基本上可以确定又是因为算法不同的问题连接不上;果然在windows日志中找到了错误【客户端和服务器的加密算法没有交集,导致握手失败;在 TLS 1.0 协议下,服务器和客户端的加密算法不匹配】

# 处理

经过排查,发现是服务端没有支持 Java 8 的 TLS1.0 cipher suite

让AI生成后加上

TLS_RSA_WITH_AES_128_CBC_SHA,TLS_RSA_WITH_AES_256_CBC_SHA,TLS_RSA_WITH_3DES_EDE_CBC_SHA,TLS_RSA_WITH_AES_128_CBC_SHA256,TLS_RSA_WITH_AES_256_CBC_SHA256,TLS_RSA_WITH_AES_128_GCM_SHA256,TLS_RSA_WITH_AES_256_GCM_SHA384,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P384,TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P521,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384,TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P521,TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256_P256,TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256_P384,TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256_P521,TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384_P384,TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384_P521,TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256_P256,TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256_P384,TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256_P521,TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384_P384,TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384_P521
1

加上后重启服务器,然后Java应用就可以连接数据库了

#故障处理#sqlserver
上次更新: 8/22/2025, 10:15:41 AM
windows server 2008 R2系统崩溃后PE修复
U盘在服务器安装CentOS7的问题and解决

← windows server 2008 R2系统崩溃后PE修复 U盘在服务器安装CentOS7的问题and解决→

Theme by Vdoing | Copyright © 2025-2025 | 鄂ICP备2024086820号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式