MYSQL问题解决:error establishing a database connection problem

本文主要是介绍MYSQL问题解决:error establishing a database connection problem,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

〇、问题调研

 一、Swap空间:

二、修改innodb_buffer_pool_size


〇、问题调研

解决问题error establishing的步骤。

1、发现error establishing a database connection的问题——稍微google一下就知道是数据库的问题

2、去查数据库mysql的err log。具体位置应该是在/var/log/mysqld.log

3、查了以后我就发现是 out of memory,Cannot allocate memory for the buffer pool的问题了

4、google了一下,这种问题有两种解决方法:

  一种方法就是增加swap文件,一般这种方法就足够解决问题。

  另一种就是修改你的innodb_buffer_pool_size


 一、Swap空间:

Swap分区在系统的物理内存不够用的时候,把硬盘空间中的一部分空间释放出来,以供当前运行的程序使用。那些被释放的空间可能来自一些很长时间没有什么操作的程序,这些被释放的空间被临时保存到Swap分区中,等到那些程序要运行时,再从Swap分区中恢复保存的数据到内存中。

先来说下swap的工作原理:

swap 的工作我们可以看成是一个静态的中转装置。假如我们的内存是512M的。当有任务来了但是由于之前任务和并发任务占有了许多的工作空间,使得这个工作的位 置要大于512M的空间时,就会导致启动失败。因为没有它的位置。这个时候许多的工程师和技术牛人们就发明了这个swap空间,即虚拟内存的技术。 swap空间实际是在硬盘上的。工作原理是:当我们有 一个任务来到的时候,发现物理内存空间不够了,那么我们把这之前用户开启了但是经常没有使用的空间给释放出来,将他们的一些信息存入swap空间。然后给 这个后来的程序先用物理内存空间,当我要用到之前的程序的时候我们再从swap空间将之前保存的内容调用回来。

增加swap空间的两种方法:第一种是创建一个swap分区,第二种是创建swap文件,这里我们介绍第二种比较简单的方法

1、查看本机有没有已经配置的swap空间,利用下面的命令可以看到swap空间的使用情况

swapon -s

 如没有配置swap空间,发现敲完上面命令什么也没有。如果已配置,会出现下面的状态,本人服务器上配置的是1G:

 还有一种方法就是用free,它会显示出系统整体的内存使用情况。

free -m

 

2、查看可用的硬盘空间,因为swap空间实际上要用的是硬盘空间,所以,当然你要查看还有多少硬盘空间可设置swap

df -h

 

 3、创建一个swap文件,并更改其权限

创建缓存文件
网上有很多方法,例如:sudo fallocate -l 2G /swapfile,
但是容易报错:fallocate: /swapfile: fallocate failed: Operation not supported
目前未找到原因,所以只好用另一种方式 ,设置1G空间:

dd if=/dev/zero of=/swapfile bs=1024 count=1024000

一般建议设置swap空间大小与为物理内存大小2倍,根据情况而定。if 表示infile,一般不做修改; of表示outfile,设置为想要创建文件夹全路径; bs=1024代表增加的模块大小B,count=1024000代表1024000个模块,也就是1G空间。之后会发现这个文件的可读权限是开发给任何人的,这样非常不安全,因此我们要改变一下这个文件的权限。

sudo chmod 600 /swapfile

我们查看这个文件的权限

 4、使用这个swap文件

使用下面这个命令,告诉系统我们要把这个文件作为swap文件了

sudo mkswap /swapfile

 然后就是要使用这个swap文件了:

sudo swapon -f /swapfile
sudo swapon -s

然后我们再用free -m命令查看内存的使用情况,会发现这个swap文件已经ok了!

5、使得这个新加入的swap文件永久生效。

如果需要在系统启动的时候就生效,我们要在/ect/fstab文件里加入下面一行

先用vi打开文件,然后添加下面一行,然后保存。

sudo vi /etc/fstab
/swapfile   swap    swap    sw  1023996   1023996

 重启检查是否已完成配置

 6.取消swap  

1)查看swap文件位置

[root@iZwz93t5hvwgq7l1r5y8cmZ /]# swapon -s
Filename                                Type            Size    Used    Priority
/swapfile                               file    1023996  814464       -1

2)取消swap、删除文件

swapoff /swapfile
rm -rf /swapfile

3)检查

[root@iZwz93t5hvwgq7l1r5y8cmZ /]# free -hmtotal        used        free      shared  buff/cache   available
Mem:           992M        815M         67M         72K        109M         43M
Swap:          999M        893M        106M

 7.更改Swap配置(依赖度)

1)查看依赖度

[root@iZwz93t5hvwgq7l1r5y8cmZ var]# cat  /proc/sys/vm/swappiness 
30

swappiness值的范围为0-100,值越高代表对swap依赖程度越高,但是swap是基于文件储存的缓存交换机制,所以效率明显低于物理内存,swappiness值过高的情况下容易导致物理内存远远没有耗尽便开始使用swap;一般来说swappiness值可以设置为10-60,ssd可以设置的高一点;

2)修改当前swappiness值为30,重启后失效

sysctl vm.swappiness=30

3)更改系统配置值,重启后依旧有效

echo "vm.swappiness = 30"  >>  /etc/sysctl.conf

二、修改innodb_buffer_pool_size

建议从参考文章  https://blog.csdn.net/sunny05296/article/details/78916775

这篇关于MYSQL问题解决:error establishing a database connection problem的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/939221

相关文章

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss

MySQL8.0设置redo缓存大小的实现

《MySQL8.0设置redo缓存大小的实现》本文主要在MySQL8.0.30及之后版本中使用innodb_redo_log_capacity参数在线更改redo缓存文件大小,下面就来介绍一下,具有一... mysql 8.0.30及之后版本可以使用innodb_redo_log_capacity参数来更改

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个