上一篇讲了在已经安装了PG数据库的情况下,安装全文搜索插件zhparser遇到的问题。在一个全新的环境中安装带有全文搜索插件zhparser的PG数据库,可以使用已经做好的Docker镜像,在安装的过程中,我来说说我遇到过的问题,大部分问题来自postgresql镜像。
1、拉取zhparser的镜像
基本运行命令:
docker run -p 5432:5432 chenxinaz/zhparser
在docker hub中zhparser项目的地址,https://hub.docker.com/r/chenxinaz/zhparser,这个镜像基于postgresql的镜像来做的,包含postgresql的数据库,不用额外安装postgresql数据库。上面的运行命令测试还可以,不建议正式使用。
2、初始化插件
在指定数据库初始化插件,运行下面SQL:
CREATE EXTENSION zhparser;
CREATE TEXT SEARCH CONFIGURATION chinese_zh (PARSER = zhparser);
ALTER TEXT SEARCH CONFIGURATION chinese_zh ADD MAPPING FOR n,v,a,i,e,l WITH simple;
测试插件是否安装成功SQL:
select ts_debug('chinese_zh', '白垩纪是地球上海陆分布和生物界急剧变化、火山活动频繁的时代');
3、关于postgresql镜像的高级参数
zhparser的可用环境参数大部分来自postgresql镜像,可以直接查看postgresql进行的环境参数。在初始化容器的时候,不设定容器参数,之后改起来就很麻烦。
3.1、指定数据库用户和密码
docker run -d --name pg -e POSTGRES_PASSWORD=password chenxinaz/zhparser
能指定的环境参数:
- POSTGRES_PASSWORD
- POSTGRES_USER
- POSTGRES_DB
- POSTGRES_INITDB_ARGS
- POSTGRES_INITDB_WALDIR
- PGDATA
3.2、推荐一组比较好用的命令
这组命令能挂载配置目录,挂载数据库目录,挂载初始化目录,用于数据库的初始化。
#复制一个配置文件的副本到本地目录
$ docker run -i --rm postgres cat /usr/share/postgresql/postgresql.conf.sample > my-postgres.conf
# 指定配置文件的位置
$ docker run -d
-p 15432:5432
-e POSTGRES_PASSWORD=password
-v "$本地配置文件位置/postgres.conf":/etc/postgresql/postgresql.conf
-v "$本地数据文件位置/data":/var/lib/postgresql/data
-v "$初始化脚本位置/docker-entrypoint-initdb.d":/docker-entrypoint-initdb.d
--name=pg
chenxinaz/zhparser
-c 'config_file=/etc/postgresql/postgresql.conf'
其中"$初始化脚本位置"中能用的脚本,可以是sql文件、压缩文件、可执行文件。例如:
#!/usr/bin/env bash
# Import SQL
echo -n "=======IMPORT SQL DATA======="
createdb -U postgres test
psql -U postgres test < /docker-entrypoint-initdb.d/test.sql
echo "=======IMPORT SQL DONE======="
其他参考官方项目文档:https://hub.docker.com/_/postgres。
4、常用备份
4.1、导出数据库:
docker exec -it pg pg_dump -h localhost -U postgres 数据库名 >/data/dum.sql
4.2、导入数据库:
docker exec -i pg psql -U postgres 数据库名 < /data/dum.sql