docker start启动容器后闪退或者失败

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: docker start启动容器后闪退或者失败

问题描述



笔者使用docker start 启动mysql容器时,显示启动成功,但是1-2s以后mysql又会自动挂掉,很是奇怪。


以下是问题复现:

Unix socket lock file is empty /var/run/mysqld/mysqld.sock.lock.
Unable to setup unix socket lock file.
Aborting


1.启动并查看容器


docker start 容器id
docker ps -a


7fc68eeac62a42218102335696160427.png


解决过程



1.是否是磁盘已满


因为测试服务器本来磁盘就很有限,所以首先想到的是不是磁盘满了,然后就尝试去清理了磁盘,清理完成后再次进行重启发现容器依然还是异常的。


2.查看日志


docker logs 容器id


d70ec7fd14474f108dc1dabe26ab5b31.png


发现图中所示位置,提示mysqld.sock.lock是空的,这里有一点需要注意,这里报的这个路径“/var/run/mysqld/mysqld.sock.lock”这是容器内的路径,所以如果你在宿主机上搜索肯定不是这个路径

# 搜索上面的文件位置
find / -name mysqld.sock.lock

db7af8aed0474e7a8047e1564a56a8d5.png


根据搜索到的路径去找到这个文件即可。


3.解决问题


解决的方式很简单,就是将这个文件mysqld.sock.lock删除即可,为甚么这个文件会异常呢,删除对其他地方有无影响呢?首先说下导致这个异常的方式多种多样,笔者碰到的是因为服务器非正常down机引起的,非正常宕机的情况下,mysql.sock.lock无法正常删除,所以有了这个问题。那这个文件删除了是否对mysql服务有影响呢,其实也没有,这个文件在mysql重新启动时会重新创建,而且mysql.sock.lock只是mysql.sock的锁文件,mysql.sock文件又有什么作用呢,这个文件主要用于客户端与服务端位于一台机子上的服务器,实现本地连接的也就是我们使用localhost可以直接连本地的服务时用的。所以删了这个文件对我们毫无影响。


总结



这个问题的产生原因其实是服务器非正常宕机引起的,导致了这个文件的异常。这里需要注意的是,若是容器没有数据卷,这个问题将很难处理,所以我们平时启动容器一定要做数据卷,不然容器内部的问题真的无法解决(容器无法启动时)。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
2月前
|
缓存 前端开发 Docker
Docker Layer Caching:加速你的容器构建
Docker Layer Caching:加速你的容器构建
|
3月前
|
运维 持续交付 开发者
Docker:重塑现代应用开发的容器革命
Docker:重塑现代应用开发的容器革命
|
3月前
|
运维 持续交付 开发者
Docker:现代应用开发的容器化革命
Docker:现代应用开发的容器化革命
|
1月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
345 5