2002-03-18 09:55:03 +00:00
|
|
|
.\" $OpenBSD: ssh-keyscan.1,v 1.14 2002/02/13 08:33:47 mpech Exp $
|
2001-05-04 03:57:05 +00:00
|
|
|
.\"
|
|
|
|
.\" Copyright 1995, 1996 by David Mazieres <dm@lcs.mit.edu>.
|
|
|
|
.\"
|
|
|
|
.\" Modification and redistribution in source and binary forms is
|
|
|
|
.\" permitted provided that due credit is given to the author and the
|
2002-03-18 09:55:03 +00:00
|
|
|
.\" OpenBSD project by leaving this copyright notice intact.
|
2001-05-04 03:57:05 +00:00
|
|
|
.\"
|
|
|
|
.Dd January 1, 1996
|
|
|
|
.Dt SSH-KEYSCAN 1
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm ssh-keyscan
|
|
|
|
.Nd gather ssh public keys
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Nm ssh-keyscan
|
2002-03-18 09:55:03 +00:00
|
|
|
.Op Fl v46
|
|
|
|
.Op Fl p Ar port
|
|
|
|
.Op Fl T Ar timeout
|
|
|
|
.Op Fl t Ar type
|
|
|
|
.Op Fl f Ar file
|
|
|
|
.Op Ar host | addrlist namelist
|
|
|
|
.Op Ar ...
|
2001-05-04 03:57:05 +00:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
.Nm
|
|
|
|
is a utility for gathering the public ssh host keys of a number of
|
|
|
|
hosts. It was designed to aid in building and verifying
|
|
|
|
.Pa ssh_known_hosts
|
|
|
|
files.
|
|
|
|
.Nm
|
|
|
|
provides a minimal interface suitable for use by shell and perl
|
|
|
|
scripts.
|
|
|
|
.Pp
|
|
|
|
.Nm
|
|
|
|
uses non-blocking socket I/O to contact as many hosts as possible in
|
|
|
|
parallel, so it is very efficient. The keys from a domain of 1,000
|
|
|
|
hosts can be collected in tens of seconds, even when some of those
|
2002-03-18 09:55:03 +00:00
|
|
|
hosts are down or do not run ssh. For scanning, one does not need
|
|
|
|
login access to the machines that are being scanned, nor does the
|
|
|
|
scanning process involve any encryption.
|
|
|
|
.Pp
|
|
|
|
The options are as follows:
|
2001-05-04 03:57:05 +00:00
|
|
|
.Bl -tag -width Ds
|
2002-03-18 09:55:03 +00:00
|
|
|
.It Fl p Ar port
|
|
|
|
Port to connect to on the remote host.
|
|
|
|
.It Fl T Ar timeout
|
|
|
|
Set the timeout for connection attempts. If
|
2001-05-04 03:57:05 +00:00
|
|
|
.Pa timeout
|
|
|
|
seconds have elapsed since a connection was initiated to a host or since the
|
|
|
|
last time anything was read from that host, then the connection is
|
|
|
|
closed and the host in question considered unavailable. Default is 5
|
|
|
|
seconds.
|
2002-03-18 09:55:03 +00:00
|
|
|
.It Fl t Ar type
|
|
|
|
Specifies the type of the key to fetch from the scanned hosts.
|
|
|
|
The possible values are
|
|
|
|
.Dq rsa1
|
|
|
|
for protocol version 1 and
|
|
|
|
.Dq rsa
|
|
|
|
or
|
|
|
|
.Dq dsa
|
|
|
|
for protocol version 2.
|
|
|
|
Multiple values may be specified by separating them with commas.
|
|
|
|
The default is
|
|
|
|
.Dq rsa1 .
|
|
|
|
.It Fl f Ar filename
|
|
|
|
Read hosts or
|
2001-05-04 03:57:05 +00:00
|
|
|
.Pa addrlist namelist
|
|
|
|
pairs from this file, one per line.
|
|
|
|
If
|
|
|
|
.Pa -
|
|
|
|
is supplied instead of a filename,
|
|
|
|
.Nm
|
2002-03-18 09:55:03 +00:00
|
|
|
will read hosts or
|
2001-05-04 03:57:05 +00:00
|
|
|
.Pa addrlist namelist
|
|
|
|
pairs from the standard input.
|
2002-03-18 09:55:03 +00:00
|
|
|
.It Fl v
|
|
|
|
Verbose mode.
|
|
|
|
Causes
|
|
|
|
.Nm
|
|
|
|
to print debugging messages about its progress.
|
|
|
|
.It Fl 4
|
|
|
|
Forces
|
|
|
|
.Nm
|
|
|
|
to use IPv4 addresses only.
|
|
|
|
.It Fl 6
|
|
|
|
Forces
|
|
|
|
.Nm
|
|
|
|
to use IPv6 addresses only.
|
2001-05-04 03:57:05 +00:00
|
|
|
.El
|
2002-03-18 09:55:03 +00:00
|
|
|
.Sh SECURITY
|
|
|
|
If a ssh_known_hosts file is constructed using
|
|
|
|
.Nm
|
|
|
|
without verifying the keys, users will be vulnerable to
|
|
|
|
.I man in the middle
|
|
|
|
attacks.
|
|
|
|
On the other hand, if the security model allows such a risk,
|
|
|
|
.Nm
|
|
|
|
can help in the detection of tampered keyfiles or man in the middle
|
|
|
|
attacks which have begun after the ssh_known_hosts file was created.
|
2001-05-04 03:57:05 +00:00
|
|
|
.Sh EXAMPLES
|
|
|
|
.Pp
|
2002-03-18 09:55:03 +00:00
|
|
|
Print the
|
|
|
|
.Pa rsa1
|
|
|
|
host key for machine
|
2001-05-04 03:57:05 +00:00
|
|
|
.Pa hostname :
|
|
|
|
.Bd -literal
|
2002-03-18 09:55:03 +00:00
|
|
|
$ ssh-keyscan hostname
|
2001-05-04 03:57:05 +00:00
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Find all hosts from the file
|
|
|
|
.Pa ssh_hosts
|
|
|
|
which have new or different keys from those in the sorted file
|
|
|
|
.Pa ssh_known_hosts :
|
|
|
|
.Bd -literal
|
2002-03-18 09:55:03 +00:00
|
|
|
$ ssh-keyscan -t rsa,dsa -f ssh_hosts | \e\
|
|
|
|
sort -u - ssh_known_hosts | diff ssh_known_hosts -
|
2001-05-04 03:57:05 +00:00
|
|
|
.Ed
|
|
|
|
.Sh FILES
|
|
|
|
.Pa Input format:
|
2002-03-18 09:55:03 +00:00
|
|
|
.Bd -literal
|
2001-05-04 03:57:05 +00:00
|
|
|
1.2.3.4,1.2.4.4 name.my.domain,name,n.my.domain,n,1.2.3.4,1.2.4.4
|
2002-03-18 09:55:03 +00:00
|
|
|
.Ed
|
2001-05-04 03:57:05 +00:00
|
|
|
.Pp
|
2002-03-18 09:55:03 +00:00
|
|
|
.Pa Output format for rsa1 keys:
|
|
|
|
.Bd -literal
|
2001-05-04 03:57:05 +00:00
|
|
|
host-or-namelist bits exponent modulus
|
2002-03-18 09:55:03 +00:00
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
.Pa Output format for rsa and dsa keys:
|
|
|
|
.Bd -literal
|
|
|
|
host-or-namelist keytype base64-encoded-key
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Where
|
|
|
|
.Pa keytype
|
|
|
|
is either
|
|
|
|
.Dq ssh-rsa
|
|
|
|
or
|
|
|
|
.Dq ssh-dsa .
|
2001-05-04 03:57:05 +00:00
|
|
|
.Pp
|
2002-03-18 09:55:03 +00:00
|
|
|
.Pa /etc/ssh/ssh_known_hosts
|
2001-05-04 03:57:05 +00:00
|
|
|
.Sh BUGS
|
|
|
|
It generates "Connection closed by remote host" messages on the consoles
|
2002-03-18 09:55:03 +00:00
|
|
|
of all the machines it scans if the server is older than version 2.9.
|
2001-05-04 03:57:05 +00:00
|
|
|
This is because it opens a connection to the ssh port, reads the public
|
|
|
|
key, and drops the connection as soon as it gets the key.
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr ssh 1 ,
|
|
|
|
.Xr sshd 8
|
2002-03-18 09:55:03 +00:00
|
|
|
.Sh AUTHORS
|
2001-05-04 03:57:05 +00:00
|
|
|
David Mazieres <dm@lcs.mit.edu>
|
2002-03-18 09:55:03 +00:00
|
|
|
wrote the initial version, and
|
|
|
|
Wayne Davison <wayned@users.sourceforge.net>
|
|
|
|
added support for protocol version 2.
|