Postgresql intarray错误:未定义符号:pfree

时间:2012-05-08 01:04:17

标签: postgresql greenplum

我正在尝试为我的Greenplum数据库4.2.1.0安装Postgresql(8.2.15)additional supplied modules intarray和intagg。安装似乎成功;我按照教程here将所有文件复制到greenplumlib-db-4.2.1.0 / lib / postgresql share / postgresql目录中。但是当我尝试执行我的java代码时,它会抛出一个“未定义的符号”错误:

org.postgresql.util.PSQLException: ERROR: could not load library "/usr/local/greenplum-db-4.2.1.0/lib/postgresql/_int.so": /usr/local/greenplum-db-4.2.1.0/lib/postgresql/_int.so: undefined symbol: pfree
at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2062)
at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1795)
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:257)
at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:479)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:353)
at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:345)
at tuffy.db.RDB.execute(RDB.java:354)
at tuffy.db.RDB.resetSchema(RDB.java:700)
at felix.main.Felix.parseFelixQuery(Felix.java:106)
at felix.main.Felix.run(Felix.java:755)
at felix.main.Main.main(Main.java:69)

表示符号 pfree 未定义。我检查了版本号:Greenplum中的postgresql和附加模块都是8.2.15。我错过了什么吗?

更新:教程的链接似乎不稳定;它基本上提供了一些简单的步骤来完成安装:

Get any of the postgresql 8.2 source package from the official site
su - gpadmin
Unpack the source, then go to ~/postgresql-8.2.xx/contrib/xxx
make USE_PGXS=1 COPT="-Wno-error" install
(Optional for Greenplum MPP) Use gpssh to copy whatever .so file that just get installed       under /usr/local/greenplum-db/lib/postgresql to other nodes
psql -f xxx.sql [DBNAME]

更新: 谢谢您的回答。

我正在安装Greenplum,但它只包含postgresql 8.2.15,所以我必须使用这个版本。我已将整个/ usr / local / pgsql / lib目录复制到greenplum库,它似乎让intarray工作,但现在我有一个新的错误:

could not load library "/usr/local/greenplum-db-4.2.1.0/lib/postgresql/plpgsql.so":
/usr/local/greenplum-db-4.2.1.0/lib/postgresql/plpgsql.so: undefined symbol: heap_copytuple 

似乎我错过了一些文件...

谢谢!

1 个答案:

答案 0 :(得分:2)

您可能遗漏了PostgreSQL 8.2 has reached of end of life last year

我建议升级到更新版本,最好升级到当前版本9.1,其中安装扩展程序(以前称为“附加提供的模块”)intarray是一个问题:

CREATE EXTENSION intarray;

The manual about CREATE EXTENSION.