Document how to get ssh access into CD testnets

This commit is contained in:
Michael Vines 2018-09-07 12:48:06 -07:00
parent b1b03ec13b
commit db825788fa
3 changed files with 27 additions and 5 deletions

View File

@ -56,3 +56,11 @@ ensure the `cuda` feature is specified at network start:
$ ./net.sh start -f "cuda,erasure" $ ./net.sh start -f "cuda,erasure"
``` ```
### How to interact with a CD testnet deployed by ci/testnet-deploy.sh
Taking **master-testnet-solana-com** as an example, configure your workspace for
the testnet using:
```
$ ./gce.sh config -p master-testnet-solana-com
$ ./ssh.sh # <-- Details on how to ssh into any testnet node
```

View File

@ -116,7 +116,16 @@ build() {
startCommon() { startCommon() {
declare ipAddress=$1 declare ipAddress=$1
test -d "$SOLANA_ROOT" test -d "$SOLANA_ROOT"
ssh "${sshOptions[@]}" "$ipAddress" "mkdir -p ~/solana ~/.cargo/bin" ssh "${sshOptions[@]}" "$ipAddress" "
mkdir -p ~/solana ~/.cargo/bin
# Help other users of the machine locate network logs
[[ -d /tmp/solana/ ]] || {
mkdir /tmp/solana/
chmod go+w /tmp/solana/
}
ln -sfT ~/solana /tmp/solana/=
"
rsync -vPrc -e "ssh ${sshOptions[*]}" \ rsync -vPrc -e "ssh ${sshOptions[*]}" \
"$SOLANA_ROOT"/{fetch-perf-libs.sh,scripts,net,multinode-demo} \ "$SOLANA_ROOT"/{fetch-perf-libs.sh,scripts,net,multinode-demo} \
"$ipAddress":~/solana/ "$ipAddress":~/solana/
@ -290,7 +299,7 @@ start() {
echo "Leader deployment took $leaderDeployTime seconds" echo "Leader deployment took $leaderDeployTime seconds"
echo "Validator deployment (${#validatorIpList[@]} instances) took $validatorDeployTime seconds" echo "Validator deployment (${#validatorIpList[@]} instances) took $validatorDeployTime seconds"
echo "Client deployment (${#clientIpList[@]} instances) took $clientDeployTime seconds" echo "Client deployment (${#clientIpList[@]} instances) took $clientDeployTime seconds"
echo "Logs in $netLogDir:" echo "Network start logs in $netLogDir:"
ls -l "$netLogDir" ls -l "$netLogDir"
} }

View File

@ -43,13 +43,18 @@ if [[ -n "$ipAddress" ]]; then
exec ssh "${sshOptions[@]}" "$ipAddress" "$@" exec ssh "${sshOptions[@]}" "$ipAddress" "$@"
fi fi
printNode() {
declare nodeType=$1
declare ip=$2
printf " %-25s | For logs run: $0 $ip tail -f /tmp/solana/=/$nodeType.log\n" "$0 $ip"
}
echo Leader: echo Leader:
echo -e " $0 $leaderIp\t| $0 $leaderIp tail -f solana/leader.log" printNode leader "$leaderIp"
echo echo
echo Validators: echo Validators:
for ipAddress in "${validatorIpList[@]}"; do for ipAddress in "${validatorIpList[@]}"; do
echo -e " $0 $ipAddress\t| $0 $ipAddress tail -f solana/validator.log" printNode validator "$ipAddress"
done done
echo echo
echo Clients: echo Clients:
@ -57,7 +62,7 @@ if [[ ${#clientIpList[@]} -eq 0 ]]; then
echo " None" echo " None"
else else
for ipAddress in "${clientIpList[@]}"; do for ipAddress in "${clientIpList[@]}"; do
echo -e " $0 $ipAddress\t| $0 $ipAddress tail -f solana/client.log" printNode client "$ipAddress"
done done
fi fi