Jawaban:
Jika Anda menggunakan -v
opsi untuk ssh
itu akan menunjukkan kepada Anda apa yang Anda teruskan (tetapi juga akan menunjukkan kepada Anda banyak pesan debug lainnya):
ssh -v -L2222:localhost:22 remotehost
Akan menunjukkan kepada Anda:
...debug messages...
debug1: Authentication succeeded (publickey).
Authenticated to remotehost ([10.0.0.23]:22).
debug1: Local connections to LOCALHOST:2222 forwarded to remote address localhost:22
debug1: Local forwarding listening on ::1 port 2222.
debug1: channel 0: new [port listener]
debug1: Local forwarding listening on 127.0.0.1 port 2222.
...debug messages...
Dan kemudian ketika Anda terhubung ke shell jauh itu, Anda dapat mengetik urutan tombol khusus:
~#
yang akan mencantumkan koneksi seperti ini:
The following connections are open:
#3 client-session (t4 r0 i0/0 o0/0 fd 7/8 cc -1)
#4 direct-tcpip: listening port 2222 for localhost port 22, connect from 127.0.0.1 port 59742 (t4 r1 i0/0 o0/0 fd 10/10 cc -1)
Perhatikan, bagaimanapun, bahwa ini hanya akan mencantumkan port yang diteruskan yang sebenarnya sedang digunakan oleh program lain (dalam hal ini saya baru saja melakukannya telnet localhost 2222
pada komputer lokal saya untuk meneruskannya remotehost
.
Jika Anda tidak memiliki koneksi apa pun yang sedang diteruskan, Anda masih dapat melihat perintah ssh Anda mendengarkan secara lokal dengan menggunakan netstat
perintah seperti ini:
% netstat -tpln
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 127.0.0.1:2222 0.0.0.0:* LISTEN 28995/ssh
tcp6 0 0 ::1:2222 :::* LISTEN 28995/ssh
The netstat
perintah juga akan mungkin daftar hal-hal lain, tapi apa yang ingin Anda cari dalam output adalah PID/Program
kolom untuk mencari ssh
proses, dan Local Address
kolom yang akan menunjukkan apa port sedang mendengarkan. Dalam contoh ini sedang mendengarkan port 2222
untuk antarmuka IPv4 dan IPv6 pada komputer saya.
netstat
telah usang mendukung ss
.