centos mysql 内存,centos7安装MySQL

各位老铁们好,相信很多人对centos mysql 内存都不是特别的了解,因此呢,今天就来为大家分享下关于centos mysql 内存以及centos7安装MySQL的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

CentOS下SWAP分区建立及释放内存详解

方法一:

一、查看系统当前的分区情况:

free-m

二、创建用于交换分区的文件:

dd if=/dev/zero of=/whatever/swap bs=block_size(10M)count=number_of_block(3000)

三、设置交换分区文件:

mkswap/export/swap/swapfile

四、立即启用交换分区文件:

swapon/whateever/swap

五、若要想使开机时自启用,则需修改文件/etc/fstab中的swap行:

/whatever/swap swap swap defaults 0 0

方法二

增加交换分区空间的方法:

1.查看一下/etc/fstab确定目前的分区

2.swapoff/dev/hd**

3.free看一下是不是停了.

4.fdisk删了停掉的swap分区

5.重新用FDISK建一个新的SWAP分区

6.mkswap/dev/hd**把新的分区做成swap

7.swapon/dev/hd**打开swap

8.修改/etc/fstab

操作实例:

1.查看系统Swap空间使用

# free

total used free shared buffers cached

Mem: 513980 493640 20340 0 143808 271780

-/+ buffers/cache: 78052 435928

Swap: 1052248 21256 1030992

2.在空间合适处创建swap文件

# mkdir swap

# cd swap

# dd if=/dev/zero of=swapfile bs=1024 count=10000

10000+0 records in

10000+0 records out

# ls-al

total 10024

drwxr-xr-x 2 root root 4096 7月 28 14:58.

drwxr-xr-x 19 root root 4096 7月 28 14:57..

-rw-r--r-- 1 root root 10240000 7月 28 14:58 swapfile

# mkswap swapfile

Setting up swapspace version 1, size= 9996 KiB

3.激活swap文件

# swapon swapfile

# ls-l

total 10016

-rw-r--r-- 1 root root 10240000 7月 28 14:58 swapfile

# free

total used free shared buffers cached

Mem: 513980 505052 8928 0 143900 282288

-/+ buffers/cache: 78864 435116

Swap: 1062240 21256 1040984

生成1G的文件

# dd if=/dev/zero of=swapfile bs=10M count=3000

创建为swap文件

#mkswap swapfile

让swap生效

#swapon swapfile

查看一下swap

#swapon-s

[root@cluster/]# swapon-sFilenameTypeSizeUsedPriority/dev/sda3               partition10201161728-1/state/partition1/swap/swapfile    file307199920-2

加到fstab文件中让系统引导时自动启动

#vi/etc/fstab

/state/partition1/swap/swapfil swap swap defaults 0 0

完毕。

二,LINUX释放内存

细心的朋友会注意到,当你在linux下频繁存取文件后,物理内存会很快被用光,当程序结束后,内存不会被正常释放,而是一直作为caching.这个问题,貌似有不少人在问,不过都没有看到有什么很好解决的办法.那么我来谈谈这个问题.

先来说说free命令

[root@cluster/]# free-m

total   used   free  shared buffers  cached

Mem:    31730  31590   139    0    37  27537

-/+ buffers/cache:   4015  27714

Swap:   30996    1  30994

其中:

total内存总数

used已经使用的内存数

free空闲的内存数

shared多个进程共享的内存总额

buffers Buffer Cache和cached Page Cache磁盘缓存的大小

-buffers/cache的内存数:used- buffers- cached

+buffers/cache的内存数:free+ buffers+ cached

可用的memory=free memory+buffers+cached

有了这个基础后,可以得知,我现在used为163MB,free为86,buffer和cached分别为10,94

那么我们来看看,如果我执行复制文件,内存会发生什么变化.

[root@cluster/]# cp-r/etc~/test/

[root@cluster/]# free-m

total   used   free  shared buffers  cached

Mem:    31730  31590   139    0    37  27537

-/+ buffers/cache:   4015  27714

Swap:   30996    1  30994

在我命令执行结束后,used为244MB,free为4MB,buffers为8MB,cached为174MB,天呐都被cached吃掉了.别紧张,这是为了提高文件读取效率的做法.

引用[url][/url]为了提高磁盘存取效率, Linux做了一些精心的设计,除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换),还采取了两种主要Cache方式:Buffer Cache和Page Cache。前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache有效缩短了 I/O系统调用(比如read,write,getdents)的时间。

那么有人说过段时间,linux会自动释放掉所用的内存,我们使用free再来试试,看看是否有释放?

[root@cluster/]# free-m

total   used   free  shared buffers  cached

Mem:    31730  31590   139    0    37  27537

-/+ buffers/cache:   4015  27714

Swap:   30996    1  30994

MS没有任何变化,那么我能否手动释放掉这些内存呢???回答是可以的!

/proc是一个虚拟文件系统,我们可以通过对它的读写操作做为与kernel实体间进行通信的一种手段.也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整.那么我们可以通过调整/proc/sys/vm/drop_caches来释放内存.操作如下:

[root@cluster/]# cat/proc/sys/vm/drop_caches

0

首先,/proc/sys/vm/drop_caches的值,默认为0

[root@cluster/]# sync

手动执行sync命令(描述:sync命令运行 sync子例程。如果必须停止系统,则运行 sync命令以确保文件系统的完整性。sync命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O和读写映射文件)

[root@server test]# echo 3/proc/sys/vm/drop_caches

[root@server test]# cat/proc/sys/vm/drop_caches

3

将/proc/sys/vm/drop_caches值设为3

[root@server test]# free-m

total   used   free  shared buffers  cached

Mem:     249    66   182    0    0    11

-/+ buffers/cache:    55   194

Swap:    511    0   511

再来运行free命令,发现现在的used为66MB,free为182MB,buffers为0MB,cached为11MB.那么有效的释放了buffer和cache.

有关/proc/sys/vm/drop_caches的用法在下面进行了说明

/proc/sys/vm/drop_caches(since Linux 2.6.16)

Writing to this file causes the kernel to drop clean caches,

dentries and inodes from memory, causing that memory to become free.

To free pagecache, use echo 1/proc/sys/vm/drop_caches;

to free dentries and inodes, use echo 2/proc/sys/vm/drop_caches;

to free pagecache, dentries and inodes, use echo 3/proc/sys/vm/drop_caches.

Because this is a non-destructive operation and dirty objects

这几天发现linux系统内存一直涨,即使把apache和mysql关闭了,内存也不释放,可以使用以下脚本来释放内存:

脚本内容:

#!/bin/sh

# cache释放:

# To free pagecache:

/bin/sync

/bin/sync

#echo 1/proc/sys/vm/drop_caches

# To free dentries and inodes:

#echo 2/proc/sys/vm/drop_caches

# To free pagecache, dentries and inodes:

echo 3/proc/sys/vm/drop_caches

利用系统crontab实现每天自动运行:

crontab-e

输入以下内容:

00 00***/root/Cached.sh

每天0点释放一次内存,这个时间可以根据自己需要修改设置

在运行./Cached.sh时如果提示错误:Permission denied权限的问题,可以运行

mysql 5.6与5.7内存参数优化内存占用为30MB左右

MySQL 5.6和 5.7默认启动时占用内存高达400多兆,对于小型内存应用而言,这样的内存占用率明显偏高,可能导致系统崩溃。为了解决这一问题,我们可以通过编辑 `/etc/my.cnf`文件,在 `[mysqld]`下调整或修改以下参数以优化内存使用。

具体调整如下:

1. `performance_schema_max_table_instances= 200`

2. `table_definition_cache= 100`

3. `table_open_cache= 100`

调整这三个参数的值,可以显著降低内存占用,将 MySQL使用的内存减少到约60兆左右,大大降低了默认内存使用量。

进一步的调整包括:

1. `innodb_buffer_pool_size= 2M`

2.禁用 `performance_schema`功能(默认启用,占用大量内存)

在完成上述调整后,MySQL的内存使用量大约降至22兆。以下是完整的配置文件示例,适用于 CentOS 6 64位系统,使用 yum安装的环境:

通过 ssh登录服务器或 VPS,编辑 `/etc/my.cnf`文件,执行以下配置:

`# For advice on how to change settings please see`

`dev.mysql.com/doc/refman/`

`[mysqld]`

`# innodb_buffer_pool_size= 128M`

`# log_bin`

`#`

`# join_buffer_size= 128M`

`# sort_buffer_size= 2M`

`# read_rnd_buffer_size= 2M`

`datadir=/var/lib/mysql`

`socket=/var/lib/mysql/mysql.sock`

`#symbolic-links=0`

`skip-external-locking`

`key_buffer_size= 8M`

`max_allowed_packet= 1M`

`table_open_cache= 4`

`sort_buffer_size= 64K`

`read_buffer_size= 256K`

`read_rnd_buffer_size= 256K`

`net_buffer_length= 2K`

`thread_stack= 240K`

`innodb_buffer_pool_size=2M`

`performance_schema_max_table_instances=50`

`table_definition_cache=50`

`table_open_cache=32`

`max_connections=50`

`max_user_connections=35`

`wait_timeout=10`

`interactive_timeout=15`

`long_query_time=5`

`symbolic-links=0`

`sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES`

`[mysqld_safe]`

`log-error=/var/log/mysqld.log`

`pid-file=/var/run/mysqld/mysqld.pid`

以上配置文件中包含了多个参数调整,旨在降低内存占用,提高性能和稳定性。在实际应用中,根据服务器资源和业务需求进行微调,以达到最佳的性能和资源利用。

实例详解MySQL占用内存过大解决方法

本文旨在阐述解决MySQL内存占用过大的方法,通过调整配置文件来优化内存使用。以Windows Service 2016和CentOS7两种系统为例,介绍如何通过调整相关配置来减轻MySQL对内存的压力。

对于资源有限的服务器,合理管理内存至关重要。以2核4G5M的服务器为例,面对4G内存的限制,加上MySQL的内存消耗,容易导致资源紧张。在个人服务器上,MySQL内存使用情况可能差异较大,但都可能面临内存占用过高的问题。

要解决MySQL内存占用过大的问题,首先需要找到并修改配置文件。对于Windows Service 2016,配置文件通常位于C:\ProgramData\MySQL\MySQL Server 8.0\my.ini;对于CentOS7,则在/etc/my.cnf。如果配置文件已被修改,应根据实际情况找到正确路径。

调整的关键配置项包括:

table_definition_cache:设置为400。此选项存储表定义数量,增加此值可加速表的打开速度,但占用更少空间,且不使用文件描述符。最小值和默认值均为400。

table_open_cache:设置为256。此选项用于缓存已打开的表,减少访问磁盘的次数。增加此值会增加文件描述符的数量,因此确保在[mysqld safe]部分的“open files limit”变量设置为至少4096。

performance_schema:设置为off。此选项用于监控MySQL server资源消耗等,关闭后可节省资源,但不会影响server行为。

调整配置后,保存并退出。随后重启MySQL服务。Windows Service 2016下,以管理员身份启动控制台,分别执行`net stop mysql`和`net start mysql`命令;CentOS7则直接执行`service mysqld restart`或`/etc/init.d/mysqld restart`。

重启后,观察MySQL内存占用情况。以Windows Service 2016为例,内存占用降至约62M;CentOS7则增加至约92M。通过上述方法,可以有效降低MySQL的内存占用,但需注意,内存优化的同时可能会影响到性能,根据实际情况调整。

总结,通过合理调整MySQL配置文件中的相关参数,可以在不牺牲大量性能的前提下,有效降低内存占用,优化服务器资源利用。然而,对于吞吐量要求较高的场景,需要根据实际请求进行更详细的性能调整和优化。

阅读剩余
THE END