- 浏览: 633858 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (314)
- 生活 (2)
- c# (37)
- 技术 (3)
- 400电话 (0)
- 400常见问题 (0)
- 400资费 (0)
- html (7)
- css (0)
- 数据库 (7)
- javascript (16)
- php (33)
- asp.net mvc2 (10)
- mysql (9)
- C# 3.0 LinQ (10)
- vs2005或vs2008 (4)
- flash and as3 (7)
- fms (1)
- dedeCMS (11)
- java (33)
- j2me (1)
- swing (1)
- c++ (1)
- jquery easyui (3)
- jquery (5)
- android (29)
- MongoDB (9)
- VtigerCRM (1)
- test (0)
- linux (30)
- nutch (2)
- SqlServer数据库 (2)
- 数据检索 (2)
- java抓取 (11)
- 乐天 (1)
- 淘宝 (1)
- Silverlight4.0 (6)
- sphinx实时索引 (5)
- ecshop (9)
- codeigniter(CI) (3)
- axure6 (1)
- 京东店铺装修教程 (2)
- xpath (1)
- joomla (2)
- bpm (1)
- Bootstrap (2)
- knockout (4)
- ecstore (4)
- css3 (1)
- 微信 (2)
- dede (0)
- soa_edi (1)
- odoo (0)
- web (1)
最新评论
-
骑着蜗牛超F1:
在ie6下报了个stack overflow at line ...
兼容ie6和ie7 的16进制码流在html中显示为图片代码(base64) -
冰之海洋:
好像少了一句代码吧? FloatingFunc.show(th ...
android 一直在最前面的浮动窗口效果 -
yanzhoupuzhang:
连接有问题!
iis7.0官方下载 IIS 7.0(微软Web服务器组件IIS 7.0) 官方(windows 2003,XP,2000) -
whatable:
唉,楼主你都没有搞清楚重量级和轻量级。。。。既然引用了SWT, ...
java swing 内置浏览器打开网页显示flash图表-swt Browser应用 -
yy_owen:
我晕啊,你链接的什么内容额,我要的iis,你链接个视频什么意思 ...
iis7.0官方下载 IIS 7.0(微软Web服务器组件IIS 7.0) 官方(windows 2003,XP,2000)
mysql PID file not found and Can't connect to MySQL through socket mysql.sock
今天同事A找到我,说是Mysql server X的负载很高,查询很慢。他自己捣鼓了一阵未果后,我们一起看了下。
[root@redhat var]# uname -a
Linux xxx 2.6.18-128.el5 #1 SMP Wed Dec 17 11:41:38 EST 2008 x86_64 x86_64 x86_64 GNU/Linux
[root@redhat var]# mysql -u root -p -e "select version();"
+------------+
| version() |
+------------+
| 5.1.32-log |
+------------+
同事A的操作:
A一看mysql server有问题第一反应是重启mysql server,囧!!o(╯□╰)
但是又使用了错误的命令
[root@redhat var]# /var/lib/mysql/libexec/mysqld restart ----操作①
100708 14:43:53 [ERROR] Fatal error: Please read "Security" section of the manual to find out how to run mysqld as root!
100708 14:43:53 [ERROR] Aborting
100708 14:43:53 [Note] /var/lib/mysql/libexec/mysqld: Shutdown complete
发现问题后,他又想起来应该是用下面的命令重启
[root@redhat var]# service mysql restart ----操作②
MySQL manager or server PID file could not be found! [FAILED]
Starting MySQL......
CTRL+C取消
这时候
[root@redhat var]# ps aux | grep mysql
可以看到,系统又启动了一个Mysql进程,但是过一会后,会自动消失,这时候看日志可以发现以下错误:
100708 15:26:52 [ERROR] Can't start server: Bind on TCP/IP port: Address already in use
100708 15:26:52 [ERROR] Do you already have another mysqld server running on port: 30017 ?
100708 15:26:52 [ERROR] Aborting
然后后面我们一起看。
首先我用client工具连接,发现mysql正常。web应用连接数据库也正常只是查询很慢。
其次我在命令下面,连接:
[root@redhat var]# mysql -u root -p
提示:
Enter password:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
这时候同事A提醒我,可以重启服务没关系。囧,o(╯□╰)o,他在建议我重启解决问题。
好吧,如他所愿。于是我先:
[root@redhat var]# service mysql stop
MySQL is running but PID file could not be found
然后去mysql data dir下面查看,果然没有pid file。
这时候我的第一反应是配置文件不对,导致不能正常停止和重启。
由于server是好的,因此我没有急着去比较以前备份的/etc/my.cnf.bak和/etc/my.cnf。
我们先查找负载高的原因。因为命令行下无法进入mysql,在client下使用
show processlist;
可以看到里面有很多locked的查询,其中等待时间最久的一个是一个select查询,显示正在sending data,然后其余都是locked。
猜想是sending data的线程占用了"所有的分配给mysql的资源",导致后来的线程全部挂起,由于"查询(线程)是依次执行的",后面locked的线程一直在等待前面sending data的线程结束。(这一段是猜想的…)
sending data的这个线程U是一个select 查询,这个select对6张表进行了连接(公司的一个实习生提交的一个查询),其中有两张表的数据量在10w左右,另外有张data表数据量在 1000w左右,另外还有sum(distinct ) ,group by,order by… 可以想象下…不知道要到何年何月这个查询才能执行完。
这个sending data的慢查询的processid为799,当机立断运行
kill 799
然后再运行
show processlist;
可以看到前面locked的线程在一个个依次执行,后面还有好多个跟线程U类似的select线程,全部kill掉后,被堵塞的别的正常的几个Update,select,insert操作很快就执行完了。
而后,web应用恢复正常,速度变快。
返回linux命令行,使用
[root@redhat var]# top
<shift+m 按内存使用排序>
<1 显示cpu使用情况>
这时候可以发现server负载恢复正常。
下面解决无法正常关闭重启的情况。
也就是因为前面同事的误操作引起的
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
和MySQL manager or server PID file could not be found! [FAILED]
的错误。
我前面不是怀疑是配置文件里面有什么无法识别的参数选项么。http://www.my400800.cn
通过
[root@redhat var]# diff /etc/my.cnf /etc/my.cnf.bak
发现,配置文件没有问题。
#我的server的hostname,mysql pid文件默认名字为hostname.pid,如果没有在/etc/my.cnf里面指定特定和pid filename和pid file path的话,这个文件是跟mysql数据在一起的。
[root@redhat var]# hostname
redhat
MySQL is running but PID file could not be found 解决方法
这时候通过
#切换到mysql data dir(mysql的数据文件目录下)
#你们的mysql data dir或许跟我的不一样哦,我的是/var/lib/mysql/var/
[root@redhat var]# cd /var/lib/mysql/var/
获取mysql用户运行的mysql进程的 pid,然后导入到hostname.pid文件里面
[root@redhat var]# echo `ps aux | grep mysql | grep "user=mysql" | grep -v "grep" | awk '{print $2}'`>> redhat.pid
#注意这里的redhat.pid跟hostname相关,这里是我的hostname.pid
将文件的属主和属主组改为mysql:mysql
[root@redhat var]# chown mysql:mysql redhat.pid
然后运行
[root@redhat var]# mysql -u root -p
还是会提示:
Enter password:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
[root@redhat var]# ls /tmp | grep sock
果然没有mysql.sock这个文件
但是这时候运行
[root@redhat var]# service mysql status
显示
MySQL running (10949) [ OK ]
恩,pid file文件恢复正常,然后运行
[root@redhat var]# service mysql restart
Shutting down MySQL. [ OK ]
Starting MySQL. [ OK ]
这时候再运行
[root@redhat var]# ls /tmp | grep sock
可以发现重启后,/tmp下有了mysql.sock这个文件。
大家可以搜索下mysql.sock的用途以及使用产生等等。
同事A的 操作① 导致pid 文件丢失, 操作② 导致mysql.sock文件丢失,大家感兴趣可以去vi mysqld脚本和server mysql脚本,然后导致service mysql status/stop/start/restart运行异常,导致命令行下mysql -u root -p登录mysql异常。
评论
kill进程后重启也是可以的~,不知道有没有什么问题
发表评论
-
修改NGINX版本名称伪装任意WEB SERVER
2016-07-08 19:16 934无论是作为Web服务器或其他类型程序的反向代理服务器,Ngi ... -
修改nginx的http响应头server字段
2016-07-07 13:26 4839修改src/http/ngx_http_header_f ... -
Nginx 下缓存静态文件(如css js)
2016-07-06 15:34 776目的:缓存nginx服务器的静态文件。如css,js,ht ... -
Nginx编译安装第三方模块http_substitutions_filter_module
2016-07-05 00:04 12441. >>ngx_http_substit ... -
Linux一键安装web环境全攻略(阿里云服务器)
2016-06-26 20:18 633一键安装包下载: 点此下载 安装须知 1、此安装 ... -
Linux下批处理文件编写
2015-09-16 09:39 812linux下的批处理文件,基本就是shell脚本文件。 ... -
Memcache,Redis,MongoDB(数据缓存系统)方案对比与分析
2015-08-26 10:04 679一、问题: 数据库表数据 ... -
安骑士(云盾客户端)安装指南
2015-08-21 14:31 1735安骑士是云盾安全防护体系中的主机安全防护模块,基于云端联动防 ... -
Linux 系统挂载数据盘
2015-08-21 14:14 591适用系统:Linux(Redhat , CentOS,De ... -
doesn't contain a valid partition table 解决方法
2015-08-21 14:07 2275fdisk -l提示信息:doesn't contain a ... -
在Ubuntu 12.04安装和设置SSH服务
2015-08-20 10:37 4651.安装Ubuntu缺省安装了openssh-client ... -
Ubuntu14.04安装 php及mysql
2015-08-18 11:17 1064①安装php: sudo apt-get install ... -
ubuntu下使用vi是方向键变乱码 退格键不能使用的解决方法
2015-08-18 09:17 784在插入模式下,按删除键没有任何反应,按方向键分别打印出 ... -
Linux系统 wget 权限被人下掉了 怎么添加 是root账户
2015-08-10 17:59 17131 看看weget的安装位置 [root@abc /tmp ... -
MongoDB 安装与启动
2015-07-31 22:21 641下载安装和配置 windows下安装Mongo数据库: ... -
查看Linux 32 or 64 bit及Linux版本命令
2015-07-31 22:17 489用命令查询系统是32位还是64位getconf LONG_B ... -
Ubuntu安装vncserver实现图形化访问
2015-07-31 16:22 1526请注意: 如果在安装中部分软件无法安装成功,说明软件 ... -
Ubuntu14.04使用VNC解决gnome-session-is-accelerated: No composite
2015-07-31 16:02 3167Ubuntu14.04目前仍是非常不稳定,使用VNC的时候 ... -
linux命令中ps -ef是什么意思
2015-05-14 17:04 922ps -ef是以全格式显示当前所有的进程ps是Linux 操作 ... -
Linux crontab 命令格式与详细例子
2015-05-14 16:41 400基本格式 : * * * * * command ...
相关推荐
让人纠结了一把…… 代码如下:zhouqian@zhou:~$ mysqlERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’ (2)网上好多的解决办法,可是每个人的实际情况...
ERROR 2002: Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (111) 解决办法: /usr/local/mysql/bin/mysqladmin -u root > -S /var/lib/mysql/mysql.sock password 'your.passwd' ...
标题中的问题 "Can't connect to local MySQL through socket '/tmp/mysql.sock'" 是一个常见的MySQL连接错误,通常发生在尝试通过套接字文件(socket file)连接到本地MySQL服务器时。该问题通常涉及MySQL服务未...
在MySQL服务器的运行过程中,可能会遇到“ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock'”这样的错误。这个错误提示表明,客户端试图通过Unix域套接字(socket文件)...
今天,我们一起解决两个常见的错误:mysql PID file not found 和 Can't connect to MySQL through socket mysql.sock。 mysql PID file not found mysql PID file not found 是 MySQL 数据库无法启动的常见错误之...
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2) 的异常。是用dmg直接安装的以为安装包又出现了奇奇怪怪的错误,正欲卸载该版本时找到了我的问题的关键。 解决...
在使用MySQL时,可能会遇到一个常见的错误:“ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’”。这个错误表明客户端无法通过Unix套接字文件与本地MySQL服务器建立...
提示中的“Can’t connect to MySQL through socket mysql.sock”可能意味着MySQL的Unix套接字文件存在问题。检查`socket`配置项,通常在`my.cnf`中: ``` socket = /var/lib/mysql/mysql.sock ``` 确保该路径...
3、Can’t connect to local MySQL server through socket ‘/Data/mydata/mysql.sock’ socket文件目录不对应导致的问题 4、今天要说的就是 没有打开only_full_group_by Cause:...
在安装好了MySQL之后,使用了新的配置文件后,MySQL服务器可以成功启动,但在登陆的时候出现了ERROR 2002 (HY000): Can’t connect to local MySQL server through socket,即无法通过socket连接到mysql服务器,同时...
最近在linux上装Aphace... can't connect to local MySQL server through socket 'var/run/mysqld/mysqld.sock' 这个把我弄得几近崩溃,我在网上查找了很多的解决办法,大概有几种解决方案: 1.权限问题 2.修改/
?php $link=mysql_connect(‘localhost’,’root’,... 运行后报错 Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ 但在 命令行中能进入mysql [root@localhost local]# mysql -u root -p E
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (111)
在Ubuntu VPS上安装Docker时,可能会遇到一个常见的错误:“Cannot connect to the Docker daemon at unix:///var/run/docker.sock.” 这个问题通常是由于Docker守护进程未运行或者是由于Linux内核版本过低导致的。...
同时,如果你试图通过命令行连接到本地MySQL服务器,可能会收到类似于“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)”的错误,这表明MySQL服务器的套接字文件也未找到或...
MySQL数据库是我们日常运维工作中经常会使用的一个重要组件,它在运行过程中可能会出现各种问题,而错误ERROR 2002 (HY000): Can't connect to local MySQL server through socket是一个比较常见的连接失败错误。...
服务器断电后重启,导致MySQL连接失败。mysql.sock文件丢失,innodb引擎表损坏,最直接的解决办法。
在MySQL的使用过程中,有时会遇到异常错误"ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)"。这个错误通常表示客户端无法通过套接字文件与MySQL服务器...
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock'(2) ``` 解决方法是使用以下命令: ``` sudo chown -R _mysql:mysql /usr/local/var/mysql ``` 然后启动 MySql 服务: `...
MySQL 错误:Can’t open file 的解决方案 MySQL 错误:Can’t open file 是一种典型的 MySQL 表受损错误,解决的办法就是修复表。出现这个错误的原因可能是你把数据库文件挪来挪去的结果,当然不排除其他原因。...