Docker启动mysql容器时找不到 mysqlx.sock 和 mysqld.sock

复制代码
2025-04-26 12:18:50+08:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 8.0.41-1.el9 started.
chown: changing ownership of '/var/run/mysqld/mysqld.sock': No such file or directory
chown: changing ownership of '/var/run/mysqld/mysqlx.sock': No such file or directory
2025-04-26 12:18:51+08:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 8.0.41-1.el9 started.
chown: changing ownership of '/var/run/mysqld/mysqld.sock': No such file or directory
chown: changing ownership of '/var/run/mysqld/mysqlx.sock': No such file or directory
2025-04-26 12:18:53+08:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 8.0.41-1.el9 started.
chown: changing ownership of '/var/run/mysqld/mysqld.sock': No such file or directory
chown: changing ownership of '/var/run/mysqld/mysqlx.sock': No such file or directory
2025-04-26 12:18:57+08:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 8.0.41-1.el9 started.
chown: changing ownership of '/var/run/mysqld/mysqld.sock': No such file or directory
chown: changing ownership of '/var/run/mysqld/mysqlx.sock': No such file or directory

事情的经过是这样的,docker容器里面安装的mysql服务,当docker容器不正当关闭时或者强制关掉容器时当再次启动容器在运行里面的mysql服务时就回报找不到mysqlx.sock 无法启动容器,但是在我们挂载的目录里面又能看到mysql.sock文件夹,就是启动不了,经过一番探索给出下面几种解决方式:

下面是docker容器与我本地之间的挂载目录,容器名称为mysql

docker run \

-p 3306:3306 \

--name mysql \

--privileged=true \

--restart unless-stopped \

-v /Users/hayden/mysql:/etc/mysql \

-v /Users/hayden/mysql/logs:/logs \

-v /Users/hayden/mysql/data:/var/lib/mysql \

-v /etc/localtime:/etc/localtime \

-e MYSQL_ROOT_PASSWORD=root1234\

-d mysql:8.0

第一种:删除mysql.sock文件,以我上面挂载目录为例

当我们如果本地挂载目录里面/Users/hayden/mysql/data有 mysql.sock文件的话我们可以删掉他然后在重启一下mysql容器,因为mysql容器启动时会自动创建 mysql.sock,删掉以前最好是先备份一下,然后重启一下试一下看看行不行。

第二种:挂载文件夹里面mysql.sock 不存在

当然这种情况也是有的,就是我们挂载目录里面/Users/hayden/mysql/data本来就没有mysql.sock 这个文件,所以启动的时候说找不到mysql.sock 也是正常的,这种情况的话我们可以先停止容器,然后重新启动一个mysql容器挂载到其他的目录,然后等启动成功以后我们去其他容器里面将mysql.sock 复制一份到/Users/hayden/mysql/data 里面,然后新的容器,在重新启动一下原来的容器看看是否能启动成功。

首先在我们/Users/hayden/ 目录里面新建了一个文件夹mysql01

复制代码
# 先创建目录并设置权限
mkdir -p /Users/hayden/mysql01/{data,conf,logs}
chmod -R 777 /Users/hayden/mysql01

然后在启动下面的容器mysqltest,启动成功以后去 /Users/hayden/mysql01/data 里面复制mysql.sock文件到/Users/hayden/mysql/data 里面,然后停止mysqltest 容器,然后删除 mysqltest

docker run \

-p 3306:3306 \

--name mysqltest \

--privileged=true \

--restart unless-stopped \

-v /Users/hayden/mysql01:/etc/mysql \

-v /Users/hayden/mysql01/logs:/logs \

-v /Users/hayden/mysql01/data:/var/lib/mysql \

-v /etc/localtime:/etc/localtime \

-e MYSQL_ROOT_PASSWORD=root1234\

-d mysql:8.0

复制代码
#停止容器
docker stop mysqltest
#删除容器
​​​​​​​docker rm mysqltest
#最后在启动一下原来的mysql容器看看是否能启动成功
docker start mysql
如果上面都不行的话,那就试一下最后一种办法
复制代码
#先停止容器
docker stop mysql

#在mysql文件夹下面创建文件sockets
mkdir -p /Users/hayden/mysql/sockets

#或者 同时创建data,conf,sockets 3个文件夹
mkdir -p /Users/hayden/mysql/{data,conf,sockets}

#创建成功以后给权限
chmod -R 777 /Users/hayden/mysql

#删掉容器mysql
docker rm mysql

最后使用下面的方式重新创建容器即可,因为容器里面的SQL数据是指向我们/Users/hayden/mysql/data的,所以mysql数据这些都不会丢失。使用下面重新创建容器以后咱们的mysql就能正常启动了。

复制代码
docker run -d \
  --name mysql \  
  -p 3306:3306 \
  -v /Users/hayden/mysql/data:/var/lib/mysql \
  -v /Users/hayden/mysql/conf:/etc/mysql/conf.d \
  -v /Users/hayden/mysql/sockets:/var/run/mysqld \
  -e MYSQL_ROOT_PASSWORD=root123 \
  -e TZ=Asia/Shanghai \
  mysql:8.0 \
  --socket=/var/run/mysqld/mysqld.sock
相关推荐
nbsaas-boot30 分钟前
Java 正则表达式白皮书:语法详解、工程实践与常用表达式库
开发语言·python·mysql
乌托邦的逃亡者34 分钟前
Docker的/var/lib/docker/目录占用100%的处理方法
运维·docker·容器
sun0077003 小时前
mysql索引底层原理
数据库·mysql
程序员秘密基地3 小时前
基于html,css,vue,vscode,idea,,java,springboot,mysql数据库,在线旅游,景点管理系统
java·spring boot·mysql·spring·web3
OKUNP5 小时前
Docker高级管理--容器通信技术与数据持久化
docker·容器·php
叁沐6 小时前
MySQL 11 怎么给字符串字段加索引?
mysql
用户6855449692738 小时前
第一周作业
docker
淮北49411 小时前
最简单的实验室资产管理系统,使用Flask,mysql,html(四、知识补充)
mysql·flask·html
星辰云-11 小时前
【超详细】CentOS系统Docker安装与配置一键脚本(附镜像加速配置)
linux·docker·centos
神仙别闹12 小时前
基于Java+MySQL实现(Web)可扩展的程序在线评测系统
java·前端·mysql