postgresql初始化之initdb的使用详解_PostgreSQL

来源:脚本之家  责任编辑:小易  

initdb 官网

initdb创建了一个新的PostgreSQL数据库集群。数据库集群是由单个服务器实例管理的数据库集合。

创建数据库集群包括数据库所在的目录、生成共享目录表(属于整个集群而不是任何特定数据库的表)以及创建template1和postgres数据库。稍后创建新数据库时,将复制template1数据库中的所有内容(因此,template1中安装的任何内容都会自动复制到以后创建的每个数据库中。),postgres数据库是供用户、实例程序和第三方应用程序使用的默认数据库。

尽管initdb将尝试创建指定的数据目录,但如果所需数据目录的父目录是根目录,则它可能没有权限。要再这样的设置中初始化,需要创建一个空数据目录作为根目录,然后使用chown将目录的所有权分配给数据库用户账户,然后su成为运行initdb的数据库用户。

initdb必须作为拥有服务器进程的用户运行,因为服务器需要访问initdb创建的文件和目录。由于服务器不能作为root用户运行,所以也不能作为root用户运行initdb。

出于安全原因,在默认情况下,initdb创建的新集群只能由集群所有者访问。——allow-group-access选项允许与集群所有者属于同一组的任何用户读取集群中的文件。这对于作为非特权用户执行备份非常有用。

initdb初始化数据库集群的默认语言环境和字符集编码。在创建数据库时,可以分别设置字符集编码、排序顺序(LC_COLLATE)和字符集类(LC_CTYPE,例如upper、lower、digit)。initdb确定template1数据库的那些设置,这些设置将作为所有其他数据库的默认设置。

要更改默认的排序顺序或字符集类,请使用——lc-collate和——lc-ctype选项。除了C或POSIX之外的排序顺序也会造成性能损失。由于这些原因,在运行initdb时选择正确的语言环境是很重要的。

其余的语言环境类别可以在服务器启动后更改。还可以使用——locale设置所有语言环境类别的默认值,包括排序顺序和字符集类。所有服务器语言环境值(lc_*)都可以通过SHOW All来显示。

常用参数:

-D directory/--pgdata=directory此选项指定应该存储数据库集群的目录。必传。也可以设置环境变量PGDATA来替换-D选项。

-U username/--username=username选择数据库superuser的用户名。这默认为运行initdb的用户的名称。

-E encoding/--encoding=encoding选择模板数据库的编码。这也是您稍后创建的任何数据库的默认编码,

--lc-collate/--lc-ctype更改默认的排序顺序或字符集类。

-k/--data-checksums在数据页上使用校验和来帮助检测I/O系统的损坏,否则系统将是静默的。启用校验和可能会导致显著的性能损失。如果设置,则计算所有数据库中所有对象的校验和。所有校验和失败将在pg_stat_database视图中报告。

所以postgresql初始化可能使用的命令是:

su - pguser001 -c "/u01/pgsql/bin/initdb --username=pguser001 --encoding=UTF8 --lc-collate=C --lc-ctype=en_US.
utf8 --data-checksums -D /data"

注:如果数据目录已经存在且初始化了的话,initdb将不会运行。

补充:postgresql 初始化 initdb 出现No such file or directory

1.initdb出现

 FATAL: could not open extension control file "/opt/HighGo/Develop/share/postgresql/extension/file_fdw.control": No such file or directory.

如下:

me@me:/opt/HighGo/Develop/bin$ <span style="color:rgb(51,51,255);">./initdb -D ../data -W</span>
The files belonging to this database system will be owned by user "me".
This user must also own the server process.
The database cluster will be initialized with locale "en_US.UTF-8".
The default database encoding has accordingly been set to "UTF8".
The default text search configuration will be set to "english".
creating directory ../data ... ok
creating subdirectories ... ok
selecting default max_connections ... 100
selecting default shared_buffers ... 32MB
creating configuration files ... ok
creating template1 database in ../data/base/1 ... ok
initializing pg_authid ... ok
Enter new systemuser password: 
Enter it again: 
Enter syssao password: 
Enter it again: 
Enter syssso password: 
Enter it again: 
setting dba password ... ok
initializing dependencies ... ok
<span style="color:rgb(204,0,0);">creating system views ... FATAL: could not open extension control file "/opt/HighGo/Develop/share/postgresql/extension/file_fdw.control": No such file or directory
STATEMENT: /*</span>
 * PostgreSQL System Views
 *
 * Copyright (c) 1996-2012, PostgreSQL Global Development Group
 *
 * src/backend/catalog/system_views.sql

原因是file_fdw.control插件没有安装.进入源代码目录下的contrib目录下.找到file_fdw文件进入其中,编译安装,

make
make install

同理出现:

creating system views ... FATAL: 
could not open extension control file "/opt/HighGo/Develop/share/postgresql/extension/dblink.control": No such file or directory.

在contrib目录下进入到dblink文件中,make,make install

所以如果出现一些其他的hstore.control 等.相应的安装上.

以上为个人经验,希望能给大家一个参考,也希望大家多多支持真格学网。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:使用postgresql 模拟批量数据插入的案例postgreSQL数据库默认用户postgres常用命令分享PostgreSQL 启动失败的解决方案解决postgresql无法远程访问的情况浅谈Postgresql默认端口5432你所不知道的一点

  • 本文相关:
  • postgresql教程(二):模式schema详解
  • 在postgresql数据库中判断是否是数字和日期时间格式函数操作
  • postgresql 启动失败的解决方案
  • postgresql 非count方法算记录数操作
  • postgresql安装、配置及简单使用方法
  • pgsql 实现用户自定义表结构信息获取
  • postgresql 检查数据库主从复制进度的操作
  • 详解postgresql 语法中关键字的添加
  • postgresql批量update与oracle差异详解
  • 修改一行代码提升 postgres 性能 100 倍
  • postgresql和mysql的区别
  • 如何在windows下手动初始化PostgreSQL数据库
  • 如何在CentOS 7/6.5/6.4 下安装PostgreSQL 9.3 与 ...
  • 如何在windows下手动初始化PostgreSQL数据库
  • freebsd下postgresql怎么起动
  • 如何本地安装centos的数据库postgresql94
  • linux下postgresql 9.4 怎么安装
  • 虚拟机中如何安装PostgreSQL数据库?
  • linux 下怎么看postgresql安装到哪个目录了?
  • centos7怎么打开postgresql
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页postgresql使用postgresql 模拟批量数据插入的案例postgresql数据库默认用户postgres常用命令分享postgresql 启动失败的解决方案解决postgresql无法远程访问的情况浅谈postgresql默认端口5432你所不知道的一点postgresql教程(二):模式schema详解在postgresql数据库中判断是否是数字和日期时间格式函数操作postgresql 启动失败的解决方案postgresql 非count方法算记录数操作postgresql安装、配置及简单使用方法pgsql 实现用户自定义表结构信息获取postgresql 检查数据库主从复制进度的操作详解postgresql 语法中关键字的添加postgresql批量update与oracle差异详解修改一行代码提升 postgres 性能 100 倍postgresql 角色与用户管理介绍windows下postgresql数据库的下载windows下postgresql安装图解15个postgresql数据库实用命令分postgresql中的oid和xid 说明postgresql alter语句常用操作小windows postgresql 安装图文教程postgresql 安装和简单使用postgresql 创建表分区postgresql新手入门教程postgresql 获取两个时间类型小时差值案例postgresql归档配置及自动清理归档日志的postgre数据库insert 、query性能优化详解linux下创建postgresql数据库的方法步骤windows postgresql 9.1 安装详细步骤postgresql教程(七):函数和操作符详解(postgresql 实现取出分组中最大的几条数据解决sqoop从postgresql拉数据,报错tcp/ippostgresql教程(十二):角色和权限管理介postgresql流复制参数max_wal_senders的用
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved