382 lines
12 KiB
Bash
Executable File
382 lines
12 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
usage() {
|
|
cat <<'EOF'
|
|
Usage:
|
|
./scripts/compare/run_perf_compare_quick_remote.sh \
|
|
--run-root <path> \
|
|
--remote-root <path> \
|
|
[--rir-set <mixed2|all5>] \
|
|
[--ssh-target <user@host>] \
|
|
[--rpki-client-bin <path>] \
|
|
[--libtls-path <path>] \
|
|
[--rp-run-mode <serial|parallel>] \
|
|
[--ours-extra-args '<args>'] \
|
|
[--dry-run]
|
|
EOF
|
|
}
|
|
|
|
ROOT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd)"
|
|
RUN_ROOT=""
|
|
REMOTE_ROOT=""
|
|
SSH_TARGET="${SSH_TARGET:-root@47.251.56.108}"
|
|
RPKI_CLIENT_BIN="${RPKI_CLIENT_BIN:-/home/yuyr/dev/rpki-client-9.7/build-m5/src/rpki-client}"
|
|
LIBTLS_PATH="${LIBTLS_PATH:-/home/yuyr/dev/rpki-client-9.7/.deps/libtls/root/usr/lib/x86_64-linux-gnu/libtls.so.28.0.0}"
|
|
RP_RUN_MODE="${RP_RUN_MODE:-serial}"
|
|
RIR_SET="${RIR_SET:-mixed2}"
|
|
OURS_EXTRA_ARGS="${OURS_EXTRA_ARGS:-}"
|
|
DRY_RUN=0
|
|
|
|
while [[ $# -gt 0 ]]; do
|
|
case "$1" in
|
|
--run-root) RUN_ROOT="$2"; shift 2 ;;
|
|
--remote-root) REMOTE_ROOT="$2"; shift 2 ;;
|
|
--rir-set) RIR_SET="$2"; shift 2 ;;
|
|
--ssh-target) SSH_TARGET="$2"; shift 2 ;;
|
|
--rpki-client-bin) RPKI_CLIENT_BIN="$2"; shift 2 ;;
|
|
--libtls-path) LIBTLS_PATH="$2"; shift 2 ;;
|
|
--rp-run-mode) RP_RUN_MODE="$2"; shift 2 ;;
|
|
--ours-extra-args) OURS_EXTRA_ARGS="$2"; shift 2 ;;
|
|
--dry-run) DRY_RUN=1; shift ;;
|
|
-h|--help) usage; exit 0 ;;
|
|
*) echo "unknown argument: $1" >&2; usage; exit 2 ;;
|
|
esac
|
|
done
|
|
|
|
[[ -n "$RUN_ROOT" && -n "$REMOTE_ROOT" ]] || { usage >&2; exit 2; }
|
|
[[ "$RP_RUN_MODE" == "serial" || "$RP_RUN_MODE" == "parallel" ]] || { echo "invalid --rp-run-mode: $RP_RUN_MODE" >&2; usage; exit 2; }
|
|
[[ "$RIR_SET" == "mixed2" || "$RIR_SET" == "all5" ]] || { echo "invalid --rir-set: $RIR_SET" >&2; usage; exit 2; }
|
|
[[ "$DRY_RUN" -eq 1 || -x "$RPKI_CLIENT_BIN" ]] || { echo "rpki-client binary not executable: $RPKI_CLIENT_BIN" >&2; exit 2; }
|
|
[[ "$DRY_RUN" -eq 1 || -f "$LIBTLS_PATH" ]] || { echo "libtls not found: $LIBTLS_PATH" >&2; exit 2; }
|
|
|
|
RUN_ROOT="$(python3 - <<'PY' "$RUN_ROOT"
|
|
from pathlib import Path
|
|
import sys
|
|
print(Path(sys.argv[1]).resolve())
|
|
PY
|
|
)"
|
|
|
|
mkdir -p "$RUN_ROOT/steps/step-001/ours" "$RUN_ROOT/steps/step-001/rpki-client" "$RUN_ROOT/steps/step-001/compare"
|
|
mkdir -p "$RUN_ROOT/steps/step-002/ours" "$RUN_ROOT/steps/step-002/rpki-client" "$RUN_ROOT/steps/step-002/compare"
|
|
|
|
tal_path_for_rir() {
|
|
case "$1" in
|
|
afrinic) printf '%s' "$ROOT_DIR/tests/fixtures/tal/afrinic.tal" ;;
|
|
apnic) printf '%s' "$ROOT_DIR/tests/fixtures/tal/apnic-rfc7730-https.tal" ;;
|
|
arin) printf '%s' "$ROOT_DIR/tests/fixtures/tal/arin.tal" ;;
|
|
lacnic) printf '%s' "$ROOT_DIR/tests/fixtures/tal/lacnic.tal" ;;
|
|
ripe) printf '%s' "$ROOT_DIR/tests/fixtures/tal/ripe-ncc.tal" ;;
|
|
*) echo "unknown rir: $1" >&2; exit 2 ;;
|
|
esac
|
|
}
|
|
|
|
ta_path_for_rir() {
|
|
case "$1" in
|
|
afrinic) printf '%s' "$ROOT_DIR/tests/fixtures/ta/afrinic-ta.cer" ;;
|
|
apnic) printf '%s' "$ROOT_DIR/tests/fixtures/ta/apnic-ta.cer" ;;
|
|
arin) printf '%s' "$ROOT_DIR/tests/fixtures/ta/arin-ta.cer" ;;
|
|
lacnic) printf '%s' "$ROOT_DIR/tests/fixtures/ta/lacnic-ta.cer" ;;
|
|
ripe) printf '%s' "$ROOT_DIR/tests/fixtures/ta/ripe-ncc-ta.cer" ;;
|
|
*) echo "unknown rir: $1" >&2; exit 2 ;;
|
|
esac
|
|
}
|
|
|
|
case "$RIR_SET" in
|
|
mixed2)
|
|
RIRS=(apnic arin)
|
|
SCOPE_LABEL="APNIC+ARIN mixed release two-step synchronized compare"
|
|
;;
|
|
all5)
|
|
RIRS=(afrinic apnic arin lacnic ripe)
|
|
SCOPE_LABEL="all-five-RIR mixed release two-step synchronized compare"
|
|
;;
|
|
esac
|
|
|
|
COPY_FILES=()
|
|
for rir in "${RIRS[@]}"; do
|
|
COPY_FILES+=("$(tal_path_for_rir "$rir")" "$(ta_path_for_rir "$rir")")
|
|
done
|
|
|
|
if [[ "$DRY_RUN" -eq 1 ]]; then
|
|
cat <<EOF2
|
|
workflow_name=性能对比测试快速版
|
|
scope=$SCOPE_LABEL
|
|
rir_set=$RIR_SET
|
|
rirs=${RIRS[*]}
|
|
run_root=$RUN_ROOT
|
|
remote_root=$REMOTE_ROOT
|
|
ssh_target=$SSH_TARGET
|
|
rp_run_mode=$RP_RUN_MODE
|
|
ours_extra_args=$OURS_EXTRA_ARGS
|
|
EOF2
|
|
exit 0
|
|
fi
|
|
|
|
cleanup_remote() {
|
|
if [[ "${KEEP_REMOTE:-0}" != "1" ]]; then
|
|
ssh "$SSH_TARGET" "rm -rf '$REMOTE_ROOT'" >/dev/null 2>&1 || true
|
|
fi
|
|
}
|
|
trap cleanup_remote EXIT
|
|
|
|
(
|
|
cd "$ROOT_DIR"
|
|
cargo build --release --bin rpki --bin ccr_to_compare_views
|
|
)
|
|
|
|
ssh "$SSH_TARGET" "set -e; id -u _rpki-client >/dev/null 2>&1 || useradd -r -M -s /usr/sbin/nologin _rpki-client || true; rm -rf '$REMOTE_ROOT'; mkdir -p '$REMOTE_ROOT/bin' '$REMOTE_ROOT/lib' '$REMOTE_ROOT/state/ours' '$REMOTE_ROOT/state/rpki-client' '$REMOTE_ROOT/steps/step-001/ours' '$REMOTE_ROOT/steps/step-001/rpki-client' '$REMOTE_ROOT/steps/step-002/ours' '$REMOTE_ROOT/steps/step-002/rpki-client'"
|
|
scp "$ROOT_DIR/target/release/rpki" "${COPY_FILES[@]}" "$SSH_TARGET:$REMOTE_ROOT/"
|
|
scp "$RPKI_CLIENT_BIN" "$SSH_TARGET:$REMOTE_ROOT/bin/rpki-client"
|
|
scp "$LIBTLS_PATH" "$SSH_TARGET:$REMOTE_ROOT/lib/libtls.so.28"
|
|
printf '%s' "$OURS_EXTRA_ARGS" | ssh "$SSH_TARGET" "cat > '$REMOTE_ROOT/ours-extra-args.txt'"
|
|
printf '%s' "$RP_RUN_MODE" | ssh "$SSH_TARGET" "cat > '$REMOTE_ROOT/rp-run-mode.txt'"
|
|
printf '%s' "$RIR_SET" | ssh "$SSH_TARGET" "cat > '$REMOTE_ROOT/rir-set.txt'"
|
|
|
|
run_step() {
|
|
local step_id="$1"
|
|
local kind="$2"
|
|
local local_step="$RUN_ROOT/steps/$step_id"
|
|
|
|
ssh "$SSH_TARGET" bash -s -- "$REMOTE_ROOT" "$step_id" "$kind" <<'EOS'
|
|
set -euo pipefail
|
|
REMOTE_ROOT="$1"
|
|
STEP_ID="$2"
|
|
KIND="$3"
|
|
|
|
cd "$REMOTE_ROOT"
|
|
mkdir -p "steps/$STEP_ID/ours" "steps/$STEP_ID/rpki-client"
|
|
OURS_EXTRA_ARGS="$(cat ours-extra-args.txt)"
|
|
RP_RUN_MODE="$(cat rp-run-mode.txt)"
|
|
RIR_SET="$(cat rir-set.txt)"
|
|
OURS_EXTRA_ARGV=()
|
|
if [[ -n "$OURS_EXTRA_ARGS" ]]; then
|
|
# shellcheck disable=SC2206
|
|
OURS_EXTRA_ARGV=($OURS_EXTRA_ARGS)
|
|
fi
|
|
|
|
case "$RIR_SET" in
|
|
mixed2) RIRS=(apnic arin) ;;
|
|
all5) RIRS=(afrinic apnic arin lacnic ripe) ;;
|
|
*) echo "invalid rir set: $RIR_SET" >&2; exit 2 ;;
|
|
esac
|
|
|
|
tal_file_for_rir() {
|
|
case "$1" in
|
|
afrinic) printf '%s' "afrinic.tal" ;;
|
|
apnic) printf '%s' "apnic-rfc7730-https.tal" ;;
|
|
arin) printf '%s' "arin.tal" ;;
|
|
lacnic) printf '%s' "lacnic.tal" ;;
|
|
ripe) printf '%s' "ripe-ncc.tal" ;;
|
|
*) echo "unknown rir: $1" >&2; exit 2 ;;
|
|
esac
|
|
}
|
|
|
|
ta_file_for_rir() {
|
|
case "$1" in
|
|
afrinic) printf '%s' "afrinic-ta.cer" ;;
|
|
apnic) printf '%s' "apnic-ta.cer" ;;
|
|
arin) printf '%s' "arin-ta.cer" ;;
|
|
lacnic) printf '%s' "lacnic-ta.cer" ;;
|
|
ripe) printf '%s' "ripe-ncc-ta.cer" ;;
|
|
*) echo "unknown rir: $1" >&2; exit 2 ;;
|
|
esac
|
|
}
|
|
|
|
OURS_TAL_ARGS=()
|
|
CLIENT_TAL_ARGS=()
|
|
for rir in "${RIRS[@]}"; do
|
|
tal_file="$(tal_file_for_rir "$rir")"
|
|
ta_file="$(ta_file_for_rir "$rir")"
|
|
OURS_TAL_ARGS+=(--tal-path "$tal_file" --ta-path "$ta_file")
|
|
CLIENT_TAL_ARGS+=(-t "../../$tal_file")
|
|
done
|
|
|
|
if [[ "$KIND" == "snapshot" ]]; then
|
|
rm -rf state/ours/work-db state/ours/raw-store.db state/rpki-client/cache state/rpki-client/out state/rpki-client/ta state/rpki-client/.ta
|
|
fi
|
|
mkdir -p state/ours/work-db state/ours/raw-store.db state/rpki-client/cache state/rpki-client/out state/rpki-client/ta state/rpki-client/.ta
|
|
chmod 0777 state/ours/work-db state/ours/raw-store.db
|
|
chmod -R 0777 state/rpki-client
|
|
|
|
START_EPOCH="$(python3 - <<'PY'
|
|
import time
|
|
print(time.time() + 3.0)
|
|
PY
|
|
)"
|
|
|
|
run_ours() {
|
|
python3 - <<'PY' "$START_EPOCH"
|
|
import sys, time
|
|
x = float(sys.argv[1])
|
|
d = x - time.time()
|
|
if d > 0:
|
|
time.sleep(d)
|
|
PY
|
|
started_ms="$(python3 - <<'PY'
|
|
import time
|
|
print(int(time.time() * 1000))
|
|
PY
|
|
)"
|
|
set +e
|
|
env RPKI_PROGRESS_LOG=1 RPKI_PROGRESS_SLOW_SECS=0 ./rpki \
|
|
--db state/ours/work-db \
|
|
--raw-store-db state/ours/raw-store.db \
|
|
"${OURS_TAL_ARGS[@]}" \
|
|
--parallel-phase1 \
|
|
"${OURS_EXTRA_ARGV[@]}" \
|
|
--ccr-out "steps/$STEP_ID/ours/result.ccr" \
|
|
--report-json "steps/$STEP_ID/ours/report.json" \
|
|
> "steps/$STEP_ID/ours/run.log" 2>&1
|
|
exit_code=$?
|
|
set -e
|
|
finished_ms="$(python3 - <<'PY'
|
|
import time
|
|
print(int(time.time() * 1000))
|
|
PY
|
|
)"
|
|
python3 - <<'PY' "steps/$STEP_ID/ours/round-result.json" "$STEP_ID" "$KIND" "$started_ms" "$finished_ms" "$exit_code"
|
|
import json, sys
|
|
path, step_id, kind, started_ms, finished_ms, exit_code = sys.argv[1:]
|
|
json.dump(
|
|
{
|
|
"stepId": step_id,
|
|
"kind": kind,
|
|
"durationMs": int(finished_ms) - int(started_ms),
|
|
"exitCode": int(exit_code),
|
|
},
|
|
open(path, "w"),
|
|
indent=2,
|
|
)
|
|
PY
|
|
}
|
|
|
|
run_client() {
|
|
cd state/rpki-client
|
|
python3 - <<'PY' "$START_EPOCH"
|
|
import sys, time
|
|
x = float(sys.argv[1])
|
|
d = x - time.time()
|
|
if d > 0:
|
|
time.sleep(d)
|
|
PY
|
|
started_ms="$(python3 - <<'PY'
|
|
import time
|
|
print(int(time.time() * 1000))
|
|
PY
|
|
)"
|
|
set +e
|
|
LD_LIBRARY_PATH="$REMOTE_ROOT/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}" "$REMOTE_ROOT/bin/rpki-client" \
|
|
-vv \
|
|
"${CLIENT_TAL_ARGS[@]}" \
|
|
-d cache out \
|
|
> "$REMOTE_ROOT/steps/$STEP_ID/rpki-client/run.log" 2>&1
|
|
exit_code=$?
|
|
set -e
|
|
cp out/rpki.ccr "$REMOTE_ROOT/steps/$STEP_ID/rpki-client/result.ccr" 2>/dev/null || true
|
|
cp out/openbgpd "$REMOTE_ROOT/steps/$STEP_ID/rpki-client/openbgpd" 2>/dev/null || true
|
|
finished_ms="$(python3 - <<'PY'
|
|
import time
|
|
print(int(time.time() * 1000))
|
|
PY
|
|
)"
|
|
python3 - <<'PY' "$REMOTE_ROOT/steps/$STEP_ID/rpki-client/round-result.json" "$STEP_ID" "$KIND" "$started_ms" "$finished_ms" "$exit_code"
|
|
import json, sys
|
|
path, step_id, kind, started_ms, finished_ms, exit_code = sys.argv[1:]
|
|
json.dump(
|
|
{
|
|
"stepId": step_id,
|
|
"kind": kind,
|
|
"durationMs": int(finished_ms) - int(started_ms),
|
|
"exitCode": int(exit_code),
|
|
},
|
|
open(path, "w"),
|
|
indent=2,
|
|
)
|
|
PY
|
|
}
|
|
|
|
if [[ "$RP_RUN_MODE" == "parallel" ]]; then
|
|
run_ours &
|
|
OURS_PID=$!
|
|
run_client &
|
|
CLIENT_PID=$!
|
|
wait "$OURS_PID"
|
|
wait "$CLIENT_PID"
|
|
else
|
|
run_ours
|
|
run_client
|
|
fi
|
|
EOS
|
|
|
|
for rel in result.ccr round-result.json run.log stage-timing.json; do
|
|
scp -C "$SSH_TARGET:$REMOTE_ROOT/steps/$step_id/ours/$rel" "$local_step/ours/"
|
|
done
|
|
for rel in result.ccr round-result.json run.log openbgpd; do
|
|
scp -C "$SSH_TARGET:$REMOTE_ROOT/steps/$step_id/rpki-client/$rel" "$local_step/rpki-client/" || true
|
|
done
|
|
|
|
"$ROOT_DIR/scripts/periodic/compare_ccr_round.sh" \
|
|
--ours-ccr "$local_step/ours/result.ccr" \
|
|
--rpki-client-ccr "$local_step/rpki-client/result.ccr" \
|
|
--out-dir "$local_step/compare" \
|
|
--trust-anchor unknown >/dev/null
|
|
|
|
python3 - <<'PY' "$local_step/ours/round-result.json" "$local_step/rpki-client/round-result.json" "$local_step/ours/stage-timing.json" "$local_step/compare/compare-summary.json" "$local_step/step-summary.json" "$OURS_EXTRA_ARGS"
|
|
import json, sys
|
|
ours = json.load(open(sys.argv[1]))
|
|
client = json.load(open(sys.argv[2]))
|
|
stage = json.load(open(sys.argv[3]))
|
|
compare = json.load(open(sys.argv[4]))
|
|
ours_extra_args = sys.argv[6]
|
|
json.dump(
|
|
{
|
|
"stepId": ours["stepId"],
|
|
"kind": ours["kind"],
|
|
"oursExtraArgs": ours_extra_args,
|
|
"oursDurationMs": ours["durationMs"],
|
|
"rpkiClientDurationMs": client["durationMs"],
|
|
"oursExitCode": ours["exitCode"],
|
|
"rpkiClientExitCode": client["exitCode"],
|
|
"oursTotalMs": stage["total_ms"],
|
|
"oursRepoSyncMsTotal": stage["repo_sync_ms_total"],
|
|
"oursPublicationPointRepoSyncMsTotal": stage.get("publication_point_repo_sync_ms_total"),
|
|
"oursDownloadEventCount": stage.get("download_event_count"),
|
|
"oursRrdpDownloadMsTotal": stage.get("rrdp_download_ms_total"),
|
|
"oursRsyncDownloadMsTotal": stage.get("rsync_download_ms_total"),
|
|
"oursDownloadBytesTotal": stage.get("download_bytes_total"),
|
|
"oursVrps": compare["vrps"]["ours"],
|
|
"rpkiClientVrps": compare["vrps"]["rpkiClient"],
|
|
"oursVaps": compare["vaps"]["ours"],
|
|
"rpkiClientVaps": compare["vaps"]["rpkiClient"],
|
|
"vrpMatch": compare["vrps"]["match"],
|
|
"vapMatch": compare["vaps"]["match"],
|
|
"allMatch": compare["allMatch"],
|
|
"onlyInOurs": len(compare["vrps"]["onlyInOurs"]),
|
|
"onlyInRpkiClient": len(compare["vrps"]["onlyInRpkiClient"]),
|
|
},
|
|
open(sys.argv[5], "w"),
|
|
indent=2,
|
|
)
|
|
PY
|
|
}
|
|
|
|
run_step step-001 snapshot
|
|
run_step step-002 delta
|
|
|
|
python3 - <<'PY' "$RUN_ROOT/steps/step-001/step-summary.json" "$RUN_ROOT/steps/step-002/step-summary.json" "$RUN_ROOT/summary.json" "$RP_RUN_MODE" "$OURS_EXTRA_ARGS" "$RIR_SET" "$SCOPE_LABEL" "${RIRS[@]}"
|
|
import json, sys
|
|
steps = [json.load(open(p)) for p in sys.argv[1:3]]
|
|
summary = {
|
|
"workflowName": "性能对比测试快速版",
|
|
"scope": sys.argv[7],
|
|
"rpRunMode": sys.argv[4],
|
|
"oursExtraArgs": sys.argv[5],
|
|
"rirSet": sys.argv[6],
|
|
"rirs": sys.argv[8:],
|
|
"steps": steps,
|
|
}
|
|
json.dump(summary, open(sys.argv[3], "w"), indent=2, ensure_ascii=False)
|
|
print(json.dumps(summary, indent=2, ensure_ascii=False))
|
|
PY
|