在Fedora Core 5中安装DB2 8.2数据库

日期: 2008-06-17 来源:TechTarget中国

  最新发布的Fedora Linux Core5 (代号Bordeaux),带来的很多新的功能.如更好的中文支持,全新的GCC 4.1 等.但遗憾的是使用普通方法安装IBM DB2 数据库时,会出现严重错误而失败。笔者通过反复摸索.终于成功的将DB2 8.2 成功的安装在Fedora Core 5 上。


  以下的步骤除非特别声明,否则都需要以超级用户root的身份执行。而且最好禁用selinux 的功能。方法试编辑/etc/selinux/config文件,确保其中存在SELINUX=disabled 行。这也许需要重新启动Linux才能生效。


  另外DB2通常需要安装pdksh 软件包,在Fedora Core 5 中,只要安装了zsh 软件包即可。另外还需要修改/etc/sysctl.conf 文件。笔者将其中加上如下4行。


#for IBM DB2
            kernel.msgmni = 512
            kernel.sem = 250 128000 32 1024
            #end of IBM DB2
 
  首尾两行是注释,从而不起作用。执行 sysctl -p命令,上述的改变就立即生效了。加上注释的好处在于以后可以清楚的知道这些行是干什么用的。在不需要的时候可以删除之。


  笔者使用的是IBM DB2 8.2 版本,下载回来后将tar包解压。进入生成的目录后执行


rpm -ivh db2/linux/Java-1.4/IBMJava2-SDK-1.4.1-2.0.i386.rpm
 
  这样会装好IBM的Java 包,事实上采用Sun 公司的标准jdk或jre包亦可。但稍微复杂一些。


  执行


 ./db2_install
 
  按照提示输入DB2.ESE ,这代表本次安装的是DB2企业版。


  本步骤完成后,不能按照通常的办法执行db2_setup 命令,企图使用图形安装的方法注定会失败。


  安装成功的关键在于先要打上补丁包。在ibm公司网站上下载最新的补丁包FP11_MI00152.tar,这哥包是专门配合2.6内核的。解压后进入该目录后执行


./installFixPak -y
 
  将license导入的方法是:


 /opt/IBM/db2/V8.1/adm/db2licm -a db2ese82.lic
 
  其中的db2ese82.lic 就是和本版本对应的license。如果没有license,此步骤则可以省略。


  这样会升级必要的rpm 包,升级完成后就可以通过手工的方法创建实例了。


  由于需要手工安装,所以必须先创建一些DB2需要的用户。


groupadd -g 800 dasadm1
            groupadd -g 801 db2grp1
            groupadd -g 802 db2fgrp1
            adduser -g 800 -u 800 dasusr1
            adduser -g 801 -u 801 db2inst1
            adduser -g 802 -u 802 db2fenc1
 
  以上添加用户的命令中指定了uid和gid,只是为了更容易记住DB2相关的用户和组而已,并非必要的选项。另外还要使用passwd命令给上述的3个用户添加密码。再执行下列命令,就能够正确的创建DB2管理和数据库实例了。


/opt/IBM/db2/V8.1/instance/dascrt -u dasusr1
            /opt/IBM/db2/V8.1/instance/db2icrt -u db2fenc1 db2inst1
 
  这样安装的工作就顺利完成了。你可以用通常的方法使用DB2 数据库,比如以db2inst1用户的身份执行db2sampl 命令来创建sample 数据库了。

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

相关推荐