在上一章中我们讲了怎么安装PostgreSQL,在数据库安装完成及启动数据库服务以后,需要连接到数据库上对数据库里的数据进行操作。连接数据库也可以分为两种:
下面我们分别介绍这两种连接方式。
1. 命令行连接
通过Linux系统平台的命令行界面或Windows系统平台的cmdline界面进行连接。在上一章的内容中,我们安装了两个软件包,分别是 postgresql96 和 postgresql96-server 。postgresql96为我们提供了连接数据库工具的客户端软件psql,postgresql96-server 是服务端软件。psql命令有两种格式,分别是:
psql postgres://username:password@host:port/dbname
psql -U username -h hostname -p port -d dbname
先解释第一个命令格式里各个参数:
username:连接数据的用户名,默认值是postgres
password:密码,默认值是postgres
host:主机名,默认值是localhost
port:端口,默认值是5432
dbname:要连接的数据库名,默认值是postgres
第二个命令的各个参数:
-U username 用户名,默认值postgres
-h hostname 主机名,默认值localhost
-p port 端口号,默认值5432
-d dbname 要连接的数据库名,默认值postgres
但是在知道了这个命令的基本用法以后,却并不能直接连接到刚启动的数据库上,我们先尝试一下:
TYPE:指的是连接类型,一般有local和host两种,local指的是本地连接,host指的是从远程主机连接或本地主机的localhost地址连接
DATABASE:指的是要连接的数据库,all表示所有,还可以使用具体的数据库名,比如postgres
USER:指的是用来连接的用户名,all表示所有用户,还可以使用具体的用户名,比如postgres
ADDRESS:指的是连接数据库的客户端IP地址来源,127.0.0.1/32表示只允许来自己本机的连接,0.0.0.0/0表示允许来自所有ip的连接,192.168.1.0/24表示允许192.168.1.1-192.168.1.255这个地址段的ip地址连接
METHOD:表示连接的时候使用的认证方式,常用的有trust,表示信任所有连接。md5,表示需要连接的客户端提供一个加密密码来登录。
在linux系统上,data目录默认在/var/lib/psql/9.6/
下。
本地连接非常好理解,就是从安装PostgreSQL的主机上连接,那 peer 和 ident 认证又是怎么回事呢?PostgreSQL的官方文档的官方文档上是这么说的:
peer认证是安装了PostgreSQL服务端的系统,通过getpeereid()函数获取连接客户端的用户名,然后通过map映射来进行客户认证的一种认证方式,要求只能用在客户端和服务端都安装在同一台电脑上时,客户端连接服务端的认证。
ident认证是客户端从一个ident服务器上获取一个用户名,作为连接服务器端数据库的用户的认证方式,也可能用到map映射。这种认证方式只支持TCP/IP连接的方式。
上面的两个认证里都提到了map映射,map映射又指的什么呢?
map映射是用来将系统用户映射到对应的postgres数据库用户,用来限制指定的用户使用指定的账号来登陆。
介绍了这么多概念,可能不是很好理解,我们举个例子说明并实际操作一下就明白了。map映射是在data目录下的pg_ident.conf
目录里配置的,其基本定义格式如下:
# MAPNAME SYSTEM-USERNAME PG-USERNAME
mm root postgres
MAPNAME指的是映射的名称
SYSTEM-USERNAME就是系统用户的名称,比如root
PG-USERNAME就是数据库里存在的用户名称,比如postgres
上面定义的map意思就是,我定义了一个叫做mm的映射,当客户端用户是root的时候,允许它用postgres用户来登陆。
那么我们来尝试连接一下。先将pg_hba.conf里的连接认证方式修改为下面的格式:
可以看到,此时的用户名不是root,就不能使用postgres用户来连接,提示认证失败。那么再回到root用户,然后尝试一下PostgreSQL另外一种连接方式,命令如下:
psql postgres://postgres@
上面所有的内容就是命令行连接方式的内容
2. 图形界面连接
PostgreSQL官方提供了用来连接PostgreSQL数据库的图形界面工具,叫做pgAdmin,目前最新版本已经是pgAdmin 4。但是在使用的时候发现,pgAdmin 4使用的是web形式来连接数据库,pgAdmin 4客户端就像是一个专用的浏览器,连接的时候会很慢。而pgAdmin 3更像是一个客户端工具,连接速度非常快,切换数据库和表的时候速度也更快。因此,这里我们使用pgAdmin3来讲解,等到后面pgAdmin 4的版本有改进了之后再更新这部分的内容。
pgAdmin的官网地址是http://www.pgadmin.org,打开官网后,其页面如下所示:
左边的对象浏览器是你的服务器页面,pgAdmin 将服务器分为一个个服务器组,一个组里可以包含多台服务器,便于管理。
右边上面位置则是用来显示服务器或服务器中的数据库、表的各种详细信息页面
右边下面位置则是用来执行SQL语句的位置,这也是为什么pgAdmin被成为管理和开发平台的原因之一。
点击文件,选择添加服务器:
前面我们讲到,刚安装好并初始化完毕后,PostgreSQL服务器默认监听的地址是本地地址,即localhost。而pgAdmin我们一般都是在自己的电脑上安装,然后远程连接到机房的物理服务器上。那怎么允许我们的机器可以连接到PostgreSQL服务器端呢?这里涉及到data目录下两个配置文件:
postgresql.conf
pg_hba.conf
在postgresql.conf中有一个listen_address的配置,它的默认值如下:
默认监听localhost,这就是为什么刚安装好的PostgreSQL只能在本机上连接的原因。我们将这个地址修改为0.0.0.0或服务器的ip地址,如下所示:
listen_addresses = '192.168.1.244'
然后重启服务器,查看一下PostgreSQL服务端监听的地址:
可以看到,确实监听在192.168.1.244这个地址上了。这个时候还有一个问题,那就是认证的问题。刚才我们讲过peer和ident两种认证方式,前者只适用于本地连接,而后者则需要从ident服务器上获取用户名。都不适合我们当前的连接方式,那么还需要再修改认证方式,这里要介绍的认证方式是md5和trusted。
md5 认证方式是通过账号密码的方式认证,但是密码的传输过程是使用md5加密的
trust 认证方式则是不进行任何认证,默认信任所有的连接,属于最不安全的一种认证方式。
但是从第一章到现在,我们都没讲过PostgreSQL的密码设置问题,也没有为数据库设置一个密码,那么我们只能先使用trusted的认证方式先连接到数据库上,再考虑修改数据库密码的问题。修改pg_hba.conf中的连接方式如下:
host all all trust
重启服务器,再从pgAdmin上连接:
pg_hba.conf:用来配置连接位置、认证方式
postgresql.conf:用来配置服务器端监听的地址和端口,配置选项是listen_addresses和listen_port。
pg_ident.conf:用来设置ident和peer认证方式的用户名映射
3. 需要注意的问题
一定要理解本地连接、远程连接的概念以及和pg_hba.conf中的TYPE类型进行对应