zoukankan      html  css  js  c++  java
  • mysql无法启动

    linux下mysql无法启动的解决方法  
    2010-02-23 15:34:36| 分类: UNIX |字号 
    刚开始学mysql时都是用redhat自带的。启动是什么 /rc.d/init.d/ start 
     这很简单,但是后来越学越多,系统自带的mysql,有的是版本太低,有的是与  自己想要装的web服务需要的低版本的mysql  
     后来自己学着以tar的方式安装mysql,我的mysql装在/usr/local/mysql目录下启  
     动碰到过很多问题。最常见的是: 
     ERROR 2002: Can't connect to local MySQL server through socket  
     '/tmp/mysql.sock' (111)  
     解决办法: 
     [root@test mysql]# /usr/local/mysql/bin/mysqladmin -u root /  > -S /var/lib/mysql/mysql.sock password 'your.passwd'  或者做个连接 
     ln -s /var/lib/mysql/mysql.sock /tmp 
     其实提示找不到 /tmp/mysql.sock有时也并不是/tmp目录下没这个文件,是启动  命令不对,我碰到过 
     常见的几种启动方式,自己也不是记得很清楚,如果你确定tmp下有mysql.sock这  个文件不妨试试另外的几个命令  /usr/local/mysql/bin/mysql -u root -p  /usr/local/mysql/bin/mysqld --user=mysql&  /usr/local/mysql/bin/mysqld --user=root&  /usr/local/mysql/bin/mysqld_safe --user=root&  /usr/local/mysql/bin/mysqld_safe --user=mysql& 
     /usr/local/mysql/bin/safe_mysqld--uer=root&(注意safe_mysqld与mysqld_safe是不同的,&表示mysql在后台运行)我的就会报错了  STOPPING server from pid file 
     /usr/local/mysql/data/localhost.localdomain.pid  060304 11:46:21 mysqld ended 
     这是权限问题,我的mysql目录属于root用户,也属于root群组,改用mysqld_safe启动就没问题了,  大家只要注意这几个mysql,safe_mysqld,mysqld_safe,mysqld,mysqladmin.多试  几次 
     其实有时mysql已经正常启动了,查看mysql是否启动命令  ps -aux | grep mysqld  会看到如下类似内容 
     mysql 6394 0.0 1.5 10528 992 pts/3 S 16:16 0:00  /usr/local/mysql/ 


    应届生求职季宝典 开启你的职场征途 简历撰写 笔试真题 面试攻略 专业技能指导 公务员专区


     mysql 6395 0.0 1.5 10528 992 pts/3 S 16:16 0:00  /usr/local/mysql/ 
     mysql 6396 0.0 1.5 10528 992 pts/3 S 16:16 0:00  /usr/local/mysql/ 
     root 6422 0.0 1.1 2408 732 pts/3 S 16:20 0:00 grep  mysql  
     查看mysql是否在监听端口命令  netstat -tl | grep mysql netstat -ant 会看到如下类似内容  tcp 0 0 *:mysql *:* LISTEN 
    启动mysql 报错: 
    ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2) 
    1、先查看 /etc/rc.d/init.d/mysqld status 看看m y s q l 是否已经启动. 另外看看是不是权限问题. 
    2、确定你的mysql.sock是不是在那个位置, 
    mysql -u 你的mysql用户名 -p -S /var/lib/mysql/mysql.sock 3、试试:service mysqld start 
    4、如果是权限问题,则先改变权限 #chown -R mysql:mysql /var/lib/mysql [root@localhost ~]# /etc/init.d/mysqld start 启动 MySQL: [ 确定 ] 
    [root@localhost ~]# mysql -uroot -p 
    ERROR 2002 (HY000): Can't connect to local server through socket '/var/lib/mysql/mysql.sock' (2) 
     原因是,/var/lib/mysql 的访问权限问题。  
    shell> chown -R mysql:mysql /var/lib/mysql 


     
    接着启动服务器 
    shell> /etc/init.d/mysql start 
    服务器正常启动后察看 /var/lib/mysql 自动生成mysql.sock文件。 但是我的问题仍然没有得到解决。 问题终于解决: 
    方法: 修改/etc/my.conf: [mysqld] 
    datadir=/usr/local/mysql/data socket=/var/lib/mysql/mysql.sock [mysql.server] user=mysql 
    basedir=/usr/local/mysql 
    If there is not currently a section called [client], add one at the bottom of the file and copy the socket= line under the [mysqld] section such as: [client] 
    socket=/var/lib/mysql/mysql.sock 
    发现依旧如此,运行/etc/init.d/mysql start报错: Starting MySQLCouldn't find MySQL manager or server 
     是mysqld服务没启,运行/usr/local/mysql/bin/mysqld_safe &  
    问题解

  • 相关阅读:
    OOP、DI、IOC的情爱恩仇录
    NuGet:添加EntityFramework
    DataGrid之DataGridComboBoxColumn,DataGridCheckBoxColumn,DataGridHyperlinkColumn,DataGridTextColumn
    JohnSon:动态创建模块选项卡
    maf实例
    MVVM理解之逐步重构成为MVVM模式,比MVC的独到之处
    我学Unity系列1:Unity和Mef的比较
    微软一站式代码资料
    匿名方法,泛型委托,Lambda表达式
    关于JS表单验证(转)
  • 原文地址:https://www.cnblogs.com/chenzhao/p/3902366.html
Copyright © 2011-2022 走看看