f456f964ec
Replace the host with $DB_PORT, which is dependent to the database imagae's exposed port.
35 lines
1.7 KiB
Bash
35 lines
1.7 KiB
Bash
# deploy.sh in gogits image, replace the configs and run gogs
|
|
|
|
## Replace the database password
|
|
DB_TYPE=THE_DB_TYPE
|
|
DB_PASSWORD=THE_DB_PASSWORD
|
|
DB_ALIAS=DB
|
|
DB_TYPE_LINE=`awk '$0 ~ str{print NR}' str="DB_TYPE = mysql" $GOPATH/src/github.com/gogits/gogs/conf/app.ini`
|
|
DB_PASSWORD_LINE=`awk '$0 ~ str{print NR+1}' str="USER = root" $GOPATH/src/github.com/gogits/gogs/conf/app.ini`
|
|
|
|
sed -i "${DB_TYPE_LINE}s/.*$/DB_TYPE = $DB_TYPE/g" $GOPATH/src/github.com/gogits/gogs/conf/app.ini
|
|
sed -i "${DB_PASSWORD_LINE}s/.*$/PASSWD = $DB_PASSWORD/g" $GOPATH/src/github.com/gogits/gogs/conf/app.ini
|
|
|
|
if [ $DB_TYPE = "postgres" ]
|
|
then
|
|
# Add the postgres in gogs image.
|
|
apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys B97B0AFCAA1A47F044F244A07FCC7D46ACCC4CF8
|
|
echo "deb http://apt.postgresql.org/pub/repos/apt/ precise-pgdg main" > /etc/apt/sources.list.d/pgdg.list
|
|
apt-get update
|
|
apt-get -y -q install python-software-properties software-properties-common
|
|
apt-get -y -q install postgresql-9.3 postgresql-client-9.3 postgresql-contrib-9.3
|
|
fi
|
|
|
|
## Replace the database address and port
|
|
# When using --link in docker run, the database image's info looks like this:
|
|
# DB_PORT=tcp://172.17.0.2:3306
|
|
# DB_PORT_3306_TCP_PORT=3306
|
|
# DB_PORT_3306_TCP_PROTO=tcp
|
|
# DB_PORT_3306_TCP_ADDR=172.17.0.2
|
|
#sed -i "/HOST = 127.0.0.1:3306/c\HOST = $DB_PORT_3306_TCP_ADDR:$DB_PORT_3306_TCP_PORT" $GOPATH/src/github.com/gogits/gogs/conf/app.ini
|
|
sed -i "/HOST = 127.0.0.1:3306/c\HOST = `echo $DB_PORT | cut -d '/' -f 3`" $GOPATH/src/github.com/gogits/gogs/conf/app.ini
|
|
|
|
cd $GOPATH/src/github.com/gogits/gogs/
|
|
|
|
# The sudo is a must here, or the go within docker container won't get the current user by os.Getenv("USERNAME")
|
|
sudo ./gogs web
|