• mysql 常见的几个错误问题


    Mysql常见的几个错误问题及解决方法:
    1.问题: mysql DNS反解:skip-name-resolve
     
    错误日志有类似警告:

    点击(此处)折叠或打开

    1. 120119 16:26:04 [Warning] IP address '192.168.1.10' could not be resolved: Name or service not known
    2. 120119 16:26:04 [Warning] IP address '192.168.1.14' could not be resolved: Name or service not known
    3. 120119 16:26:04 [Warning] IP address '192.168.1.17' could not be resolved: Name or service not known
    通过show processlist发现大量类似如下的连接:


    点击(此处)折叠或打开

    1. |592|unauthenticated user|192.168.1.10:35320|NULL|Connect| |login|NULL|
    2. |593|unauthenticated user|192.168.1.14:35321|NULL|Connect| |login|NULL|
    3. |594|unauthenticated user|192.168.1.17:35322|NULL|Connect| |login|NULL|
     
    skip-name-resolve 参数的作用:不再进行反解析(ip不反解成域名),这样可以加快数据库的反应时间。
     
    修改配置文件添加并需要重启:

    点击(此处)折叠或打开

    1. [mysqld] 
    2. skip-name-resolve
     

    其实就是在[mysqld]下面一行加入skip-name-resolve重启mysql服务就可以了。

    下面是更加详细的解释:

    现象:

    程序连接mysql时,mysql的error.log里面提示:

    [Warning] IP address '10.0.0.220' could not be resolved: Name or service not known

    原因:

    Mysql数据库服务器没有配置 /etc/hosts,也没有DNS服务,导致mysqld线程解析IP对应的主机名时,解析失败。

    参考资料:

    Mysql域名解析:

    当一个新的客户端尝试跟mysqld创建连接时,mysqld产生一个新线程来处理这个请求。新线程会先检查请求建立连接的主机名是否在Mysql的主机名缓冲中,如果不在,线程会尝试去解析请求连接的主机名。

    解析的逻辑如下:

    a. Mysql线程通过gethostbyaddr()把获取的IP地址解析成主机名,然后通过gethostbyname()把获取的主机名解析成IP地址,保障主机名和IP地址对应关系的准确;

    b. 如果操作系统支持使用安全进程的gethostbyaddr_r()和gethostbyname_r() 调用,Mysqld线程可以用它俩来优化主机名解析;

    c. 如果操作系统不支持安全线程调用,Mysqld进程先做一个互斥锁,然后调用gethostbyaddr()和gethostbyname()解析主机名。此时,在第一个进程释放掉主机名缓冲池的主机名之前,其它进程无法再次解析这个主机名; <-------MySQL手册里面在此处说的host name ,意思应该是指同一个IP地址和对应的第一个主机名关系。

    在启动mysqld进程是,可以使用 --skip-name-resolve 参数禁用DNS的主机名解析功能,禁用该功能后,在MySQL授权表里面,你只能使用IP地址。

    如果你所处环境的DNS非常慢 或者 有很多主机, 你可以通过禁用DNS解析功能--skip-name-resolve 或者 提高 HOST_CACHE_SIZE大小 来提升数据库的响应效率。

    禁用主机名缓冲的发方法: 使用--skip-host-cache 参数; 刷新主机名缓冲区: 执行 flush hosts 或者执行mysqladmin flush-hosts;

    禁用TCP/IP连接: 使用--skip-networking参数。

    实验:
    # grep 192.168.1.1 /etc/hosts 
    192.168.1.1 hostname_online

    sql> grant usage on *.* to root@'h_tt_%' identified by 'root';

    sql> flush hosts;

    # mysql -h 192.168.1.1 -uroot -proot

    ERROR 1045 (28000): Access denied for user 'root'@'hostname_online' (using password: YES) ### IP解析为hostname_online,不是h_tt_%,访问被拒。

    # grep 192.168.1.1 /etc/hosts

    192.168.1.1 hostname_online

    192.168.1.1 h_tt_1

    # mysql -h 192.168.1.1 -uroot -proot

    ERROR 1045 (28000): Access denied for user 'root'@'hostname_online' (using password: YES)#### mysqld没有刷新主机池缓冲池中的IP和主机名信息,此时IP对应hostname_online

    sql> flush hosts;

    # mysql -h 192.168.1.1 -uroot -proot

    ERROR 1045 (28000): Access denied for user 'root'@'hostname_online' (using password: YES) #### mysqld解析了/etc/hosts里面同一个IP对应的第一个主机名关系时,就不再解析后面这个IP对应的主机名关系

    # grep 192.168.1.1 /etc/hosts

    192.168.1.1 h_tt_1

    192.168.1.1 hostname_online

    sql> flush hosts;

    # mysql -h 192.168.1.1 -uroot -proot

    sql> exit

    【实验:】验证解析相同IP对应的第一个主机名关系后,就不再解析相同IP:

    Sql>grant usage on *.* to root@'h_tt_%' identified by ‘root';

    Sql>flush hosts;

    # grep h_tt /etc/hosts # grep h_tt /etc/hosts

    192.168.1.1hostname_online 192.168.1.1h_tt_1

    192.168.1.1h_tt_1 192,168.1.2h_tt_1

    访问mysql被拒绝; 从两个IP都可以访问mysql.

    【结论】

    此实验验证了,上述mysql手册中对"How MySQL Uses DNS"的解释。

    即mysqld线程解析/etc/hosts是,是以IP作为唯一标识的,及时一个IP对应了多个主机名,但是mysqld线程只解析第一条对应关系,不论后面有几条这个IP对应的不同主机名的记录,Mysqld进程都不会去解析,都是无效的。

    【适用环境:】

    没有DNS服务器,主机非常非常多,或者 不想维护/etc/hosts里面手动配置的IP和主机名对应列表时,可以在mysql授权时执行主机名为"%" 或者禁用IP和主机名解析功能(--skip-name-resolve)

    2.问题错误日志:Error: Can't create a new thread (errno 12)

    数据库服务器问题,数据库操作无法创建新线程。一般是有以下3个方面的原因:
    1)、MySQL 线程开得太多。
    2)、服务器系统内存溢出。
    3)、环境软件损坏或系统损坏。
     
    【问题解决】
     
    【问题解决】


    点击(此处)折叠或打开

    1. 1)进入 phpmyadmin 的 mysql 数据库中的 user 表,对数据库的用户进行编辑,修改 max_connections 的值。适当的改小一点。
    2. 2)联系服务器管理员检查服务器的内存和系统是否正常,如果服务器内存紧张,请检查一下哪些进程消耗了服务器的内存,同时考虑是否增加服务器的内存来提高整个系统的负载能力。
    3. 3)mysql版本更改为稳定版本
    4. 4)优化网站程序的sql等等
     
     
    3.  操作报错:ERROR 1010 (HY000): Error dropping database


    点击(此处)折叠或打开

    1. mysql> drop database xjtrace;
    2. ERROR 1010 (HY000): Error dropping database (can't rmdir './xjtrace/

    在做数据库删除时出现这种提示,其原因是在database下面含有自己放进去的文件,譬如*.txt文件或*.sql文件等,只要进去把这个文件删了在执行。


    点击(此处)折叠或打开

    1. mysql>drop database xjtrace;
    2. Query OK, 0 rows affected (0.00 sec)

    果断删除即可!!
     
    4.导出数据很快,导入到新库时却很慢:
     
    MySQL导出的SQL语句在导入时有可能会非常非常慢,经历过导入仅400万条记录,竟用了近2个小时。在导出时合理使用几个参数,可以大大加快导入的速度。
     
    -e 使用包括几个VALUES列表的多行INSERT语法;
    --max_allowed_packet=XXX 客户端/服务器之间通信的缓存区的最大大小;
    --net_buffer_length=XXX TCP/IP和套接字通信缓冲区大小,创建长度达net_buffer_length的行
    注意:max_allowed_packet和net_buffer_length不能比目标数据库的配置数值大,否则可能出错。
     
    首先确定目标库的参数值

    点击(此处)折叠或打开

    1. mysql> show variables like 'max_allowed_packet';
    2. +--------------------+---------+
    3. | Variable_name | Value |
    4. +--------------------+---------+
    5. | max_allowed_packet | 1048576 |
    6. +--------------------+---------+
    7. 1 row in set (0.00 sec)
    8. mysql> show variables like 'net_buffer_length';
    9. +-------------------+-------+
    10. | Variable_name | Value |
    11. +-------------------+-------+
    12. | net_buffer_length | 16384 |
    13. +-------------------+-------+
    14. 1 row in set (0.00 sec)

    根据参数值书写mysqldump命令,如:

    mysql>mysqldump -uroot -p   数据库名 -e --max_allowed_packet=1048576 -net_buffer_length=16384 > SQL文件
     
    例如:

    点击(此处)折叠或打开

    1. mysql> mysqldump -uroot -p xjtrace -e --max_allowed_packet=1048576 --net_buffer_length=16384 >xjtrace_data_`date +%F`.sql
     
    之前2小时才能导入的sql现在几十秒就可以完成了。
     

    关于一次导入数据提示的MySQL server has gone away

    关于一次导入数据提示的MySQL server has gone away

    http://roll.sohu.com/20131217/n391910784.shtml

     

    MySQL根据配置文件会限制Server接受的数据包大小。有时候大的插入和更新会受 max_allowed_packet 参数限制,导致写入或者更新失败。

    查看目前配置:

    复制代码代码如下:
    show VARIABLES like '%max_allowed_packet%';

    显示的结果为:
    复制代码代码如下:
    +--------------------+---------+
    | Variable_name      | Value   |
    +--------------------+---------+
    | max_allowed_packet | 1048576 |
    +--------------------+---------+ 

    以上说明目前的配置是:1M.
     解决方法如下:
    1. 编辑 MySQL 安装目录下的 my.ini,在最后添加以下内容:
    max_allowed_packet=16M
    2. 重启 MySQL 服务即可
     
    set global max_allowed_packet=1024*1024*16;

    可在不重启MySQL的情况下立即生效,但是重启后就会恢复原样。

     

    Aborted_clients

    mysql > show status like 'abort%';

    +------------------+-------+
    | Variable_name | Value |
    +------------------+-------+
    | Aborted_clients | 188 |
    | Aborted_connects | 53 |
    +------------------+-------+

    客户端被异常中断的数值,即连接到mysql服务器的客户端没有正常地断开或关闭。对于一些应用程序是没有影响的,但对于另一些应用程序可能你要跟踪该值,因为异常中断连接可能表明了一些应用程序有问题。

     

    原因1. MySQL 服务宕了

    判断是否属于这个原因的方法很简单,执行以下命令,查看mysql的运行时长

    $ mysql -uroot -p -e "show global status like 'uptime';"
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | Uptime        | 68928 |
    +---------------+-------+
    1 row in set (0.04 sec)

    或者查看MySQL的报错日志,看看有没有重启的信息

    $ tail /var/log/mysql/error.log
    130101 22:22:30 InnoDB: Initializing buffer pool, size = 256.0M
    130101 22:22:30 InnoDB: Completed initialization of buffer pool
    130101 22:22:30 InnoDB: highest supported file format is Barracuda.
    130101 22:22:30 InnoDB: 1.1.8 started; log sequence number 63444325509
    130101 22:22:30 [Note] Server hostname (bind-address): '127.0.0.1'; port: 3306
    130101 22:22:30 [Note]   - '127.0.0.1' resolves to '127.0.0.1';
    130101 22:22:30 [Note] Server socket created on IP: '127.0.0.1'.
    130101 22:22:30 [Note] Event Scheduler: Loaded 0 events
    130101 22:22:30 [Note] /usr/sbin/mysqld: ready for connections.
    Version: '5.5.28-cll'  socket: '/var/lib/mysql/mysql.sock'  port: 3306  MySQL Community Server (GPL)
    

    如果uptime数值很大,表明mysql服务运行了很久了。说明最近服务没有重启过。

    如果日志没有相关信息,也表名mysql服务最近没有重启过,可以继续检查下面几项内容。

    2. 连接超时

    如果程序使用的是长连接,则这种情况的可能性会比较大。

    即,某个长连接很久没有新的请求发起,达到了server端的timeout,被server强行关闭。

    此后再通过这个connection发起查询的时候,就会报错server has gone away


    $ mysql -uroot -p -e "show global variables like '%timeout';" +----------------------------+----------+ | Variable_name | Value | +----------------------------+----------+ | connect_timeout | 30 | | delayed_insert_timeout | 300 | | innodb_lock_wait_timeout | 50 | | innodb_rollback_on_timeout | OFF | | interactive_timeout | 28800 | | lock_wait_timeout | 31536000 | | net_read_timeout | 30 | | net_write_timeout | 60 | | slave_net_timeout | 3600 | | wait_timeout | 28800 | +----------------------------+----------+
    mysql> SET SESSION wait_timeout=5;
    
    ## Wait 10 seconds
    
    mysql> SELECT NOW();
    ERROR 2006 (HY000): MySQL server has gone away
    No connection. Trying to reconnect...
    Connection id:    132361
    Current database: *** NONE ***
    
    +---------------------+
    | NOW()               |
    +---------------------+
    | 2013-01-02 11:31:15 |
    +---------------------+
    1 row in set (0.00 sec)
    

    3. 进程在server端被主动kill

    这种情况和情况2相似,只是发起者是DBA或者其他job。发现有长时间的慢查询执行kill xxx导致。

    $ mysql -uroot -p -e "show global status like 'com_kill'"
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | Com_kill      | 0     |
    +---------------+-------+

    4. Your SQL statement was too large.

    当查询的结果集超过 max_allowed_packet 也会出现这样的报错。定位方法是打出相关报错的语句。

    用select * into outfile 的方式导出到文件,查看文件大小是否超过 max_allowed_packet ,如果超过则需要调整参数,或者优化语句。

    mysql> show global variables like 'max_allowed_packet';
    +--------------------+---------+
    | Variable_name      | Value   |
    +--------------------+---------+
    | max_allowed_packet | 1048576 |
    +--------------------+---------+
    1 row in set (0.00 sec)
    

    修改参数:

    mysql> set global max_allowed_packet=1024*1024*16;
    mysql> show global variables like 'max_allowed_packet';
    +--------------------+----------+
    | Variable_name      | Value    |
    +--------------------+----------+
    | max_allowed_packet | 16777216 |
    +--------------------+----------+
    1 row in set (0.00 sec)
    
  • 相关阅读:
    p(str or array) 传递数据以易于阅读的样式格式化后输出 bootstarp样式的打印函数
    [Err] 1067
    php 正则表达式
    Docker使用及dnmp构建
    记一次Ubuntu18.04升级到19.10的经历
    面试-Redis
    ubuntu截图软件deepin scrot
    docker 搭建 Hadoop
    Docker 遇到的坑
    RabbitMQ遇到的坑
  • 原文地址:https://www.cnblogs.com/youxin/p/5354267.html
Copyright © 2020-2023  润新知