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用户的权限为完全控制。
参考: