启用swoole时报的错误,可以确定是内存问题
[2019-04-09 09:04:32 @220.0] WARNING swShareMemory_mmap_create: mmap(260046944) failed. Error: Cannot allocate memory[12]
[2019-04-09 09:04:32 @220.0] ERROR calloc[1] failed
我们查看下内存:
[root@VM_0_17_centos docker]# free -m
total used free shared buff/cache available
Mem: 992 495 85 116 412 216
Swap: 0 0 0
swap全都是0明显有问题,那就加点swap:
sudo dd if=/dev/zero of=/swapfile bs=1M count=1024 #增加1G的
sudo mkswap /swapfile
sudo swapon /swapfile
[root@VM_0_17_centos docker]# free -m
total used free shared buff/cache available
Mem: 992 494 72 116 426 217
Swap: 1023 419 604
然后就顺利启用swoole了。
free -m命令详解
[root@localhost ~]# free -m
total used free shared buffers cached
Mem: 7869 7651 218 1 191 5081
-/+ buffers/cache: 2378 5490
Swap: 478 139 339
total1:表示物理,内存总量1,2表示1,2行的内容
used1:总计分配给缓存(包含Buffer和cache)使用的数量,但其中可能部分缓存并未实际使用
free1:未被分配的内存
shared1:共享内存,一般系统不会用到,这里也不讨论
buffers1:系统分配但未被使用的buffers数量
cached1:系统分配但未被使用的cache数量
used2:实际使用的buffers和cache总量,也是实际使用的内存总量
free2:未被使用的Buffers和cache和未被分配的内存之和,这就是系统当前实际可用内存。
如下公式:
buffer和cache也是内存的一部分,如果需要,可以释放这2部分的内存
pagecache和buffercache的区别:
pagecache实际上是针对文件系统的,是文件的缓存,在文件上的数据会缓存到pagecahce,文件的逻辑层需要映射到实际的物理磁盘,这种映射关系由文件系统来完成,当pagecache中的数据需要刷新时,pagecache中的数据交给buffercache。但这种处理在2.6版本内核之后就变得简单了,没有真正意义的cache操作。
buffercache是针对磁盘块的缓存,也就是在没有文件系统的情况下,直接对磁盘操作的数据会缓存到buffercache中,如:文件系统的元数据都会缓存到buffercache中。简单来说,
pagecache用来缓存文件数据,buffercache用来缓存磁盘数据。在有文件系统的情况下,对文件操作,数据会缓存到pagecache。若直接采用dd工具对磁盘进行读写,那么数据会
缓存到buffercache。
cache和buffer的区别:
a buffer is something that has yet to be "written" to disk
a cache is something that has been "read" from the disk and stored for later use
对于共享内存(shared memory) :主要用于在unix下不同进程间共享数据,是进程间通信的一种方法,一般的应用程序不会申请共享内存。
cache:高速缓存,是位于CPU和主内存间一种容量较小但速度很高的存储器。由于CPU从主内存获取数据要等待一段时间,cahce中保存这CPU刚用过或循环使用的一部分数据,CPU再次使用该部分数据时,可从cache中直接调用,这样就减少了CPU的等待时间。cache又分为L1和L2,L2早期焊在主板上,现在都在CPU中。常见的L2容量有256KB和512KB
3.free中的buffer和cache都是基于内存
buffer作为buffercache的内存,是块设备的读写缓冲区,
cache作为pagecache的内存,文件系统的cache
如果cache的值很大,说明cache中的文件数很多,如果频繁访问到的文件都能被cache住,那么磁盘的读IO必会非常小。
如何释放cachememory:
To free pagecache:
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
#注意,释放前最好sync一下,防止丢失数据,但是一般情况下没有必要手动释放内存
总结:
cache是cpu和内存之间的,buffer是内存和磁盘之间的,都是为了解决速度不对等的问题。
缓存(cache)是把读取过来的数据保存起来,重新读取时若命中,就不去硬盘了,若没有命中就去读硬盘,其中的数据会根据读取频率进行组织,把最频繁读取的内容放在最容易找到的位置,把不再读取的内容不断往后排,直至从中删除。
缓冲(buffer)时根据磁盘的读写设计的,把分散的写操作集中进行,减少磁盘碎片和硬盘的的反复寻道,从而提高系统性能,linux有一个守护进程定期清空缓冲内容(即写入磁盘)。
也可以通过sync命令手动清空缓冲。举个例子:我这里有个ext2的的u盘,我往里面cp一个3M的mp3,但u盘的灯没有跳动,过了一会(或者手动输入sync),U盘的灯就跳动起来了。卸载设备时会清空缓存,所以有时候卸载一个设备要等上几秒中。
修改/etc/sysctl.conf中的vm.swappiness右边的数字可以在下次开机时调节swap使用策略。该数字范围是0~100,数字越大越倾向于使用swap。默认为60,可以改一下试试。–两者都是RAM中的数据。
buffer是即将要写入磁盘的,而cache是被从磁盘中读出来的。
buffer由各种进程分配,被用在如输入队列等方面。一个简单的例子是某个进程要求有多个字段读入,在所有字段被读入完整之前,进程把先前读入的字段放在buffer中保存。
cache经常被用在磁盘的I/O请求上,如果有多个进程要访问某个文件,于是该文件被做成cache以便下次被访问,这样可以提高系统性能。
Buffer Cachebuffer cache,又称bcache,其中文名称为缓冲器高速缓冲存储器,简称缓冲器高缓。另外,buffer cache按照其工作原理,又被称为块高缓