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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

一、环境变量

安装了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数据库

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: 数据库