mirror of https://github.com/jackc/pgx.git
40 lines
2.2 KiB
Bash
Executable File
40 lines
2.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
set -eux
|
|
|
|
if [ "${PGVERSION-}" != "" ]
|
|
then
|
|
sudo apt-get remove -y --purge postgresql libpq-dev libpq5 postgresql-client-common postgresql-common
|
|
sudo rm -rf /var/lib/postgresql
|
|
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
|
|
sudo sh -c "echo deb http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main $PGVERSION >> /etc/apt/sources.list.d/postgresql.list"
|
|
sudo apt-get update -qq
|
|
sudo apt-get -y -o Dpkg::Options::=--force-confdef -o Dpkg::Options::="--force-confnew" install postgresql-$PGVERSION postgresql-server-dev-$PGVERSION postgresql-contrib-$PGVERSION
|
|
sudo chmod 777 /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "local all postgres trust" > /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "local all all trust" >> /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "host all pgx_md5 127.0.0.1/32 md5" >> /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "host all pgx_pw 127.0.0.1/32 password" >> /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "hostssl all pgx_ssl 127.0.0.1/32 md5" >> /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "host replication pgx_replication 127.0.0.1/32 md5" >> /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
echo "host pgx_test pgx_replication 127.0.0.1/32 md5" >> /etc/postgresql/$PGVERSION/main/pg_hba.conf
|
|
sudo chmod 777 /etc/postgresql/$PGVERSION/main/postgresql.conf
|
|
if $(dpkg --compare-versions $PGVERSION ge 9.6) ; then
|
|
echo "wal_level='logical'" >> /etc/postgresql/$PGVERSION/main/postgresql.conf
|
|
echo "max_wal_senders=5" >> /etc/postgresql/$PGVERSION/main/postgresql.conf
|
|
echo "max_replication_slots=5" >> /etc/postgresql/$PGVERSION/main/postgresql.conf
|
|
fi
|
|
sudo /etc/init.d/postgresql restart
|
|
fi
|
|
|
|
if [ "${CRATEVERSION-}" != "" ]
|
|
then
|
|
docker run \
|
|
-p "6543:5432" \
|
|
-d \
|
|
crate:"$CRATEVERSION" \
|
|
crate \
|
|
-Cnetwork.host=0.0.0.0 \
|
|
-Ctransport.host=localhost \
|
|
-Clicense.enterprise=false
|
|
fi
|