Loading...

当前位置:资讯中心主页 >PostgreSQL >文章内容

  • 在Linux上建立PostgreSQL数据库服务器
  • 来源:Linux宝库  作者:Linux宝库  发布时间:2008-05-23 14:19:49
    • 域名注册

    • 域名惊喜价格 cn域名1元注册
    • com域名39.9

      虚拟主机

    • 主机按月支付,低至19元/月
    • 超大流量,可开子站点

      VPS主机

    • 特惠VPS168元/月,4-8M独享带宽保证
    • 独立操作系统,无限开站点

      在上一篇文章中,我们讨论了在Linux上非常流行的MySQL数据库服务器的使用方法。在这篇文章中,我们将关注另一个选择,名为 PostgreSQL的开放源码数据库。尽管MySQL是个快速,强大和相当简单的关系型数据库管理系统,但PostgreSQL更加具有综合性,并为这种复杂性牺牲了一些速度。

      如果你已习惯于使用包含各种图标和快捷方式的界面,那么PostgreSQL非常适合你,尽管MySQL的4版本也提供类似的功能。为了在这篇文章中能够向你清晰的说明怎样建立PostgreSQL,我使用以下版本的软件: Red Hat Linux 7.1 PostgreSQL 7.1.3

      准备安装

      在开始之前,你需要获得这些软件。你能下载最新的7.1.3版本。将PostgreSQL这个源码程式下载下来之后,应该把他放在Linux服务器的/usr/local目录下。如果你把他放在其他地方,请注明并修改相应的路径指示。

      PostgreSQL并不以根权限运行。这源于研发者的安全设计思想。因此,你需要一个用户账号来建立运行PostgreSQL进程。在这篇文章中我们使用postgres这个用户,同时还将创建一个名为postgres的组。

      当然,如果想创建这些账号,你需要以终极用户的身份登录(通常是根权限)。为了在Linux服务器上创建这个postgres用户组,我将在命令行中执行 groupadd postgres。下一步,创建用户并加入这个组,命令为useradd postgres ?g postgres。

      在正式开始安装PostgreSQL之前,我们还需要做两件事情。首先,我们将自己来创建将要用到的目录并在postgres用户中指定所有者。这样就能避免权限不清所带来的问题。

      首先,创建两个目录: mkdir /usr/local/pgsql mkdir /usr/local/postgresql-7.1.3

      然后,指定这两个目录在早先创建的postgres用户中的所有者: chown postgres.postgres /usr/local/pgsql chown postgres.postgres /usr/local/postgresql-7.1.3

      目前让我们将这个版本解压以便能安装他。首先,用su postgres命令改动postgres用户。然后,用cd /usr/local命令转到/usr/local目录下并用下列命令将下载的文件解压: gunzip ?dc postgresql-7.1.3.tar.gz | tar xvf

      当列表中的文件解压完成之后,你就会回到命令提示符下,使用cd /usr/local/postgres-7.1.3命令转到相应目录下。

      完成之后,就能开始了

      像其他开放源码的程式相同,安装过程的第一步就是安装设置中指定你的操作环境,包括所希望的程式安装路径和特定性能的有效/无效。

      为了实现安装的意图,我们要确信软件安装在了/usr/local/pgsql目录下,这是我们先前创建的目录。为了完成这一步,我们使用命令: ./configure --prefix=/usr/local/pgsql

      下一步是用先前提供的选项来编译源程式。用命令行实现这一点。完成之后,你能通过键入安装时的命令来安装二进制文件。

      在你开始启动数据库之前,PostgreSQL也有一些环境变量需要设置,你应该让PostgreSQL知道在哪儿能找到他的数据文件,共享库,应用程式文件,和操作记录。在我的RedHat Linux 7.1服务器上,我喜欢通过修改/home/postgres目录下的.bash_profile文件来实现这一点。由于这个文件是在登录时被查看,所以能在环境中为postgres用户添加合适的变量。使用你最喜欢的文本编辑器来完成以下的步骤(我用的是pico)。

      用下面的命令打开并编辑.bash_profile文件: pico /home/postgres/.bash_profile

      然后,在文件中用户名一行前添加下列行: PGLIB=/usr/local/pgsql/lib PGDATA=/usr/local/pgsql/data PATH=$PATH:/usr/local/pgsql/bin MANPATH=$MANPATH:/usr/local/pgsql/man export PGLIB PGDATA PATH MANPATH

      保存文件并用下面的命令创建目录/usr/local/pgsql/pgdata: mkdir /usr/local/pgsql/data

      如果postgres用户对整个/usr/local/pgsql目录拥有完全权限的话,你就无需使用根用户。这个目录将存储所有你的数据库文件。

      启动你的(数据库)引擎

      在能正式启动数据库引擎之前,你需要通过一个初始化命令对不同的PostgreSQL数据库进行初始化。如果想实现这个初始化,使用命令cd /usr/local/pgsql/bin并且键入./initdb,然后按[Enter]。你将得到许多状态信息然后回到命令行提示符下。

      在这时,你能用以下命令开启Postgres postmaster: /usr/local/pgsql/bin/postmaster ?i -D /usr/local/pgsql/data &

      这将启动PostgreSQL并在/usr/local/pgsql/data目录下运行数据库,能从互连网上对数据库进行连接(通过参数-i),能运行于后台(通过参数 &)。你的数据库引擎已启动并开始准备接受数据。

      创建数据库

      在这个例子中,我们将创建一个名为mydb的数据库和一个名为mytable的表格,这样能让你确信一切都正常工作。首先,在命令行中键入 createdb mydb。如果PostgreSQL回复CREATED DATABASE,说明已接受了命令。目前,我们使用psql工具和这个数据库一起工作。键入psql mydb并按[Enter]。这将带你进入PostgreSQL的交互式模式。

      如果想在mydb数据库中创建mytable表格,能按照以下的步骤。请记住这并不是个真实的表格,只是个样本罢了: CREATE TABLE mytable ( id varchar(20), name varchar(30));

      一旦你完成这些,你将看到一个CREATED信息,说明表格已创建。目前我们能在表格中插入一个记录,查看内容,然后退出psql工具: INSERT INTO mytable values (’作家’, ’Scott Lowe’);

      目前psql将答复INSERT 18732 1。如果想查看这个表格的内容,键入: SELECT “* FROM MYTABLE;”

      你将看到以下的结果:

      身份 | 姓名

      --------+------------

      作家 | Scott Lowe

      如果要退出psql工具,键入\q并按[Enter]。

      总结

      这让我们大致了解了在RedHat Linux上PostgreSQL 7.1.3数据库的基本安装过程。我认为你将看到PostgreSQL是个功能强大的数据库,以其高级的性能完全有能力顺利地运行于多种环境之中。

      如果你在安装PostgreSQL时遇见所有问题,我建议你仔细阅读在PostgreSQL的Web站点中的文件。

  • 以上内容由 华夏名网 搜集整理,如转载请注明原文出处,并保留这一部分内容。

      “华夏名网” http://www.sudu.cn 和 http://www.bigwww.com 是成都飞数科技有限公司的网络服务品牌,专业经营虚拟主机,域名注册,VPS,服务器租用业务。公司创建于2002年,经过6年的高速发展,“华夏名网”已经成为我国一家知名的互联网服务提供商,被国外权威机构webhosting.info评价为25大IDC服务商之一。

    华夏名网网址导航: 虚拟主机 双线主机 主机 域名注册 cn域名 域名 服务器租用 酷睿服务器 vps vps主机

  • (阅读次数:115)
  • 上一篇: 基于Linux2.4内核的透明代理解决方案B    下一篇: 谷歌收购了265网站 未对外披露收购金额
  • [收藏] [推荐] [评论] [打印本页] [返回上一页][关闭窗口]
  • 昵称: (为空则显示guest)
  • 评论分数: ★ ★ ★★★ ★★★★ ★★★★★
  • 评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。