deploy_server.sh 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. #!/usr/bin/env bash
  2. #################
  3. # Parse options #
  4. #################
  5. instructions() {
  6. echo "Usage: $0 [-i] [ -d ] [ -p ] [ -b ] [-a] [-t]" >&2
  7. echo " -i: initial peer"
  8. echo " -d: device" >&2
  9. echo " -p: server identity path" >&2
  10. echo " -b: block_ids" >&2
  11. echo " -a: host maddrs" >&2
  12. echo " -t: whether to run local tests" >&2
  13. exit 1
  14. }
  15. if [ ! $# -ge 8 ]; then
  16. instructions
  17. fi
  18. while getopts ":i:d:p:b:a:t:" option; do
  19. case $option in
  20. i) INITIAL_PEER=${OPTARG}
  21. ;;
  22. d) DEVICE=${OPTARG}
  23. ;;
  24. p) SERVER_ID_PATH=${OPTARG}
  25. ;;
  26. b) BLOCK_IDS=${OPTARG}
  27. ;;
  28. a) HOST_MADDR=${OPTARG} # TODO: allow several maddrs
  29. ;;
  30. t) RUN_LOCAL_TESTS=true
  31. ;;
  32. \?) instructions
  33. ;;
  34. esac
  35. done
  36. echo "=========="
  37. echo "= Config ="
  38. echo "=========="
  39. echo "Initial peer: ${INITIAL_PEER}"
  40. echo "Device: ${DEVICE}"
  41. echo "Server name: ${SERVER_ID_PATH}"
  42. echo "Server address: ${HOST_MADDR}"
  43. echo "Bloom blocks: ${BLOCK_IDS}"
  44. ###########################
  45. # Install or activate env #
  46. ###########################
  47. # TODO fix bug with self calling
  48. source ~/miniconda3/etc/profile.d/conda.sh
  49. if conda env list | grep ".*bloom-demo.*" >/dev/null 2>/dev/null; then
  50. conda activate bloom-demo
  51. else
  52. conda create -y --name bloom-demo python=3.8.12 pip
  53. conda activate bloom-demo
  54. conda install -y -c conda-forge cudatoolkit-dev==11.3.1 cudatoolkit==11.3.1 cudnn==8.2.1.32
  55. pip install -i https://pypi.org/simple torch==1.12.0+cu113 -f https://download.pytorch.org/whl/torch_stable.html
  56. pip install -i https://pypi.org/simple -r requirements.txt
  57. fi
  58. ##############
  59. # Run server #
  60. ##############
  61. python -m cli.run_server --converted_model_name_or_path bigscience/test-bloomd-6b3 --device ${DEVICE} --initial_peer ${INITIAL_PEER} \
  62. --block_indices ${BLOCK_IDS} --torch_dtype float32 --identity_path ${SERVER_ID_PATH} --host_maddrs ${HOST_MADDR} &> ${SERVER_ID_PATH}.log