PostgreSQL的目录结构及修改数据目录
initdb 的时候会指定一个 PGDATA 目录,这就是 PostgresQL 存储数据的地方,比如:/var/lib/pgsql/10/data。
======显示数据目录
1. 进入psql
sudo -u postgres psql
2. 找到数据目录
postgres=# SHOW data_directory;
data_directory
------------------------
/var/lib/pgsql/10/data
(1 row)
======PGDATA 下面各项存储的内容大概是:
文件 存储内容
PG_VERSION 实例的 版本号
postgresql.conf 主配置文件
postgresql.auto.conf (新功能,优先级更高)
pg_hba.conf 认证配置文件
pg_ident.conf 映射配置文件
postmaster.opts /usr/pgsql-10/bin/postgres "-D" "/var/lib/pgsql/10/data/"
postmaster.pid
...
目录名: 存储内容
base: 默认表空间目录,建立的表格储存在此目录中.每个 database 会在 base 目录下有一个子目录
global: 一些共享系统表的目录.Postgres 自己的 meta 数据库存放的地方(全局 DB)
pg_stat_tmp: 统计信息的存储目录
pg_tblsp: 存储了指向各个用户自建表空间实际目录的链接方式
pg_twophase: 使用两阶段提交功能时分布式事务的存储目录
==以下目录功能待补充...
log
pg_commit_ts
pg_dynshmem
pg_logical
pg_multixact
pg_notify
pg_replslot
pg_serial
pg_snapshots
pg_stat
pg_subtrans
pg_wal
pg_xact
以下目录应该是10.0以前版本的
pg_clog: commit log的目录
pg_log:系统日志目录,在查询一些系统错误时就可查看此目录下的日志文件
pg_xlog:wal(Write Ahead Log 预写式日志)日志的目录
base 目录是最重要的一个目录,放的是每一个 database 的数据。
base 目录里的每一个数字目录对于一个 database 的 oid,可以通过 查看 pg_database 这张表查看每一个 数据库的 oid 。
[root@srv]# ls /var/lib/pgsql/10/data/base
1 13805 13806
postgres=# select oid, datname from pg_database ;
oid | datname
-------+-----------
13806 | postgres
1 | template1
13805 | template0
(3 rows)
每一张表的数据(大部分)又是放在 base/(dboid)/(relfilenode) 这个文件里面:
postgres=# select relname, relowner, relfilenode from pg_class where relowner = 13805;
relname | relowner | relfilenode
---------+----------+-------------
(0 rows)
查询'item'表的数据文件.这里的'item'是table名称.
lai=# select pg_relation_filepath('item');
pg_relation_filepath
----------------------
base/16385/24595
(1 row)
======PG安装目录,postgresql默认在/usr/pgsql-10
子目录有:
(1)/usr/pgsql-10/bin: 二进制可执行文件目录,此目录下有postgres,psql等可执行程序.
(2)/usr/pgsql-10/lib: 动态库目录,PG程序运行需要的动态库都在此目录下,如libpg.so.
(3)/usr/pgsql-10/share: 此目录下存放有文档和配置模板文件,一些扩展包的sql文件,在此目录的子目录extension下.
-----------
修改data_directory的所有者,目录权限
chown -R postgres:postgres /home/pgdata
chmod 700 /home/pgdata
--------
======修改数据目录
1. 进入psql
sudo -u postgres psql
2. 找到数据目录
SHOW data_directory;
3. 关闭数据库
sudo systemctl stop postgresql
sudo systemctl status postgresql
4. 我们将现有的数据库目录复制到新的位置用rsync。
>> 使用-a标志保留的权限和其他目录属性, 能避免未来的升级权限问题.
>> 而-v提供详细输出,以便能够按照进度。
注意:确保没有对目录没有尾随斜线,如果你使用制表符完成可以加入。
当有一个结尾的斜线, rsync将转储目录复制到安装点,而不是转移成一个包含内容PostgreSQL目录:
sudo rsync -av /var/lib/postgresql /mnt/newdir
5. 复制完成后,我们将使用.bak扩展名重命名当前文件夹,并保留该文件,直到我们确认移动已成功。 通过重命名它,我们将避免可能由于新的和旧的位置中的文件引起的混乱:
sudo mv /var/lib/postgresql/10/data /var/lib/postgresql/10/data.bak
6. 修改配置文件:postgresql.conf
data_directory = '/mnt/newdir/postgresql/10/data'
7. 启动数据库
sudo systemctl start postgresql
sudo systemctl status postgresql
8. 显示数据目录
sudo -u postgres psql
SHOW data_directory;
9. 删除备份
sudo rm -Rf /var/lib/postgresql/9.5/main.bak
10.重启
sudo systemctl restart postgresql
sudo systemctl status postgresql
==================
移动PostgreSQL的数据目录移到新位置
https://www.howtoing.com/how-to-move-a-postgresql-data-directory-to-a-new-location-on-ubuntu-16-04
PG安装目录
https://blog.csdn.net/liguangxianbin/article/details/79563881
Postgres 数据表文件存储位置
https://blog.csdn.net/jameshadoop/article/details/60962451
http://veryr.com/posts/postgres-storage-location/
PostgreSQL的目录结构及修改数据目录的更多相关文章
- POSTGRESQL 创建表结构、修改字段、导入导出数据库(支持CSV)
这两个月经常使用postgresql,总结一些经常使用的语句: --创建表 CREATE TABLE customers ( customerid SERIAL primary key , compa ...
- Vue项目搭建流程 以及 目录结构构建
Vue项目搭建流程 以及 目录结构构建 一个小的Vue项目, 基于微信浏览器的移动端, 做了这么多的练习项目, 这一次准备记录下构建的过程, 以方便以后的调高效率 环境准备 操作系统 我的 windo ...
- BAT 快速删除CVS文件和拷贝最近修改文件的目录结构
相信大家在操作大量文件的的时候,经常会遇到一些手动很难操作的情况 比如有CVS版本控制下每个文件夹下都有一个CVS文件夹,一个个手工删除肯定很费劲,我们都是懒人,还是用工具解决吧.不用重新写程序,直接 ...
- xcode修改代码目录结构出现clang:error:nosuchfileordirectory解决方法
需要迁移一个开源工程的一部分内容到自己工程,迁移对方的工程到自己工程之后,因目录结构配置整理需要,对嵌入的工程目录进行了结构改变,编译后出现: clang: error: no such file o ...
- 【Linux】Linux 目录结构
博客已转移,请借一步说话 .http://www.weixuehao.com/archives/492 初学Linux,首先需要弄清Linux 标准目录结构 / root --- 启动Linux时使用 ...
- Linux 标准目录结构
初学Linux,首先需要弄清Linux 标准目录结构 / root --- 启动Linux时使用的一些核心文件.如操作系统内核.引导程序Grub等. home --- 存储普通用户的个人文件 ftp ...
- CentOS6.5菜鸟之旅:纯转载Linux目录结构
来自:http://www.iteye.com/topic/1125162 使用linux也有一年多时间了 最近也是一直在维护网站系统主机 下面是linux目录结构说明 本人使用的是centos系 ...
- Centos目录结构详细版
使用linux也有一年多时间了 最近也是一直在维护网站系统主机 下面是linux目录结构说明 本人使用的是centos系统,很久没有发表博文了 近期会整理自己所用所了解知识点,发表linux相关的 ...
- CentOS目录结构超详细版
最近初学Linux 对linux的目录产生了很多疑问,看到这篇文章,让我顿时对目录有了一个清晰的认识!推荐给大家! ------------------------------------------ ...
随机推荐
- Shell编程积累 zhuan
在新的shell里执行程序 cd /home/lq/Server/anew-lstm_scriptmatlab -nodesktop -singleCompThred -r 'aStart' ,qui ...
- decltype的参数是左值时,得到一个引用类型
int* a = new int(10); decltype(*a) 得到的是引用类型:int&
- PAT-GPLT训练集 L1-043 阅览室
PAT-GPLT训练集 L1-043 阅览室 注意:连续的S和E才算一次借还 代码: #include<iostream> #include<cstdio> using nam ...
- node编译C++,比如安装node-gyp失败的问题
遇到的这个问题是很多需要编译才能运行的node模块共有的问题. npm i -g windows-build-tools 首先以管理员身份打开命令行,然后在命令行下执行这一行命令. 然后重新运行你刚才 ...
- unity鼠标滚轮控制摄像机视野的缩放和按住鼠标控制摄像机移动
//摄像机前进后退的速率 private float view_value=20f; private float maximum = 100; private float minmum = 30; / ...
- C++各种类继承关系的内存布局
body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...
- iconfont.cn批量加入
iconfont.cn还没有一个批量加入的功能 以下是最新的图标批量加入购物车功能代码. var icons = document.querySelectorAll('.icon-gouwuche1' ...
- Java语法基础学习DayFour
一.面向对象 1.特点: A:是一种更符合我们思考习惯的思想B:把复杂的事情简单化C:让我们从执行者变成了指挥者 2.使用: a:创建对象格式类名 对象名 = new 类名();b:如何使用成员变量和 ...
- Appium Python API
1.contexts contexts(self): Returns the contexts within the current session. 返回当前会话中的上下文,使用后可以识别H5页面的 ...
- Android修行之路------List view无法获取监听方法
注意: 1.在list view自定义布局中如果添加滚动布局,会导致自定义布局无法获取监听. 2.如果ListView的每项布局里有像Button,ImageButton之类View的控键时,这些Vi ...