sock文件介绍--以mysql.sock为例

socket 文件 (.sock) 通常是临时文件。

  • MySQL 的 socket 文件是临时文件,只在服务运行时有效。
  • 可通过配置文件更改 socket 文件的存放路径,常见路径如 /tmp/mysql.sock 或指定自定义目录。
  • 如果连接出现问题,可能需要检查 MySQL 服务状态或路径配置是否正确。

什么是 socket 文件?

  • 在 MySQL 中,socket 文件 用于本地客户端与 MySQL 服务进程之间的通信
  • 默认情况下,这个文件会在 MySQL 启动时创建,并在 MySQL 服务关闭时自动删除。
  • 文件路径 通常类似于 /tmp/mysql.sock 或用户指定的路径。

socket 文件特点

  1. 临时性:MySQL 服务运行时存在,关闭后自动删除。
  2. 作用:为本地客户端提供高效的进程间通信(IPC),性能通常比 TCP 连接更快。
  3. 可配置
    • 可在 MySQL 配置文件中通过 socket 参数自定义路径。

    • 示例配置:

      ini 复制代码
      [mysqld]
      socket=/usr/local/src/mysql_demo/master_replica/mysql.sock
      
      [client]
      socket=/usr/local/src/mysql_demo/master_replica/mysql.sock

注意事项

  • 如果 socket 文件意外丢失或未正确删除,可能导致客户端连接错误,比如:

    复制代码
    ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock'

    解决方法

    1. 检查 MySQL 服务是否正在运行。

    2. 如果 socket 文件路径自定义,确保客户端使用正确的配置文件。

    3. 重启 MySQL 服务以重新生成 socket 文件:

      bash 复制代码
      sudo systemctl restart mysql

相关推荐
无小道2 分钟前
Redis——哨兵
数据库·redis·缓存·哨兵
wear工程师3 分钟前
可重复读能不能防幻读?MVCC 和 Next-Key Lock 到底谁在起作用
mysql·面试
AOwhisky14 分钟前
Kubernetes(K8s)学习笔记(第十四期):集群存储与有状态应用(下篇):StatefulSet 有状态应用管理
redis·笔记·mysql·云原生·kubernetes·云计算·k8s
EntyIU31 分钟前
CentOS-高可用部署手册-MySQL双主RedisNginx
linux·mysql·centos
爱奥尼欧37 分钟前
轻量级可扩展日志框架-异步日志与系统集成
开发语言·数据库·c++·学习
爱奥尼欧43 分钟前
轻量级可扩展日志框架-日志落地与日志器模块实现
jvm·数据库·c++
ycydynq1 小时前
Django利用中间间 判断页面是否登录,未登录则返回登录页
数据库·django·sqlite
承渊政道1 小时前
【MySQL数据库学习】(MySQL访问、连接池原理与简易网站数据流动)
数据库·学习·mysql·mysql访问·连接池原理
吴声子夜歌1 小时前
SQL进阶——EXISTS谓词
java·数据库·sql
wefg13 小时前
【MySQL】索引(索引底层原理/创建/查看/删除主键、普通、联合、前缀、全文索引)
数据库·mysql