windows2008 server 上迁移postgresql 的data目录

 

有人把postgresql 装到了C盘,结果C盘只有40G,眼看数据库就要把C盘撑爆了。

Step 1:停止PostgreSQL服务

   通过“Windows Services Management?即“服务”中停止相应的PostgreSQL服务

Step 2:数据迁移

拷贝data文件夹至新数据目录,需要注意必须检查用户权限是否可于访问新的数据目录。 

Step3:修改注册表

对应键值位置在"HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\postgresql-x64-9.3\ImagePath",将“-D”后的目录名修改为新的数据目录位置即可,如果目录路径中含有空格,需要用引号引起

原先内容为:

C:/Program Files (x86)/PostgreSQL/9.3/bin/pg_ctl.exe runservice -N "postgresql-9.3" -D "C:/Program Files (x86)/PostgreSQL/9.3/data" -w

修改为:

C:/Program Files (x86)/PostgreSQL/9.3/bin/pg_ctl.exe runservice -N "postgresql-9.3" -D "D:/PostgreSQL/9.3/data" -w

Step4:启动PostgreSQL服务

 


注意事项:修改文件夹的权限

postgreSQL运行的时候用的是NETWORK_SERVICE用户,没有权限对复制后的data目录进行写入,因此会造成PostgreSQL服务启动的时候失败。

但有些windows 2008 R2 磁盘和文件夹属性没有安全选项卡,无法修改权限,怎么办?

运行gpedit.msc --选择用户配置--管理模板--windows组件--windows资源管理器--到右边窗口找到“删除安全选项卡”一项,将其设为禁用,就出现安全选项了。添加NETWORK_SERVICE用户的权限为完全控制。

windows2008 server 上迁移postgresql 的data目录

windows2008 server 上迁移postgresql 的data目录

 

参考:

https://www.landui.com/help/show-3587.html

https://wiki.postgresql.org/wiki/%E5%9C%A8Windows%E5%B9%B3%E5%8F%B0%E4%B8%8A%E5%AE%89%E8%A3%85%E4%B8%8E%E8%BF%90%E8%A1%8CPostgreSQL%E7%9A%84%E5%B8%B8%E8%A7%81%E9%97%AE%E9%A2%98%E4%B8%8E%E8%A7%A3%E7%AD%94#.E4.B8.BA.E4.BB.80.E4.B9.88.E6.88.91.E9.9C.80.E8.A6.81.E4.B8.80.E4.B8.AA.E9.9D.9E.E7.AE.A1.E7.90.86.E5.91.98.E5.B8.90.E5.8F.B7.E6.9D.A5.E8.BF.90.E8.A1.8CPostgreSQL.EF.BC.9F