这篇文章主要介绍“postgresql安装过程中内核资源的配置详情”,在日常操作中,相信很多人在postgresql安装过程中内核资源的配置详情问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”postgresql安装过程中内核资源的配置详情”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!1、共享内存和信号量Shared Memory and Semaphores修改/etc/sysctl.conf文件,linux一般只修改如下两个参数即可,其中kernel.shmmax值和shared_buffers一样,一般设置为物理内存的40%即可免费主机域名,其他的参数的默认值非常大,通常不需要更改。kernel.shmmax=XXXkernel.shmall=XXSHMMAX:共享内存段的最大大小,单位bytesSHMALL:可用共享内存的总数,单位bytes的话值和SHMMAX一样,单位是pages的话值等于SHMMAX/PAGE_SIZElinux查看Block size大小的方法tune2fs -l /dev/sda1 |grep ‘Block size’linux查看Page size大小的方法getconf PAGESIZE2、systemd RemoveIPC修改/etc/systemd/logind.conf文件,增加RemoveIPC=no即可在RHEL7.2中,systemd-logind 服务引入了一个新特性,该新特性是:当一个user完全退出os之后,remove掉这个user所有的IPC objects。系统用户除外。“系统用户”由/etc/login.defs中的SYS_UID_MAX设置确定。该特性由/etc/systemd/logind.conf参数文件中RemoveIPC选项来控制。3、资源限制Resource Limits修改/etc/security/limits.conf文件,主要是限制每个用户的进程数,每个进程打开的文件数,示例如下postgres soft nproc 2047postgres hard nproc 16384postgres soft nofile 1024postgres hard nofile 655364、Linux内存过量使用Linux Memory Overcommit修改/etc/sysctl.conf文件,增加vm.overcommit_memory=2Linux对大部分申请内存的请求都回复”yes”,以便能跑更多更大的程序。因为申请内存后,并不会马上使用内存。这种技术叫做 Overcommit。当linux发现内存不足时,会发生OOM killer(OOM=out-of-memory)。它会选择杀死一些进程(用户态进程,不是内核线程),以便释放内存。在Linux 2.4及更高版本中,默认的虚拟内存行为对于PostgreSQL不是最优的。由于内核实现内存过度提交的方式,如果PostgreSQL或其他进程的内存需求导致系统耗尽虚拟内存,内核可能会终止PostgreSQL postmaster(主服务器进程)。如果内存紧张,增加操作系统的交换空间可以帮助避免这个问题,因为只有当物理内存和交换空间耗尽时才会调用内存不足(out- memory, OOM)杀手。如果PostgreSQL本身是导致系统内存不足的原因,那么可以通过更改配置来避免这个问题。最好减少max_connections,而使用外部连接池软件。在Linux 2.6及更高版本上,可以修改内核的行为sysctl -w vm.overcommit_memory=2。overcommit_memory可选值:0、1、2。0, 表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。1, 表示内核允许分配所有的物理内存,而不管当前的内存状态如何。2, 表示内核允许分配超过所有物理内存和交换空间总和的内存5、大页内存Linux Huge Pages系统支持大页内存的情况下,修改/etc/sysctl.conf文件,增加vm.nr_hugepages=XX,即启用大页内存。PostgreSQL中大页内存的默认行为是尽可能使用它们,并在失败时回退到正常页面。要强制使用大页内存,可以在postgresql.conf中将huge_pages设置为on。查看内存是否支持大页内存,cat /proc/meminfo查看是否有PageTables、HugePages_Total、Hugepagesize、HugePages_Free、HugePages_Rsvd等项,如果没有,需要内核配置CONFIG_HUGETLBFS=y、CONFIG_HUGETLB_PAGE=y支持大内存页确定vm.nr_hugepages值的方法$ head -1 $PGDATA/postmaster.pid4170$ pmap 4170 | awk ‘/rw-s/ && /zero/ {print $2}’6490428K$ grep ^Hugepagesize /proc/meminfoHugepagesize: 2048 kB以上6490428/2048=3170,所以编辑/etc/sysctl.conf文件修改vm.nr_hugepages=3170oracle的算法# grep Hugepagesize /proc/meminfoFor example, if /proc/meminfo lists the large page size as 2 MB, and the total SGA size for the instance is 1.6 GB, then set the value for the vm.nr_hugepages kernel parameter to 820 (1.6 免费主机域名GB / 2 MB = 819.2).到此,关于“postgresql安装过程中内核资源的配置详情”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云技术网站,小编会继续努力为大家带来更多实用的文章!
这篇文章主要为大家展示了“如何解析SQL”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解析SQL”这篇文章吧。首先要把这个概念记在脑中:“声明”。 SQL 语言是为计算机声明了一个你想从原始数据中获得什么样的结…