Saya sering perlu ssh ke komputer sewenang-wenang dari cluster tertentu (semua mesin di cluster identik). Namun, set mesin yang tersedia di cluster sering berubah, jadi saya memiliki skrip yang mengembalikan nama host sewenang-wenang dari cluster yang tersedia dan cocok dengan persyaratan saya (mis. Online dan menjalankan OS yang benar).
Perhatikan juga, bahwa saya menggunakan penerusan kredensial Kerberos (GSSAPIAuthentication) untuk otentikasi.
Saat ini, saya ssh dalam menggunakan ssh `get_host`
. Saya ingin mengeksekusi ssh cluster
. Dengan nama host yang dikenal, ini mudah dengan yang berikut di /ssh/config
:
Host cluster
HostName static_host.cluster.domain.tld
GSSAPIAuthentication yes
GSSAPIDelegateCredentials yes
Bagaimana saya bisa memilih HostName
secara dinamis, menggunakan skrip saya? (Atau apakah SSH memiliki metode berbeda untuk mendukung fungsi yang saya inginkan?) Saya ingin melakukan sesuatu seperti yang berikut ini, tetapi tidak berhasil:
Host cluster
HostName `get_host` # This does not work
...
Grawity menunjukkan bahwa ProxyCommand
bisa berupa skrip yang mendapatkan nama host dan meneruskan ssh
koneksi ke sana menggunakan netcat
atau socat
. Namun, ini tidak meneruskan kredensial Kerberos. Bantuan dengan ini juga dihargai.
EDIT:
Anda tidak dapat melakukan ini dengan Kerberos seperti yang saya inginkan (lihat komentar dalam jawaban yang diterima). Jadi, saya menggunakan skrip ini ssh-wrapper
,, sebagai ssh
alias untuk melakukan penulisan ulang dinamis pada ssh
argumen baris perintah. Itu tidak kuat, tetapi itu bekerja untuk saya.
#!/bin/bash
# Mapping between host aliases and dynamically-generated hostname
declare -A MAP
MAP[cluster]=`gethost`
# Find and replace on all positional args
args=$*
for key in ${!MAP[@]}; do
replace=${MAP[$key]}
args=`echo ${args} | sed "s/\(^\|[[:space:]]\)${key}\(\$\|[[:space:]]\)/${replace}/"`
done
# Execute using called-name if not this script
if [ "ssh-wrapper" != "`basename $0`" ]; then
exec $0 ${args}
# Otherwise, assume ssh and execute
else
exec ssh ${args}
fi