zoukankan      html  css  js  c++  java
  • 源码编译安装postgresql

    安装准备

    修改操作系统参数 ,修改 /etc/sysctl.conf

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    kernel.shmmni = 4096  
    kernel.sem = 501000 6412800000 501000 12800
    fs.file-max = 767246
    net.ipv4.ip_local_port_range = 1024 65000
    net.core.rmem_default = 1048576
    net.core.rmem_max = 1048576
    net.core.wmem_default = 262144
    net.core.wmem_max = 262144
    net.ipv4.tcp_tw_recycle=1
    net.ipv4.tcp_max_syn_backlog=4096
    net.core.netdev_max_backlog=10000
    vm.overcommit_memory=0
    net.ipv4.ip_conntrack_max=655360
    sysctl -p 生效

    修改 /etc/security/limits.conf

    1
    2
    3
    4
    5
    6
    7
    8
    * soft nofile 131072  
    * hard nofile 131072
    * soft nproc 131072
    * hard nproc 131072
    * soft core unlimited
    * hard core unlimited
    * soft memlock 50000000
    * hard memlock 50000000

    修改/etc/pam.d/login

    1
    session required pam_limits.so

    添加用户和组

    1
    2
    3
    #groupadd postgresql  
    #useradd -g postgresql postgresql
    # passwd postgres

    创建目录

    1
    2
    3
    4
    5
    6
    mkdir -p /opt/pg_root/data  
    mkdir -p /opt/pg_root/log
    touch /opt/pg_root/log/pgsql.log
    cd /usr/local
    chown -R postgres:postgres pg_root
    ln -sf /opt/pg_root /database/pgdata/pg_root

    配置环境变量

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    su - postgres  
    vi .bash_profile
    export DATE=`date +"%Y%m%d%H%M"`
    export PGPORT=1921
    export PGDATA=/database/pgdata/tbs1/pg_root/data
    export PGHOME=/opt/pgsql_9beta3
    export PATH=/database/pgdata/tbs1/pg_root/bin:$PATH
    export LD_LIBRARY_PATH=export DATE=`date +"%Y%m%d%H%M"`
    export MANPATH=$PGHOME/share/man:$MANPATH
    export LANG=en_US.utf8
    alias rm='rm -i'
    alias ll='ls -lh'

    安装PostgreSQL

    解压安装包到 /opt/postgresql-9.0beta3:

    1
    # tar xvf postgresql-9.0beta3.tar.gz

    进行安装配置

    1
    2
    cd /opt/postgresql-9.0beta3  
    ./configure --prefix=/opt/pg_root --with-pgport=1921 --with-segsize=8 --with-wal-segsize=64 --with-wal-blocksize=64 --with-perl --with-python --with-openssl --with-pam --with-ldap --with-libxml --with-libxslt --enable-thread-safety

    注意:Configure 脚本详细选项可以查看帮助:./configure --help 如查看版本信息:./configure -V , 如果报缺少相应包,则 yum 安装相应包即可。

    编译

    1
    # gmake (12:46)

    这个过程比较长,大概在二十分钟以上没有任何问题的话,我们可以看到最后一句提示信息

    1
    All of PostgreSQL successfully made. Ready to install.”

    安装

    1
    # gmake install-world

    成功安装后能看到最后一句提示信息”PostgreSQL installation complete.”

    初始化数据库(PSQL用户)

    1
    2
    root# su - postgres  
    initdb -D /opt/pg_root/data -E UTF8 --locale=C -U postgres -W

    注意: initdb 脚本详细选项可以查看 initdb --help ,例如查看 initdb 脚本版本命令如下 initdb -V

    命令执行完后提示

    1
    2
    3
    4
    Success. You can now start the database server using:
    postgres -D /usr/local/pgsql/data
    or
    pg_ctl -D /usr/local/pgsql/data -l logfile start

    数据库的启动与关闭

    启动数据库

    1
    pg_ctl -D /database/pgdata/pg_root/data-l /database/pgdata/pg_root/log/pgsql.log start

    关闭数据库 (参考步骤,这步只是为了显示关闭数据库命令)

    1
    pg_ctl -D /database/pgdata/pg_root/data

    创建数据库用户、数据库

    创建数据库用户

    1
    2
    3
    CREATE ROLE usera LOGIN  
    ENCRYPTED PASSWORD 'usera'
    nosuperuser inherit nocreatedb nocreaterole;

    创建数据库

    1
    createdb mydb -O usera

    登陆测试

    1
    2
    3
    4
    5
    6
    7
    8
    9
    psql -d mydb -U usera  
    psql (9.0beta3)
    Type "help" for help.

    oup=> select version();
    version
    ----------------------------------------------------------------------------------------------------------------------
    PostgreSQL 9.0beta3 on x86_64-unknown-linux-gnu, compiled by GCC gcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46), 64-bit
    (1 row)
    螃蟹在剥我的壳,笔记本在写我,漫天的我落在枫叶上雪花上,而你在想我。 --章怀柔
  • 相关阅读:
    支持向量机 (三): 优化方法与支持向量回归
    支持向量机 (二): 软间隔 svm 与 核函数
    支持向量机 (一): 线性可分类 svm
    拉格朗日乘子法
    特征选择: 卡方检验、F 检验和互信息
    Python 多进程、多线程效率比较
    Umi+Dva搭建Cesium 3D开发环境
    React 项目生产版本迭代页面不刷新问题
    React-Native学习手册----搭建基于ios平台的开发环境
    Cesium 绘制点、线、面和测距
  • 原文地址:https://www.cnblogs.com/lovezhr/p/14991285.html
Copyright © 2011-2022 走看看