远程连接DB2数据库环境变量和连接配置

文章详细介绍了如何配置DB2客户端的环境变量以解决命令未找到的问题,以及通过编目(nodecatalog)和数据库编目(dbcatalog)实现远程连接到DB2服务器的过程。首先,需编辑.bash_profile设置环境变量,然后通过db2catalog命令将远程服务器和数据库添加到本地目录,从而实现客户端与服务器的连接。
摘要由CSDN通过智能技术生成

一、环境变量

安装了db2客户端之后,输入db2命令提示

-bash: db2: command not found

多半是环境变量未配置。参照如下命令和步骤编辑环境变量

[db2admin@app01 ~]$ vi .bash_profile
DB2DIR=/opt/ibm/db2/V11.1
LD_LIBRARY_PATH=$DB2DIR/lib64
PATH=$DB2DIR/bin:$DB2DIR/adm:$DB2DIR/misc:$PATH
CLASSPATH=.$DB2DIR/java/db2java.zip:$DB2DIR/java/db2jcc.jar:$DB2DIR/java/sqlj.zip:$DB2DIR/function:$DB2DIR/java/db2jcc_license_cisuz.jar:$DB2DIR/java/db2jcc_license_cu.jar:$CLASSPATH
export PATH CLASSPATH LD_LIBRARY_PATH DB2DIR

:wq 保存退出,并source生效一下

[db2admin@app01 ~]$ source .bash_profile

二、远程连接

在db2数据库中,需要理解catalog(编目)这个概念,理解前先说下db2数据库的体系结构:由系统(节点)也就是主机,下面是实例,实例下面是数据库,然后是表空间,再是数据库对象。现在假设你有一个数据库服务器建立在MDMNODE1 的机器上,你有一个客户端在windows、linux或任何平台上,你现在想建立一个客户端到服务器端的连接,具体步骤如下:

<第一步> 要在客户端的机器上能够把远程的服务器能够识别出来,怎么做?

在DB2使用编目(catalog)方式,具体来说就是通过编目把远程的服务器写在本地客户端的一个文件中:

例:

[db2admin@app01 home]$ db2 catalog tcpip node MDMNODE1 remote 192.168.124.163 server 60006

命令注释:MDMNODE1 是一个节点名(在一个机器上必须是唯一的),remote后面是服务器的IP地址,server是远程服务器上实例对应的端口号。DB2通过这种方式在本地的SQLNODIR文件中把远程服务器的信息记录下来,所以编目节点其实就是把远程服务器映射到本地,通过SQLNODIR中的记录能够找到远程服务器和实例,类似指向远程服务器和实例的地址指针。

查看:

[db2admin@app01 home]$ db2 list node directory
 Node Directory
 Number of entries in the directory = 1
Node 1 entry:
 Node name                      = MDMNODE1
 Comment                        =
 Directory entry type           = LOCAL
 Protocol                       = TCPIP
 Hostname                       = 192.168.124.163
 Service name                   = 60006

<第二步> 当把远程的服务器IP地址,实例编目下来后,第二步应该把该实例下的数据库编目到本地:

[db2admin@app01 home]$ db2 catalog db mdmdb at node mdmnode1
DB20000I  The CATALOG DATABASE command completed successfully.
DB21056W  Directory changes may not be effective until the directory cache is 
refreshed.

命令注释:mdmdb 是远程实例下的数据库,mdmnode1是我们在第一步中编目的节点名 

[db2admin@app01 home]$ db2 list db directory 
 System Database Directory 
 Number of entries in the directory = 1
Database 1 entry: 
 Database alias                       = MDMDB
 Database name                        = MDMDB
 Node name                            = MDMNODE1
 Database release level               = 10.00
 Comment                              =
 Directory entry type                 = Remote
 Catalog database partition number    = -1
 Alternate server hostname            =
 Alternate server port number         =

接下来试着连接:

[db2admin@app01 home]db2 connect to MDMDB user dbuser using dbpwd

查看当前数据库所有的表

[db2admin@app01 home]$ db2 list tables

断开连接

[db2admin@app01 home]$ db2 terminate

总结:

上面是客户端和服务器不在同一台机器上,是通过编目节点,编目数据库来实现客户端连接到服务器上数据库的目的!

如果是连接在同一台机器上,那么此时不用显示编目节点,但是在服务器上当我们创建一个实例的时候,有一个隐含的把实例在本地编目的过程,假设在p570上创建一个实例名为db2inst1,其实有一个隐含的

  db2 catalog local node db2inst1 instance db2inst1 system p570 ostype aix的步骤,同样当你在db2inst1下创建一个数据库MYDB的时候,有一个隐含的编目(catalog)数据库的步骤:

  db2 catalog db mydb at node db2inst1的步骤。

至此你可以这样理解编目(catalog),编目就是在本地或远程建立客户端到服务器的数据库连接的目的。

学习参考:远程连接db2数据库

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值