X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b30dca66a056bc6ee627bab5956dd8884a0e74aa..6bee9f6a6be594a7bcda9ec4062d56e325b2efc6:/tools/arvbox/lib/arvbox/docker/common.sh diff --git a/tools/arvbox/lib/arvbox/docker/common.sh b/tools/arvbox/lib/arvbox/docker/common.sh index 66f249510d..f391376f39 100644 --- a/tools/arvbox/lib/arvbox/docker/common.sh +++ b/tools/arvbox/lib/arvbox/docker/common.sh @@ -2,16 +2,19 @@ # # SPDX-License-Identifier: AGPL-3.0 +export RUBY_VERSION=2.7.0 +export BUNDLER_VERSION=2.2.19 -export PATH=${PATH}:/usr/local/go/bin:/var/lib/gems/bin -export GEM_HOME=/var/lib/gems -export GEM_PATH=/var/lib/gems +export DEBIAN_FRONTEND=noninteractive +export PATH=${PATH}:/usr/local/go/bin:/var/lib/arvados/bin:/usr/src/arvados/sdk/cli/binstubs export npm_config_cache=/var/lib/npm export npm_config_cache_min=Infinity export R_LIBS=/var/lib/Rlibs export HOME=$(getent passwd arvbox | cut -d: -f6) +export ARVADOS_CONTAINER_PATH=/var/lib/arvados-arvbox defaultdev=$(/sbin/ip route|awk '/default/ { print $5 }') +dockerip=$(/sbin/ip route | grep default | awk '{ print $3 }') containerip=$(ip addr show $defaultdev | grep 'inet ' | sed 's/ *inet \(.*\)\/.*/\1/') if test -s /var/run/localip_override ; then localip=$(cat /var/run/localip_override) @@ -19,10 +22,10 @@ else localip=$containerip fi -root_cert=/var/lib/arvados/root-cert.pem -root_cert_key=/var/lib/arvados/root-cert.key -server_cert=/var/lib/arvados/server-cert-${localip}.pem -server_cert_key=/var/lib/arvados/server-cert-${localip}.key +root_cert=$ARVADOS_CONTAINER_PATH/root-cert.pem +root_cert_key=$ARVADOS_CONTAINER_PATH/root-cert.key +server_cert=$ARVADOS_CONTAINER_PATH/server-cert-${localip}.pem +server_cert_key=$ARVADOS_CONTAINER_PATH/server-cert-${localip}.key declare -A services services=( @@ -32,12 +35,12 @@ services=( [api]=8004 [controller]=8003 [controller-ssl]=8000 - [sso]=8900 [composer]=4200 [arv-git-httpd-ssl]=9000 [arv-git-httpd]=9001 [keep-web]=9003 [keep-web-ssl]=9002 + [keep-web-dl-ssl]=9004 [keepproxy]=25100 [keepproxy-ssl]=25101 [keepstore0]=25107 @@ -46,6 +49,8 @@ services=( [doc]=8001 [websockets]=8005 [websockets-ssl]=8002 + [webshell]=4201 + [webshell-ssl]=4202 ) if test "$(id arvbox -u 2>/dev/null)" = 0 ; then @@ -57,21 +62,20 @@ else fi run_bundler() { + GEMLOCK=/var/lib/arvados/lib/ruby/gems/gems.lock + flock $GEMLOCK /var/lib/arvados/bin/gem install --no-document bundler:$BUNDLER_VERSION if test -f Gemfile.lock ; then frozen=--frozen else frozen="" fi - if ! test -x /var/lib/gems/bin/bundler ; then - bundlergem=$(ls -r $GEM_HOME/cache/bundler-*.gem 2>/dev/null | head -n1 || true) - if test -n "$bundlergem" ; then - flock /var/lib/gems/gems.lock gem install --local --no-document $bundlergem - else - flock /var/lib/gems/gems.lock gem install --no-document bundler - fi + BUNDLER=bundle + if test -x $PWD/bin/bundle ; then + # If present, use the one associated with rails workbench or API + BUNDLER=$PWD/bin/bundle fi - if ! flock /var/lib/gems/gems.lock bundler install --path $GEM_HOME --local --no-deployment $frozen "$@" ; then - flock /var/lib/gems/gems.lock bundler install --path $GEM_HOME --no-deployment $frozen "$@" + if ! flock $GEMLOCK $BUNDLER install --verbose --local --no-deployment $frozen "$@" ; then + flock $GEMLOCK $BUNDLER install --verbose --no-deployment $frozen "$@" fi } @@ -86,12 +90,12 @@ pip_install() { popd if [ "$PYCMD" = "python3" ]; then - if ! pip3 install --no-index --find-links /var/lib/pip $1 ; then - pip3 install $1 - fi + if ! pip3 install --prefix /usr/local --no-index --find-links /var/lib/pip $1 ; then + pip3 install --prefix /usr/local $1 + fi else - if ! pip install --no-index --find-links /var/lib/pip $1 ; then + if ! pip install --no-index --find-links /var/lib/pip $1 ; then pip install $1 - fi + fi fi }