start-relup-test-cluster.sh 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. #!/usr/bin/env bash
  2. set -euo pipefail
  3. ## EMQX can only start with longname (https://erlang.org/doc/reference_manual/distributed.html)
  4. ## The host name part of EMQX's node name has to be static, this means we should either
  5. ## pre-assign static IP for containers, or ensure containers can communiate with each other by name
  6. ## this is why a docker network is created, and the containers's names have a dot.
  7. # ensure dir
  8. cd -P -- "$(dirname -- "$0")/../.."
  9. # shellcheck disable=SC1091
  10. source ./env.sh
  11. set -x
  12. IMAGE="${1}"
  13. PKG="$(readlink -f "${2}")"
  14. NET='emqx.io'
  15. NODE1="node1.$NET"
  16. NODE2="node2.$NET"
  17. WEBHOOK="webhook.$NET"
  18. BENCH="bench.$NET"
  19. COOKIE='this-is-a-secret'
  20. ## Erlang image is needed to run webhook server and emqtt-bench
  21. ERLANG_IMAGE="${EMQX_BUILDER}"
  22. # builder has emqtt-bench installed
  23. BENCH_IMAGE="$ERLANG_IMAGE"
  24. ## clean up
  25. docker rm -f "$BENCH" >/dev/null 2>&1 || true
  26. docker rm -f "$WEBHOOK" >/dev/null 2>&1 || true
  27. docker rm -f "$NODE1" >/dev/null 2>&1 || true
  28. docker rm -f "$NODE2" >/dev/null 2>&1 || true
  29. docker network rm "$NET" >/dev/null 2>&1 || true
  30. docker network create "$NET"
  31. docker run -d -t --name "$NODE1" \
  32. --net "$NET" \
  33. -e EMQX_LOG__CONSOLE_HANDLER__LEVEL=warning \
  34. -e EMQX_NODE_NAME="emqx@$NODE1" \
  35. -e EMQX_NODE_COOKIE="$COOKIE" \
  36. -p 18083:18083 \
  37. -v "$PKG:/emqx.tar.gz" \
  38. -v "$(pwd)/scripts/relup-test/run-pkg.sh:/run-pkg.sh" \
  39. "$IMAGE" /run-pkg.sh emqx.tar.gz
  40. docker run -d -t --name "$NODE2" \
  41. --net "$NET" \
  42. -e EMQX_LOG__CONSOLE_HANDLER__LEVEL=warning \
  43. -e EMQX_NODE_NAME="emqx@$NODE2" \
  44. -e EMQX_NODE_COOKIE="$COOKIE" \
  45. -p 18084:18083 \
  46. -v "$PKG:/emqx.tar.gz" \
  47. -v "$(pwd)/scripts/relup-test/run-pkg.sh:/run-pkg.sh" \
  48. "$IMAGE" /run-pkg.sh emqx.tar.gz
  49. docker run -d -t --name "$WEBHOOK" \
  50. --net "$NET" \
  51. -v "$(pwd)/.ci/fvt_tests/http_server:/http_server" \
  52. -w /http_server \
  53. -p 7077:7077 \
  54. "$ERLANG_IMAGE" bash -c 'rebar3 compile; erl -pa _build/default/lib/*/ebin -eval "http_server:start()"'
  55. docker run -d -t --name "$BENCH" \
  56. --net "$NET" \
  57. "$BENCH_IMAGE" \
  58. bash -c 'sleep 10000; exit 1'
  59. wait_limit=60
  60. wait_for_emqx() {
  61. wait_sec=0
  62. container="$1"
  63. wait_limit="$2"
  64. set +x
  65. while ! docker exec "$container" emqx_ctl status >/dev/null 2>&1; do
  66. wait_sec=$(( wait_sec + 1 ))
  67. if [ $wait_sec -gt "$wait_limit" ]; then
  68. echo "timeout wait for EMQX"
  69. exit 1
  70. fi
  71. echo -n '.'
  72. sleep 1
  73. done
  74. }
  75. wait_for_webhook() {
  76. wait_sec=0
  77. wait_limit="$1"
  78. set +x
  79. while ! curl -f -s localhost:7077; do
  80. wait_sec=$(( wait_sec + 1 ))
  81. if [ $wait_sec -gt "$wait_limit" ]; then
  82. echo "timeout wait for webhook"
  83. exit 1
  84. fi
  85. echo -n '.'
  86. sleep 1
  87. done
  88. }
  89. # wait for webhook http server to start,
  90. # it may take a while because it needs to compile from source code
  91. wait_for_webhook 120
  92. # after webhook start, it should not cost more than 30 seconds
  93. wait_for_emqx $NODE1 30
  94. # afer node1 is up, it should not cost more than 10 seconds
  95. wait_for_emqx $NODE2 10
  96. echo
  97. docker exec $NODE1 emqx_ctl cluster join "emqx@$NODE2"