diff options
author | 无闻 <u@gogs.io> | 2015-10-21 13:08:42 -0400 |
---|---|---|
committer | 无闻 <u@gogs.io> | 2015-10-21 13:08:42 -0400 |
commit | a301c7ed26d401f9a01b52cac5c0d53f33a1121b (patch) | |
tree | b1b794eae74fc2876647744525dc270ae4adc115 | |
parent | eac91a74d87fcd9cfa38fcc9fb67af709a8e7a42 (diff) | |
parent | f7c7837fc84198cc0b62551fe2de9b68abd32140 (diff) | |
download | gitea-a301c7ed26d401f9a01b52cac5c0d53f33a1121b.tar.gz gitea-a301c7ed26d401f9a01b52cac5c0d53f33a1121b.zip |
Merge pull request #1814 from 0rax/develop
Update docker `socat` link creation
-rwxr-xr-x | docker/start.sh | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/docker/start.sh b/docker/start.sh index c687515f5d..42bdb3c541 100755 --- a/docker/start.sh +++ b/docker/start.sh @@ -13,12 +13,24 @@ for f in /data/gogs/data /data/gogs/conf /data/gogs/log /data/git /data/ssh; do done # Bind linked docker container to localhost socket using socat -env | sed -En 's|(.*)_PORT_([0-9]*)_TCP=tcp://(.*):(.*)|\1_\2 socat -ls TCP4-LISTEN:\2,fork,reuseaddr TCP4:\3:\4|p' | \ -while read NAME CMD; do - mkdir -p /app/gogs/docker/s6/SOCAT_$NAME - echo -e "#!/bin/sh\nexec $CMD" > /app/gogs/docker/s6/SOCAT_$NAME/run - chmod +x /app/gogs/docker/s6/SOCAT_$NAME/run -done +USED_PORT="3000:22" +while read NAME ADDR PORT; do + if test -z "$NAME$ADDR$PORT"; then + continue + elif echo $USED_PORT | grep -E "(^|:)$PORT($|:)" > /dev/null; then + echo "init:socat | Can't bind linked container ${NAME} to localhost, port ${PORT} already in use" 1>&2 + else + SERV_FOLDER=/app/gogs/docker/s6/SOCAT_${NAME}_${PORT} + mkdir -p ${SERV_FOLDER} + CMD="socat -ls TCP4-LISTEN:${PORT},fork,reuseaddr TCP4:${ADDR}:${PORT}" + echo -e "#!/bin/sh\nexec $CMD" > ${SERV_FOLDER}/run + chmod +x ${SERV_FOLDER}/run + USED_PORT="${USED_PORT}:${PORT}" + echo "init:socat | Linked container ${NAME} will be binded to localhost on port ${PORT}" 1>&2 + fi +done << EOT +$(env | sed -En 's|(.*)_PORT_([0-9]+)_TCP=tcp://(.*):([0-9]+)|\1 \3 \4|p') +EOT # Exec CMD or S6 by default if nothing present if [ $# -gt 0 ];then |