• Postgres数据库在Linux中优化


    I/O 优化
    1 打开 noatime nodirtime,async

    方法: 修改 /etc/fstab

    stat 命令查看 

    2 调整预读
    方法: 查看 sudo blockdev --getra /dev/sda
    设置 sudo blockdev --setra 4096 /dev/sdf (4096个扇区,即2M)
    3 调整虚拟内存参数
    A 方法: 查看 cat /proc/sys/vm/wappiness
    设置 vi /etc/sysctl.conf 添加

    vm.swappiness=0 虚拟内存参数 范围 0-100 越大越倾向使用swap空间 ,为了使数据库性能尽量平稳此参数设置为0

    vm.overcommit_memory=2 (0 启发式策略、1 调用总成功、2 禁用overcommit,完全避免OOM killer)   
    生效 sysctl -p

    swapoff -a

    B 方法:

    查看命令 vmstat -an 1 或 cat /proc/meminfo  

    4 写缓存优化

    vm.dirty_background_radio

    vm.dirty_radio

    vm.dirty_writeback_centisecs

    物理内存大将至调低些
    5 调整I/O 调度

     deadline 平衡所有请求,避免某个请求饿死,让响应时间最优化。

    A echo deadline > /sys/block/sddd/queue/scheduler

    B 修改 grub.conf

    elevator=deadline

    内存优化

    share_buffers 共享缓存区 推荐值内存的1/4 不要超过 1/2.

    work_mem 每个进程单独分配的内存

    maintence_work_mem 每个进程单独分配的内存,用于维护操作。

    双缓存的优化

    说明:数据库中对数据块设计了专门的共享内存缓存区,数据库的数据文件都在文件系统中,操作系统的文件系统也有缓存。

    数据库配置 huge_pages = try

    sysctl vm.nr_hugepages=10240

         

  • 相关阅读:
    Merge sorted ranges
    call_once/once_flag的使用
    对‘boost::serialization::singleton_module::get_lock()’未定义的引用
    C++多线程lock_guard
    长度为0的数组—— Arrays of Length Zero
    Utunbu VLC 播放器播放本机rtp码流
    Utunbu VLC 播放器播放本机h264码流
    Declaration of non-local variable in 'for' loop
    ZFEC--Demo--C语言接口
    malloc-demo
  • 原文地址:https://www.cnblogs.com/zhangeamon/p/5485625.html
Copyright © 2020-2023  润新知