Build Install PostgreSQL 14.0 And Use For SCO OpenServer 6.0.0 D2M1
==================================================================================================================================
在 SCO OpenServer6 系统上编译安装 PostgreSQL 14.0
纯干货,无废话。
写在前面的话:
PostgreSQL 数据库软件从 10 版本开始,就不再支持 SCO OpenServer6 系统了,但这并不代表我们无法在 SCO OpenServer 6 系统上安装使用 PostgreSQL 10 以上的数据库版本,只是相对麻烦一点。
因为 PostgreSQL 数据库是使用原生的 C 语言开发的,这对我们是一个很好的信号,我们有理由相信,经过简单的修改,我们是能够在 SCO OpenServer 6 系统上使用 PostgreSQL 14.0 的,当然,前提是你必须要有足够的耐心。
编译需要的前置条件:
1、 系统必须安装开发软件包;
2、 系统必须打上 SCO OpenServer Release 6.0.0 Maintenance Pack 4 (ver 1.0.0Ce) 补丁包;
3、 编译必须使用 gmake 3.8 或以上版本,测试中发现 3.8 或 3.8.2 的版本最好,其他版本在编译安装 make 程序包的时候需要修改程序代码。
4、 编译 PostgreSQL 14.0 必须使用 gnu m4 和 gnu bison。
编译安装 make-3.8.0 的软件包方法如下。
1、 展开 make-3.8.0.tar.bz2
2、 进入 make-3.8.0 目录
3、 执行编译前配置
# ./configure --prefix=/usr/gnu --build=i586-sco-sysv5 --host=i586-sco-sysv5
4、 编译并安装
# make
# make install
5、 建立连接
# cd /usr/bin
# ln -sf /usr/gnu/bin/make gmake
编译安装 gnu m4 的软件包的方法如下(我安装的版本是 1.4.10b)。
1、 展开 m4-1.4.10b.tar.bz2
2、 进入 m4-1.4.10b 目录
3、 执行编译前的配置
# ./configure --prefix=/usr/gnu --build=i586-sco-sysv5 --host=i586-sco-sysv5
4、 编译并安装
# gmake
# gmake install
5、 建立软链接
# cd /usr/bin
# mv m4 m4#
# ln -sf /usr/gnu/bin/m4 m4
编译安装 gnu bison 的软件包的方法如下(我安装的版本是 2.2)。
1、 展开 bison-2.2.tar.bz2
2、 进入 bison-2.2 目录
3、 执行编译前的配置
# ./configure --prefix=/usr/gnu --build=i586-sco-sysv5 --host=i586-sco-sysv5
4、 编译并安装
# gmake
# gmake install
5、 建立软链接
# cd /usr/bin
# mv yacc yacc#
# ln -sf /usr/gnu/bin/yacc yacc
# ln -sf /usr/gnu/bin/bison bison
PostgreSQL 14.0 在 SCO OpenServer 6 系统上的安装使用
做好前置工作后,我们开始进入 PostgreSQL 14.0 的安装,过程如下:
Step 1:
下载 postgresql-14.0.tar.bz2 文件,放置在 /tmp 目录下,并展开压缩文件:
# cd /tmp
# bzip2 –d -c postgresql-14.0.tar.bz2 | tar xvf -
Step 2:
修改 PostgreSQL 14.0 的安装程序源码,添加一些内容:
1、修改 postgresql-14.0/src/include/c.h 文件,在其中加入如下内容:
在:
下面加入:
查找:
-
#define FLEXIBLE_ARRAY_MEMBER /* empty */
将其修改为:
-
#ifndef FLEXIBLE_ARRAY_MEMBER
-
#define FLEXIBLE_ARRAY_MEMBER 512 /* empty */
-
#endif
2、修改 postgresql-14.0/src/backend/storage/lmgr/spin.c
将其中的:
-
#ifndef HAVE_ATOMICS
-
#define NUM_EMULATION_SEMAPHORES (NUM_SPINLOCK_SEMAPHORES + NUM_ATOMICS_SEMAPHORES)
-
#else
-
#define NUM_EMULATION_SEMAPHORES (NUM_SPINLOCK_SEMAPHORES)
-
#endif /* DISABLE_ATOMICS */
修改为:
-
#ifndef HAVE_ATOMICS
-
#define NUM_EMULATION_SEMAPHORES (NUM_SPINLOCK_SEMAPHORES + NUM_ATOMICS_SEMAPHORES + 128)
-
#else
-
#define NUM_EMULATION_SEMAPHORES (NUM_SPINLOCK_SEMAPHORES+128)
-
#endif /* DISABLE_ATOMICS */
3、在 postgresql-14.0/src/template 目录下添加文件 sco , 内容如下:
4、在 postgresql-14.0/src/template 目录下添加文件 unixware , 内容如下:
-
if test "$GCC" != yes; then
-
# The -Kno_host is for a bug in the compiler. See -hackers
-
# discussion on 7-8/Aug/2003.
-
cat >conftest.c <<__EOF__
-
extern char *strcpy(char *, const char *);
-
-
static void f(char *p, int n){
-
strcpy(p+n,"");
-
}
-
void g(void){
-
f(0, 0);
-
}
-
__EOF__
-
-
# Debugging and optimization are mutually exclusive
-
if test "$enable_debug" != yes; then
-
CFLAGS="-O"
-
fi
-
if $CC -c -O -Kinline conftest.c >conftest.err 2>&1; then
-
CFLAGS="$CFLAGS -Kinline"
-
else
-
CFLAGS="$CFLAGS -Kinline,no_host"
-
fi
-
rm -f conftest.*
-
-
PTHREAD_CFLAGS="-Kpthread"
-
-
# The effect of doing threading for the backend does not work
-
# because of a threading bug that appears in the regression tests:
-
#
-
# in make check, the plpgsql test (plpgsql.sql)
-
# set statement_timeout to 1000;
-
# select blockme();
-
# reset statement_timeout;
-
#
-
# per report from Olivier PRENANT
-
-
fi
-
-
# Unixware's ldap library reportedly needs these too
-
EXTRA_LDAP_LIBS="-llber -lresolv"
5、修改 postgresql-14.0/src/bin/psql/describe.c 文件,将其中的:
-
processSQLNamePattern(pset.db, &buf, pattern,
-
!showSystem && !pattern, false,
-
NULL, "n.nspname", NULL,
-
NULL);
全部修改成:
-
processSQLNamePattern(pset.db, &buf, pattern,
-
(!showSystem && !pattern) ? true : false, false,
-
NULL, "n.nspname", NULL,
-
NULL);
=======================================================================================================
= 注意:这个文件中类似的地方,有多处,需要耐心修改。
= 这个函数的传入参数 !showSystem && !pattern 表示 showSystem 不等于 0 并且 pattern 不等于 0 的时候,返回“真”
= 否则返回 “假” , 但是 sco openserver 6.0.0Ni 上的 c99 不支持在函数中的参数类似 !showSystem && !pattern 写法,
= 等价的写法必须是 (!showSystem && !pattern) ? true : false
= 明确的告知函数中传入的 bool 值是 true 或者是 false ,否则编译时会报 ERROR 没有定义的错误。
======================================================================================================
6、修改 postgresql-14.0/src/backend/optimizer/util/plancat.c 文件,在函数:
-
bool
-
relation_excluded_by_constraints(PlannerInfo *root,
-
RelOptInfo *rel, RangeTblEntry *rte)
中找到如下位置:
-
include_notnull = (!rte->inh || rte->relkind == RELKIND_PARTITIONED_TABLE);
将其修改为:
-
include_notnull = (rte->inh == 0 || rte->relkind == RELKIND_PARTITIONED_TABLE) ? true : false ;
================================================================================================================
= 注意:这个地方的赋值操作,(!rte->inh || rte->relkind == RELKIND_PARTITIONED_TABLE) 表示 !rte->inh 不为“真”,
= 或者是 rte->relkind 等于 RELKIND_PARTITIONED_TABLE 时,返回真值,否则返回“假”,并将该布尔值赋值给 include_notnull
= 该写法在 SCO OpenServer 6.0 的 c 编译器中不支持,会报 ERROR 没有定义的错误。
= 等价的写法为:include_notnull = (rte->inh == 0 || rte->relkind == RELKIND_PARTITIONED_TABLE) ? true : false ;
================================================================================================================
7、修改 postgresql-14.0/src/backend/access/nbtree/nbtinsert.c 文件:
在:
-
static void
-
_bt_delete_or_dedup_one_page(Relation rel, Relation heapRel, ...
函数的最后部分,找到:
-
if (BTGetDeduplicateItems(rel) && itup_key->allequalimage)
-
_bt_dedup_pass(rel, buffer, heapRel, insertstate->itup,
-
insertstate->itemsz, (indexUnchanged || uniquedup) );
修改为:
-
if (BTGetDeduplicateItems(rel) && itup_key->allequalimage)
-
_bt_dedup_pass(rel, buffer, heapRel, insertstate->itup,
-
insertstate->itemsz, (indexUnchanged || uniquedup) ? true : false );
说明:
================================================================================================================
= 注意:与前面的原因一样
= 这个函数中的 (indexUnchanged || uniquedup) 部分表示 indexUnchanged 或者是 uniquedup 为真时,返回“真”,否则返回“假”,
= 但是这种写法在 SCO OpenServer 6.0 的 c 编译器中不支持,在编译的时候会报 ERROR 没有定义的错误信息,等价的写法为:
= (indexUnchanged || uniquedup) ? true : false
=================================================================================================================
8、在 postgresql-14.0/src/include/port/ 目录下添加文件 sco.h , 内容如下:
-
/*
-
* src/include/port/sco.h
-
*
-
* see src/backend/libpq/pqcomm.c */
-
#define SCO_ACCEPT_BUG
-
-
#define USE_UNIVEL_CC
9、在 postgresql-14.0/src/include/port/ 目录下添加文件 unixware.h , 内容如下:
-
/*
-
* src/include/port/unixware.h
-
*
-
* see src/backend/libpq/pqcomm.c */
-
#define SCO_ACCEPT_BUG
-
-
/***************************************
-
* Define this if you are compiling with
-
* the native UNIXWARE C compiler.
-
***************************************/
-
#define USE_UNIVEL_CC
10、在 postgresql-14.0/src/makefiles/ 目录下添加 sco 系统的编译文件 Makefile.sco ,内容如下:
-
AROPT = cr
-
export_dynamic = -Wl,-Bexport
-
-
DLSUFFIX = .so
-
ifeq ($(GCC), yes)
-
CFLAGS_SL = -fpic
-
else
-
CFLAGS_SL = -K PIC
-
endif
-
-
# Rule for building a shared library from a single .o file
-
%.so: %.o
-
$(LD) -G -Bdynamic -o $@ $<
11、在 postgresql-14.0/src/makefiles/ 目录下添加 unixware 系统的编译文件 Makefile.unixware ,内容如下:
-
AROPT = crs
-
ifeq ($(with_gnu_ld), yes)
-
export_dynamic = -Wl,-E
-
else
-
export_dynamic = -Wl,-Bexport
-
endif
-
-
ifeq ($(ld_R_works), yes)
-
ifeq ($(with_gnu_ld), yes)
-
rpath = -Wl,-rpath,'$(rpathdir)'
-
else
-
rpath = -Wl,-R'$(rpathdir)'
-
endif
-
endif
-
-
# Unixware needs threads for everything that uses libpq
-
CFLAGS += $(PTHREAD_CFLAGS)
-
-
DLSUFFIX = .so
-
ifeq ($(GCC), yes)
-
CFLAGS_SL = -fpic
-
else
-
CFLAGS_SL = -K PIC
-
endif
-
ifeq ($(GCC), yes)
-
SO_FLAGS = -shared
-
else
-
SO_FLAGS = -G
-
endif
-
-
# Rule for building a shared library from a single .o file
-
%.so: %.o
-
$(CC) $(CFLAGS) $(LDFLAGS) $(LDFLAGS_SL) $(SO_FLAGS) -o $@ $<
-
-
sqlmansect = 5sql
12、在 postgresql-14.0/configure 文件中,添加编译操作系统环境描述内容,在:
-
openbsd*) template=openbsd ;;
下面加入:
在:
-
solaris*) template=solaris ;;
下面加入:
-
sysv5*) template=unixware ;;
在:
-
if test "$ac_cv_prog_cc_c99" = no; then
-
as_fn_error $? "C compiler \"$CC\" does not support C99" "$LINENO" 5
-
fi
上面加入
变成:
-
ac_cv_prog_cc_c99=yes
-
if test "$ac_cv_prog_cc_c99" = no; then
-
as_fn_error $? "C compiler \"$CC\" does not support C99" "$LINENO" 5
-
fi
13、在 postgresql-14.0/configure.in 文件中,添加编译操作系统环境描述内容,在:
-
openbsd*) template=openbsd ;;
下面加入:
在:
-
solaris*) template=solaris ;;
下面加入:
-
sysv5*) template=unixware ;;
在:
-
if test "$ac_cv_prog_cc_c99" = no; then
-
AC_MSG_ERROR([C compiler "$CC" does not support C99])
-
fi
上面加入:
变成:
-
ac_cv_prog_cc_c99=yes
-
if test "$ac_cv_prog_cc_c99" = no; then
-
AC_MSG_ERROR([C compiler "$CC" does not support C99])
-
fi
14、修改 postgresql-14.0/src/Makefile.shlib 文件,在其中加入共享库编译时的 sco 和 unixware 的支持。
在:
-
ifeq ($(PORTNAME), solaris)
-
ifeq ($(GCC), yes)
-
LINK.shared = $(COMPILER) -shared
-
else
-
LINK.shared = $(COMPILER) -G
-
endif
-
ifdef soname
-
ifeq ($(with_gnu_ld), yes)
-
LINK.shared += -Wl,-soname,$(soname)
-
else
-
LINK.shared += -h $(soname)
-
endif
-
endif
-
endif
下面加入:
-
ifeq ($(PORTNAME), sco)
-
ifeq ($(GCC), yes)
-
LINK.shared = $(CC) -shared
-
else
-
LINK.shared = $(CC) -G
-
endif
-
LINK.shared += -Wl,-z,text
-
ifdef soname
-
LINK.shared += -Wl,-h,$(soname)
-
endif
-
endif
-
-
ifeq ($(PORTNAME), unixware)
-
ifeq ($(GCC), yes)
-
LINK.shared = $(CC) -shared
-
else
-
LINK.shared = $(CC) -G
-
endif
-
LINK.shared += -Wl,-z,text
-
ifdef soname
-
LINK.shared += -Wl,-h,$(soname)
-
endif
-
endif
15、拷贝 postgresql-14.0/src/backend/utils/adt/jsonpath_scan.c 到 postgresql-14.0/src/include
-
# cp postgresql-14.0/src/backend/utils/adt/jsonpath_scan.c postgresql-14.0/src/include
Step 3:开始准备编译环境:
1、创建编译目录环境,建立一个编译目录,如 /tmp/objdir
2、写编译配置文件 build.sh,内容如下:
-
../postgresql-14.0/configure \
-
--prefix=/opt/PostgreSQL/14.0 \
-
--build=i586-sco-sysv5 \
-
--host=i586-sco-sysv5 \
-
--disable-spinlocks \
-
--disable-thread-safety \
-
--without-tcl \
-
--with-perl \
-
--with-openssl
3、修改其权限为 0755
4、进入 /tmp/objdir 目录,开始编译前环境配置。
-
# cd /tmp/objdir
-
# ../build.sh
Step 4:编译安装 PostgreSQL 14.0 软件
1、开始编译
Step 5:配置使用环境,使用 PostgreSQL 14.0
1、创建用户,进行使用前初始化。
# groupadd postgres
# mkdir /home
# chmod 0775 /home
# useradd -d /home/postgres -g postgres -s /bin/bash -m postgres
# passwd postgres
<选择 1 , 连续两次输入用户密码 >
2、编辑 /home/postgres/.bash_profile 文件,添加环境变量参数。
在:
export BASH_ENV
下面加入:
source $BASH_ENV
3、编辑 /home/postgres/.bashrc 文件,添加环境变量参数。
在文件最后,加入如下语句:
-
export PG_VERSION=14.0
-
export PG_HOME=/opt/PostgreSQL/${PG_VERSION}
-
export PGDATA=${HOME}/data
-
export PGLOG=${PGDATA}/pg_log
-
export PATH=$PATH:$PG_HOME/bin:.
-
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PG_HOME/lib:.
4、切换用户到 postgres
# su – postgres
5、创建数据库实例目录
$ mkdir data
6、初始化数据库实例
$ initdb -E utf-8 -U postgres –W
连续两次数据 postgres 密码
进入 data 目录,修改数据库配置文件
$ cd data
$ mkdir pg_log
$ chmod 0700 pg_log
$ vi pg_hba.conf
修改
local all all trust
为
local all all scram-sha-256
修改
host all all 127.0.0.1/32 trust
为
host all all 127.0.0.1/32 scram-sha-256
并在其下面添加
host all all 0.0.0.0/0 scram-sha-256
修改 postgresql.conf 文件
$ vi postgresql.conf
修改:
#listen_addresses = 'localhost'
为
listen_addresses = '*'
修改
#port = 5432
为
port = 5432
修改
#password_encryption = scram-sha-256
为
password_encryption = scram-sha-256
启动 postgresql 数据库实例
$ pg_ctl -D ${PGDATA} -l ${PGDATA}/pg_log/startlog start
查看是否正常:
$ psql –l
$ passwd:
数据数据库用户(postgres)密码
如果显示:
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+---------+-------+-----------------------
postgres | postgres | UTF8 | C | C |
template0 | postgres | UTF8 | C | C | =c/postgres +
| | | | | postgres=CTc/postgres
template1 | postgres | UTF8 | C | C | =c/postgres +
| | | | | postgres=CTc/postgres
(3 rows)
则表示成功
=============================================
特别注意:
本版本是在 SCO OpenServer 6 D2M1 编译的,如果在 SCO OpenServer 6.0.0 上使用,你可能还有其它的代码需要修改。我比较懒 ^_^. ,没有针对 SCO OpenServer 6.0.0 Ni 的系统进行修改。一个简单的使用办法是:
将 SCO OpenServer 6.0 D2M1 服务器上 /usr/lib/libssl.so.1.0 和 /usr/lib/libcrypto.so.1.0 拷贝到 SCO OpenServer 6.0.0 Ni 机器的 /usr/lib 目录下,即可正常使用。
^_^.