0

我正在尝试使用 bash shell 脚本从我的 Debian 6.0 服务器上的源代码构建 postgreSQL,但我遇到了问题。这是我到目前为止所做的代码:

# Initial
    apt-get update
    apt-get -y install aptitude bzip2 libbz2-dev git-core
    aptitude -y install sudo python-all-dev python-setuptools libxml2-dev libgeoip-dev libxslt1-dev uuid-dev gcc automake autoconf libpcre3-dev libssl-dev unzip zip python-psycopg2 libpq-dev wget make libreadline-dev
    aptitude -y full-upgrade 

# POSTGRESQL
###############################

# Postgresql Download & Install
    wget http://ftp.postgresql.org/pub/source/v8.4.6/postgresql-8.4.6.tar.gz -P /tmp
    mkdir /tmp/postgresql
    tar xzf /tmp/postgresql-8.4.6.tar.gz -C "/tmp/postgresql"
    cd /tmp/postgresql/
    mkdir /usr/local/pgsql
    ./configure --prefix=/usr/local/pgsql
    cd /usr/local/pgsql
    make
    make install

# Add User
    useradd -s /bin/false "postgresql_user"
    chown "postgresql_user" usr/local/pgsql

# Clean Up
    rm  /tmp/postgresql-8.4.6.tar.gz
    rm  /tmp/postgresql

# Create Database
    echo "CREATE ROLE PSQL LOGIN ENCRYPTED PASSWORD 'PASS';" | sudo -u postgresql_user usr/local/pgsql
    sudo -u postgresql_user /opt/bin/createdb --owner PSQL DATADB

我得到的错误如下:

/root/StackScript: line 22: ./configure: No such file or directory                                    
make: *** No targets specified and no makefile found.  Stop.                                          
make: *** No rule to make target `install'.  Stop.                                                    
chown: cannot access `usr/local/pgsql': No such file or directory                                                                                  
sudo: usr/local/pgsql: command not found                                                              
sudo: /opt/bin/createdb: command not found   

谁能告诉我哪里出错了?如果还有什么明显的我做错了,我总是乐于听到它!

4

1 回答 1

3

您做错的第一件事是编译旧主要版本的旧点版本。当有 8.4.15 时,你到底为什么要使用 8.4.6,并修复了很多重要的错误?请参阅版本控制政策。无论如何,您都不应该将 8.4 用于新部署,请使用最新版本进行新部署。

更好的是,使用pgapt.debian.org上的 debian 软件包而不是自己编译。

错误的直接原因是解压缩源 tarball 会产生一个目录,就像postgresql-8.4.6你拥有的/tmp/postgresql/postgresql-8.4.6. 您正在尝试在not中执行configure脚本。在运行之前进入创建的目录。/tmp/postgresql/tmp/postgresql/postgresql-8.4.6cdconfigure

于 2012-12-10T13:52:49.550 回答