热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Ubuntu系统安装postgresql数据库

想在debian下装个PostgreSQL,可是发现源里的pgsql居然是7.*.*的版本,着实吓我一跳,不过没关系,自己编译个就行了。闲话少说,开始干活:1.先下个源码包,http://www.postgresql.org/ftp/source/v8.2.5/,这里的postgresql-8.2.5.tar.gz就不

想在debian下装个PostgreSQL,可是发现源里的pgsql居然是7.*.*的版本,着实吓我一跳,不过没关系,自己编译个就行了。闲 话少说,开始干活:

1. 先下个源码包,http://www.postgresql.org/ftp/source/v8.2.5/,这里的postgresql- 8.2.5.tar.gz就不错,还算比较新。

2. 为PostgreSQL创建用户postgresql:

$ adduser postgresql

3. 为PostgreSQL创建目录:

$ su

$ cd /usr/src

$ mkdir pgsql

4. 将pgsql目录的使用权限赋给用户postgresql:

$ chown postgresql: /usr/src/pgsql

5. 把源码解压到pgsql目录下:

$ tar -zxvf postgresql-8.2.5.tar.gz /usr/src/pgsql

6. 创建安装目录:

$ cd /usr/local $ mkdir pgsql

7. 将pgsql目录的使用权限赋o用户postgresql:

$ chown postgresql: /usr/local/pgsql

8. 运行configure脚本,配置编译选项:

$ cd /usr/src/pgsql/postgresql-8.2.5

$ ./configure ??enable-debug

有的时候它会提示:

configure: error: readline library not found

configure: error: zlib library not found

这是因为还需要安装一些lib包:

$ apt-get install libreadline5-dev zlib1g-dev

然后再运行脚本就能成功了。

或者略过这些错误 提示,在运行脚本时加入参数也可以:

$ ./configure ??without-readline ??without-zlib

9. 接下来就是make和make install:

$ make

正常的话,可以看到最后一行输出为: "All of PostgreSQL successfully made. Ready to install."

$ make install

最后应该看到输出"PostgreSQL installation complete."

10. 然后设置环境变量:

$ vi /home/postgresql/.bashrc

加入一些变量定义:

export PATH=$PATH:/usr/local/pgsql/bin

export POSTGRES_HOME=/usr/local/pgsql

export PGLIB=$POSTGRES_HOME/lib

export PGDATA=$POSTGRES_HOME/data

export MANPATH="$MANPTH":$POSTGRES_HOME/man

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PGLIB(注意这里的“:”是英文下的,不是汉字的,这个错误耽误 了我很长时间)

然后执行:

$ source /home/postgresql/.bashrc

11. 使用PostgreSQL之前要初始化数据库,先用root身份建data目录:

$ cd /usr/local/pgsql

$ mkdir data

将data的使用权限赋给postgresql用户:

$ chown postgresql: /usr/local/pgsql/data

转到postgresql用户bin目录 下,执行initdb初始化命令:

$ su postgresql

$ cd bin

$ initdb

会得到如下提示:

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

12. 很明显,它提示你用上面的两行命令就可以启动database了。

在 postgresql里一个数据库一定要有个所有者对应

现在ubuntu源里的版 本已经更新到8.4了,这样就不用自己编辑安装了,但是从源里自动安装后,要修改postgresql的系统密码和用户密码。
推荐阅读
  • Parallels Desktop for Mac 是一款功能强大的虚拟化软件,能够在不重启的情况下实现在同一台电脑上无缝切换和使用 Windows 和 macOS 系统中的各种应用程序。该软件不仅提供了高效稳定的性能,还支持多种高级功能,如拖放文件、共享剪贴板等,极大地提升了用户的生产力和使用体验。 ... [详细]
  • 本文详细介绍了在 Ubuntu 16.04 系统上安装和配置 PostgreSQL 数据库的方法,包括如何设置监听地址、启用密码加密、更改默认用户密码以及调整客户端访问控制。 ... [详细]
  • 从CodeIgniter中提取图像处理组件
    本指南旨在帮助开发者在未使用CodeIgniter框架的情况下,如何独立使用其强大的图像处理功能,包括图像尺寸调整、创建缩略图、裁剪、旋转及添加水印等。 ... [详细]
  • Bootstrap Paginator 分页插件详解与应用
    本文深入探讨了Bootstrap Paginator这款流行的JavaScript分页插件,提供了详细的使用指南和示例代码,旨在帮助开发者更好地理解和利用该工具进行高效的数据展示。 ... [详细]
  • HTML前端开发:UINavigationController与页面间数据传递详解
    本文详细介绍了如何在HTML前端开发中利用UINavigationController进行页面管理和数据传递,适合初学者和有一定基础的开发者学习。 ... [详细]
  • Java中的引用类型详解
    本文详细介绍了Java中的引用类型,包括强引用、软引用、弱引用和虚引用的特点和应用场景。 ... [详细]
  • MySQL Administrator: 监控与管理工具
    本文介绍了 MySQL Administrator 的主要功能,包括图形化监控 MySQL 服务器的实时状态、连接健康度、内存健康度以及如何创建自定义的健康图表。此外,还详细解释了状态变量和系统变量的管理。 ... [详细]
  • 阿里云服务器搭建详解——Ubuntu
    由于自己电脑配置跟不上,双系统一开,整个电脑就会变得非常卡顿,所以决定在阿里云买一个云服务器。听朋友说,学生买的话是非常便宜 ... [详细]
  • 周排行与月排行榜开发总结
    本文详细介绍了如何在PHP中实现周排行和月排行榜的开发,包括数据库设计、数据记录和查询方法。涉及的知识点包括MySQL的GROUP BY、WEEK和MONTH函数。 ... [详细]
  • Linux CentOS 7 安装PostgreSQL 9.5.17 (源码编译)
    近日需要将PostgreSQL数据库从Windows中迁移到Linux中,LinuxCentOS7安装PostgreSQL9.5.17安装过程特此记录。安装环境&#x ... [详细]
  • 在使用 Cacti 进行监控时,发现已运行的转码机未产生流量,导致 Cacti 监控界面显示该转码机处于宕机状态。进一步检查 Cacti 日志,发现数据库中存在 SQL 查询失败的问题,错误代码为 145。此问题可能是由于数据库表损坏或索引失效所致,建议对相关表进行修复操作以恢复监控功能。 ... [详细]
  • 当我们忘记了Debian系统的登录密码而无法进入系统时,可以通过以下方法进行密码重置。在GRUB2引导界面中选择Debian启动项,按下“e”键进入编辑模式。接着找到以“linux”或“linux16”开头的行,在该行末尾添加“init=/bin/bash”参数。保存并继续启动,系统将进入单用户模式,此时可以使用`passwd`命令来重置root用户的密码。完成后重启系统即可正常登录。 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 在本文中,我们将探讨如何在Docker环境中高效地管理和利用数据库。首先,需要安装Docker Desktop以确保本地环境准备就绪。接下来,可以从Docker Hub中选择合适的数据库镜像,并通过简单的命令将其拉取到本地。此外,我们还将介绍如何配置和优化这些数据库容器,以实现最佳性能和安全性。 ... [详细]
  • Amoeba 通过优化 MySQL 的读写分离功能显著提升了数据库性能。作为一款基于 MySQL 协议的代理工具,Amoeba 能够高效地处理应用程序的请求,并根据预设的规则将 SQL 请求智能地分配到不同的数据库实例,从而实现负载均衡和高可用性。该方案不仅提高了系统的并发处理能力,还有效减少了主数据库的负担,确保了数据的一致性和可靠性。 ... [详细]
author-avatar
我们的北京宫
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有