mysql ulimit_linux ulimit总结(一)

2023-11-05 20:50

本文主要是介绍mysql ulimit_linux ulimit总结(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

注:本文档实验机器为:CentOS Linux release 7.2.1511 (Core)

1、ulimit概念

功能说明:控制shell程序的资源。

语法:ulimit [-aHS][-c ][-d ][-f ][-m ][-n ][-p ][-s ][-t ][-u ][-v ]

补充说明:ulimit为shell内建指令,可用来控制shell执行程序的资源。

2、ulimit常用参数

4f087d972b9113361a2c27b29bb945ec.png

3、ulimit –a输出结果说明

dafe9d157d15f9f602d17279689695f7.png

840d8e1cc6bc4a4cd1264990ab3fb89b.png

de72ada965bb0b310f12ff692335f584.png

4、常用操作

4.1、临时修改操作

注:ulimit命令修改的数值只对当前登录用户的目前使用环境有效,系统重启或者用户退出后就会失效,ssh新打开的窗口也是失效的。

4.1.1、显示系统资源的设置

# ulimit -a

4.1.1、对生成core文件的大小不进行限制

# ulimit –c unlimited

4.1.1、限制最大可加锁内存大小

ulimit -l unlimited

4.1.1、限制最大打开文件数

ulimit –n unlimited

4.1.1、限制用户最多可以使用多少个进程

ulimit -u unlimited

4.2、永久修改

在/etc/security/limits.conf文件中修改

[root@centosDB ~]# cat /etc/security/limits.conf

*           soft    nproc   16384

*           hard    nproc   65536

*           soft    nofile  2047

*           hard    nofile  65536

*           soft    core    unlimited

*           hard    core    unlimited

注:(1)需要重启系统生效,这个在生产环境是不能接受的。

(2)经本人测试发现,以上结果其他用户的max user processes没有改变

Root帐号显示的结果

2feeaa305c212f84238b0c5738347e58.png

centosdb帐号显示的结果

2dc606f3a3831957fb245190b2052668.png

从以上结果可以看出,centosdb的max user processes,不生效啊。

(3)从root帐号下分析,

Open files显示是2047,这个值是设置的软链接的值,而max user processes显示的是65536,则是硬链接的值,那ulimit –a显示的结果到底是软链接的值,还是硬链接的值呢?(网上的资料说ulimit 默认显示的是软链接,这就要打个问号了。)

其他方法:

注:(1) 把ulimit修改命令放入/etc/profile里面,网上说,可以使全部用户都生效,经本人在centos72上测试发现,只有root用户生效,而其他用户不生效,要使其他用户也生效,需要执行 source /etc/profile命令,但是重启系统后又失效了。

(2)把ulimit修改命令放入~/.bashrc,只对当前用户生效,而其他用户不生效,想要让其他用户也生效,需要分别修改其他用户的~/.bashrc文件。

总结:从以上分析,可以看出每一种修改都有点问题,那怎么做到永久修改呢,可以这样做,临时修改+永久修改,这样子在不重启系统的情况下,资源限制能生效,重启系统的情况下,也是生效的。

4.3、案例—linux安装oracle修改资源限制

#cat /etc/security/limits.conf

oracle           soft    nproc   2047

oracle           hard    nproc   16384

oracle           soft    nofile  1024

oracle           hard    nofile  65536

注:npro表示– max number of processes

nofile表示max number of open files

5、C语言操作

Linux命令行下查看帮助,man 3 ulimit

887c85deb85420b6271a8efbcd38c880.png

会发现描述信息里有“This routine is obsolete”这句话,表示这个程序过时了。建议使用getrlimit与setrlimit或sysconf代替;(注:bash下可以正常使用,只是c操作这个api过时)

查看getrlimit与setrlimit帮助信息–man 2 setrlimit,

下面简单展示使用头文件及接口,具体可以看帮助信息

#include

#include

int getrlimit(int resource, struct rlimit *rlim);

int setrlimit(int resource, const struct rlimit *rlim);

int prlimit(pid_t pid, int resource, const struct rlimit *new_limit, struct rlimit *old_limit);

5.1、简单例子

以下操作表示一个进程能够最大创建文件的大小#include #include #include #include int main (int argc, char *argv[]){  struct rlimit limit;  /* Set the file size resource limit. */  limit.rlim_cur = 65535;  limit.rlim_max = 65535;  if (setrlimit(RLIMIT_FSIZE, &limit) != 0) {    printf("setrlimit() failed with errno=%d\n", errno);    exit(1);  }  /* Get the file size resource limit. */  if (getrlimit(RLIMIT_FSIZE, &limit) != 0) {    printf("getrlimit() failed with errno=%d\n", errno);    exit(1);  }  printf("The soft limit is %llu\n", limit.rlim_cur);  printf("The hard limit is %llu\n", limit.rlim_max);  exit(0);}

注:RLIMIT_FSIZE :The  maximum  size  of files that the process may create

5.2、例子修改core信息#include #include #include #include #define CORE_SIZE   8*1024int main(){    struct rlimit rlmt;    if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {        return -1;    }      printf("Before set rlimit CORE dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur,     (int)rlmt.rlim_max);     rlmt.rlim_cur = (rlim_t)CORE_SIZE;    rlmt.rlim_max  = (rlim_t)CORE_SIZE;     if (setrlimit(RLIMIT_CORE, &rlmt) == -1) {        return -1;    }       if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {        return -1;    }      printf("After set rlimit CORE dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur,     (int)rlmt.rlim_max);/*测试非法内存,产生core文件*/    int *ptr = NULL;    *ptr = 10;    return 0;}

5.3、Prlimit例子#define _GNU_SOURCE#define _FILE_OFFSET_BITS 64#include #include #include #include #include  #define errExit(msg)     do { perror(msg); exit(EXIT_FAILURE); \                               } while (0) int main(int argc, char *argv[]) {       struct rlimit old, new;       struct rlimit *newp;       pid_t pid;        if (!(argc == 2 || argc == 4)) {              fprintf(stderr, "Usage: %s  [ "                            "]\n", argv[0]);              exit(EXIT_FAILURE);       }pid = atoi(argv[1]); /* PID of target process */        newp = NULL;       if (argc == 4) {              new.rlim_cur = atoi(argv[2]);              new.rlim_max = atoi(argv[3]);              newp = &new;       }        /* Set CPU time limit of target process; retrieve and display        *               previous limit */        if (prlimit(pid, RLIMIT_CPU, newp, &old) == -1)              errExit("prlimit-1");       printf("Previous limits: soft=%lld; hard=%lld\n", (long long) old.rlim_cur,                     (long long) old.rlim_max);        /* Retrieve and display new CPU time limit */if (prlimit(pid, RLIMIT_CPU, NULL, &old) == -1)              errExit("prlimit-2");       printf("New limits: soft=%lld; hard=%lld\n", (long long) old.rlim_cur,                     (long long) old.rlim_max);        exit(EXIT_FAILURE);}

这篇关于mysql ulimit_linux ulimit总结(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要