关于ssh设置的相关总结(ssh最⼤连接数、ssh连接时长、安全
性配置等)
以redhat6.3为例
ssh配置⽂件在:
/etc//sshd_config
可以打开查看相应配置,默认情况下只开放了⼏个选项,其余全部#屏蔽掉了。
国内有⼈已经翻译了:(直接贴过来了)
sshd_config 中⽂⼿册
SSHD_CONFIG(5) OpenBSD Programmer's Manual SSHD_CONFIG(5)
sshd_config - OpenSSH SSH 服务器守护进程配置⽂件
/etc/ssh/sshd_config
默认从/etc/ssh/sshd_config⽂件(或通过 -f 命令⾏选项指定的⽂件)读取配置信息。
配置⽂件是由"指令值"对组成的,每⾏⼀个。空⾏和以'#'开头的⾏都将被忽略。
如果值中含有空⽩符或者其他特殊符号,那么可以通过在两边加上双引号(")进⾏界定。
[注意]值是⼤⼩写敏感的,但指令是⼤⼩写⽆关的。
当前所有可以使⽤的配置指令如下:
AcceptEnv
指定客户端发送的哪些环境变量将会被传递到会话环境中。[注意]只有SSH-2协议⽀持环境变量的传递。
细节可以参考中的 SendEnv 配置指令。
指令的值是空格分隔的变量名列表(其中可以使⽤'*'和'?'作为通配符)。也可以使⽤多个 AcceptEnv 达到同样的⽬的。
需要注意的是,有些环境变量可能会被⽤于绕过禁⽌⽤户使⽤的环境变量。由于这个原因,该指令应
当⼩⼼使⽤。
默认是不传递任何环境变量。
AddressFamily
指定应当使⽤哪种地址族。取值范围是:"any"(默认)、"inet"(仅IPv4)、"inet6"(仅IPv6)。
AllowGroups
这个指令后⾯跟着⼀串⽤空格分隔的组名列表(其中可以使⽤"*"和"?"通配符)。默认允许所有组登录。
如果使⽤了这个指令,那么将仅允许这些组中的成员登录,⽽拒绝其它所有组。
这⾥的"组"是指"主组"(primary group),也就是/etc/passwd⽂件中指定的组。
这⾥只允许使⽤组的名字⽽不允许使⽤GID。相关的 allow/deny 指令按照下列顺序处理:
DenyUrs, AllowUrs, DenyGroups, AllowGroups
AllowTcpForwarding
是否允许TCP转发,默认值为"yes"。
禁⽌TCP转发并不能增强安全性,除⾮禁⽌了⽤户对shell的访问,因为⽤户可以安装他们⾃⼰的转发器。
AllowUrs
这个指令后⾯跟着⼀串⽤空格分隔的⽤户名列表(其中可以使⽤"*"和"?"通配符)。默认允许所有⽤户登录。
如果使⽤了这个指令,那么将仅允许这些⽤户登录,⽽拒绝其它所有⽤户。
如果指定了 USER@HOST 模式的⽤户,那么 USER 和 HOST 将同时被检查。
这⾥只允许使⽤⽤户的名字⽽不允许使⽤UID。相关的 allow/deny 指令按照下列顺序处理:
DenyUrs, AllowUrs, DenyGroups, AllowGroups
AuthorizedKeysFile
存放该⽤户可以⽤来登录的 RSA/DSA 公钥。
该指令中可以使⽤下列根据连接时的实际情况进⾏展开的符号:
%% 表⽰'%'、%h 表⽰⽤户的主⽬录、%u 表⽰该⽤户的⽤户名。
经过扩展之后的值必须要么是绝对路径,要么是相对于⽤户主⽬录的相对路径。
默认值是".ssh/authorized_keys"。
Banner
将这个指令指定的⽂件中的内容在⽤户进⾏认证前显⽰给远程⽤户。
这个特性仅能⽤于SSH-2,默认什么内容也不显⽰。"none"表⽰禁⽤这个特性。
ChallengeResponAuthentication
是否允许质疑-应答(challenge-respon)认证。默认值是"yes"。
所有中允许的认证⽅式都被⽀持。
Ciphers
指定SSH-2允许使⽤的加密算法。多个算法之间使⽤逗号分隔。可以使⽤的算法如下:
"aes128-cbc", "aes192-cbc", "aes256-cbc", "aes128-ctr", "aes192-ctr", "aes256-ctr",
"3des-cbc", "arcfour128", "arcfour256", "arcfour", "blowfish-cbc", "cast128-cbc"
默认值是可以使⽤上述所有算法。
ClientAliveCountMax
在未收到任何客户端回应前最多允许发送多少个"alive"消息。默认值是 3 。
到达这个上限后,将强制断开连接、关闭会话。
需要注意的是,"alive"消息与 TCPKeepAlive 有很⼤差异。
"alive"消息是通过加密连接发送的,因此不会被欺骗;⽽ TCPKeepAlive 却是可以被欺骗的。
如果 ClientAliveInterval 被设为 15 并且将 ClientAliveCountMax 保持为默认值,
那么⽆应答的客户端⼤约会在45秒后被强制断开。这个指令仅可以⽤于SSH-2协议。
ClientAliveInterval
设置⼀个以秒记的时长,如果超过这么长时间没有收到客户端的任何数据,
将通过安全通道向客户端发送⼀个"alive"消息,并等候应答。
默认值 0 表⽰不发送"alive"消息。这个选项仅对SSH-2有效。
Compression
是否对通信数据进⾏加密,还是延迟到认证成功之后再对通信数据加密。
可⽤值:"yes", "delayed"(默认), "no"。
DenyGroups
这个指令后⾯跟着⼀串⽤空格分隔的组名列表(其中可以使⽤"*"和"?"通配符)。默认允许所有组登录。
如果使⽤了这个指令,那么这些组中的成员将被拒绝登录。
这⾥的"组"是指"主组"(primary group),也就是/etc/passwd⽂件中指定的组。
这⾥只允许使⽤组的名字⽽不允许使⽤GID。相关的 allow/deny 指令按照下列顺序处理:
DenyUrs, AllowUrs, DenyGroups, AllowGroups
DenyUrs
这个指令后⾯跟着⼀串⽤空格分隔的⽤户名列表(其中可以使⽤"*"和"?"通配符)。默认允许所有⽤户登录。
如果使⽤了这个指令,那么这些⽤户将被拒绝登录。
如果指定了 USER@HOST 模式的⽤户,那么 USER 和 HOST 将同时被检查。
这⾥只允许使⽤⽤户的名字⽽不允许使⽤UID。相关的 allow/deny 指令按照下列顺序处理:
DenyUrs, AllowUrs, DenyGroups, AllowGroups
ForceCommand
强制执⾏这⾥指定的命令⽽忽略客户端提供的任何命令。这个命令将使⽤⽤户的登录shell执⾏(shell -c)。
这可以应⽤于 shell 、命令、⼦系统的完成,通常⽤于 Match 块中。
这个命令最初是在客户端通过 SSH_ORIGINAL_COMMAND 环境变量来⽀持的。
GatewayPorts
是否允许远程主机连接本地的转发端⼝。默认值是"no"。i e
默认将远程端⼝转发绑定到loopback地址。这样将阻⽌其它远程主机连接到转发端⼝。
GatewayPorts 指令可以让 sshd 将远程端⼝转发绑定到⾮loopback地址,这样就可以允许远程主机连接了。
"no"表⽰仅允许本地连接,"yes"表⽰强制将远程端⼝转发绑定到统配地址(wildcard address),
"clientspecified"表⽰允许客户端选择将远程端⼝转发绑定到哪个地址。
GSSAPIAuthentication
是否允许使⽤基于 GSSAPI 的⽤户认证。默认值为"no"。仅⽤于SSH-2。
GSSAPICleanupCredentials
是否在⽤户退出登录后⾃动销毁⽤户凭证缓存。默认值是"yes"。仅⽤于SSH-2。
HostbadAuthentication
这个指令与 RhostsRSAAuthentication 类似,但是仅可以⽤于SSH-2。推荐使⽤默认值"no"。
推荐使⽤默认值"no"禁⽌这种不安全的认证⽅式。
HostbadUsNameFromPacketOnly
在开启 HostbadAuthentication 的情况下,
指定服务器在使⽤~/.shosts~/.rhosts/etc/hosts.equiv进⾏远程主机名匹配时,是否进⾏反向域名查询。
"yes"表⽰信任客户端提供的主机名⽽不进⾏反向查询。默认值是"no"。
HostKey
主机私钥⽂件的位置。如果权限不对,可能会拒绝启动。
SSH-1默认是/etc/ssh/ssh_host_key。
SSH-2默认是/etc/ssh/ssh_host_rsa_key和/etc/ssh/ssh_host_dsa_key。
⼀台主机可以拥有多个不同的私钥。"rsa1"仅⽤于SSH-1,"dsa"和"rsa"仅⽤于SSH-2。
IgnoreRhosts
是否在 RhostsRSAAuthentication 或 HostbadAuthentication 过程中忽略.rhosts和.shosts⽂件。
不过/etc/hosts.equiv和/etc/shosts.equiv仍将被使⽤。推荐设为默认值"yes"。
IgnoreUrKnownHosts
是否在 RhostsRSAAuthentication 或 HostbadAuthentication 过程中忽略⽤户的~/.ssh/known_hosts⽂件。
默认值是"no"。为了提⾼安全性,可以设为"yes"。
KerberosAuthentication
是否要求⽤户为 PasswordAuthentication 提供的密码必须通过 Kerberos KDC 认证,也就是是否使⽤Kerberos认证。
要使⽤Kerberos认证,服务器需要⼀个可以校验 KDC identity 的 Kerberos rvtab 。默认值是"no"。
KerberosGetAFSToken
如果使⽤了 AFS 并且该⽤户有⼀个 Kerberos 5 TGT,那么开启该指令后,
将会在访问⽤户的家⽬录前尝试获取⼀个 AFS token 。默认为"no"。
KerberosOrLocalPasswd
my favourite food如果 Kerberos 密码认证失败,那么该密码还将要通过其它的认证机制(⽐如/etc/passwd)。
默认值为"yes"。
KerberosTicketCleanup
是否在⽤户退出登录后⾃动销毁⽤户的 ticket 。默认值是"yes"。
KeyRegenerationInterval
在SSH-1协议下,短命的服务器密钥将以此指令设置的时间为周期(秒),不断重新⽣成。
这个机制可以尽量减⼩密钥丢失或者⿊客攻击造成的损失。
设为 0 表⽰永不重新⽣成,默认为 3600(秒)。
ListenAddress
指定监听的⽹络地址,默认监听所有地址。可以使⽤下⾯的格式:
ListenAddress host|IPv4_addr|IPv6_addr
ListenAddress host|IPv4_addr:port
ListenAddress [host|IPv6_addr]:port
如果未指定port,那么将使⽤ Port 指令的值。
可以使⽤多个 ListenAddress 指令监听多个地址。
LoginGraceTime
限制⽤户必须在指定的时限内认证成功,0 表⽰⽆限制。默认值是 120 秒。
LogLevel
指定的⽇志等级(详细程度)。可⽤值如下:
QUIET, FATAL, ERROR, INFO(默认), VERBOSE, DEBUG, DEBUG1, DEBUG2, DEBUG3
DEBUG 与 DEBUG1 等价;DEBUG2 和 DEBUG3 则分别指定了更详细、更罗嗦的⽇志输出。
⽐ DEBUG 更详细的⽇志可能会泄漏⽤户的敏感信息,因此反对使⽤。
MACs
指定允许在SSH-2中使⽤哪些消息摘要算法来进⾏数据校验。
可以使⽤逗号分隔的列表来指定允许使⽤多个算法。默认值(包含所有可以使⽤的算法)是:
hmac-md5,hmac-sha1,,hmac-ripemd160,hmac-sha1-96,hmac-md5-96
Match
引⼊⼀个条件块。块的结尾标志是另⼀个 Match 指令或者⽂件结尾。
如果 Match ⾏上指定的条件都满⾜,那么随后的指令将覆盖全局配置中的指令。
Match 的值是⼀个或多个"条件-模式"对。可⽤的"条件"是:Ur, Group, Host, Address 。
只有下列指令可以在 Match 块中使⽤:AllowTcpForwarding, Banner,
ForceCommand, GatewayPorts, GSSApiAuthentication,
KbdInteractiveAuthentication, KerberosAuthentication,
PasswordAuthentication, PermitOpen, PermitRootLogin,
RhostsRSAAuthentication, RSAAuthentication, X11DisplayOfft,
X11Forwarding, X11ULocalHost
MaxAuthTries
指定每个连接最⼤允许的认证次数。默认值是 6 。
如果失败认证的次数超过这个数值的⼀半,连接将被强制断开,且会⽣成额外的失败⽇志消息。
MaxStartups
最⼤允许保持多少个未认证的连接。默认值是 10 。
到达限制后,将不再接受新连接,除⾮先前的连接认证成功或超出 LoginGraceTime 的限制。
装饰设计培训PasswordAuthentication
是否允许使⽤基于密码的认证。默认为"yes"。
PermitEmptyPasswords
是否允许密码为空的⽤户远程登录。默认为"no"。
PermitOpen
指定TCP端⼝转发允许的⽬的地,可以使⽤空格分隔多个转发⽬标。默认允许所有转发请求。
合法的指令格式如下:
PermitOpen host:port韩国汉阳大学
守护甜心66
PermitOpen IPv4_addr:port
PermitOpen [IPv6_addr]:port
"any"可以⽤于移除所有限制并允许⼀切转发请求。
PermitRootLogin
是否允许 root 登录。可⽤值如下:
"yes"(默认) 表⽰允许。"no"表⽰禁⽌。
"without-password"表⽰禁⽌使⽤密码认证登录。
"forced-commands-only"表⽰只有在指定了command选项的情况下才允许使⽤公钥认证登录。
同时其它认证⽅法全部被禁⽌。这个值常⽤于做远程备份之类的事情。
PermitTunnel
是否允许设备转发。可⽤值如下:
"yes", "point-to-point"(layer 3), "ethernet"(layer 2), "no"(默认)。
"yes"同时蕴含着"point-to-point"和"ethernet"。
PermitUrEnvironment
指定是否允许处理~/.ssh/environment以及~/.ssh/authorized_keys中的 environment= 选项。
默认值是"no"。如果设为"yes"可能会导致⽤户有机会使⽤某些机制(⽐如 LD_PRELOAD)绕过访问控制,造成安全漏洞。 PidFile
指定在哪个⽂件中存放SSH守护进程的进程号,默认为/var/run/sshd.pid⽂件。
Port
指定守护进程监听的端⼝号,默认为 22 。可以使⽤多条指令监听多个端⼝。
默认将在本机的所有⽹络接⼝上监听,但是可以通过 ListenAddress 指定只在某个特定的接⼝上监听。
PrintLastLog
指定是否在每⼀次交互式登录时打印最后⼀位⽤户的登录时间。默认值是"yes"。
PrintMotd
指定是否在每⼀次交互式登录时打印/etc/motd⽂件的内容。默认值是"yes"。
Protocol
指定⽀持的SSH协议的版本号。
'1'和'2'表⽰仅仅⽀持SSH-1和SSH-2协议。"2,1"表⽰同时⽀持SSH-1和SSH-2协议。
PubkeyAuthentication
是否允许公钥认证。仅可以⽤于SSH-2。默认值为"yes"。
RhostsRSAAuthentication
是否使⽤强可信主机认证(通过检查远程主机名和关联的⽤户名进⾏认证)。仅⽤于SSH-1。
这是通过在RSA认证成功后再检查 ~/.rhosts 或 /etc/hosts.equiv 进⾏认证的。
出于安全考虑,建议使⽤默认值"no"。
RSAAuthentication
是否允许使⽤纯 RSA 公钥认证。仅⽤于SSH-1。默认值是"yes"。
ServerKeyBits
指定临时服务器密钥的长度。仅⽤于SSH-1。默认值是 768(位)。最⼩值是 512 。
StrictModes
指定是否要求在接受连接请求前对⽤户主⽬录和相关的配置⽂件进⾏宿主和权限检查。
强烈建议使⽤默认值"yes"来预防可能出现的低级错误。
Subsystem
配置⼀个外部⼦系统(例如,⼀个⽂件传输守护进程)。仅⽤于SSH-2协议。
值是⼀个⼦系统的名字和对应的命令⾏(含选项和参数)。⽐如"sft /bin/sftp-rver"。
SyslogFacility
指定将⽇志消息通过哪个⽇志⼦系统(facility)发送。有效值是:
DAEMON, USER, AUTH(默认), LOCAL0, LOCAL1, LOCAL2, LOCAL3, LOCAL4, LOCAL5, LOCAL6, LOCAL7 TCPKeepAlive
指定系统是否向客户端发送 TCP keepalive 消息。默认值是"yes"。
这种消息可以检测到死连接、连接不当关闭、客户端崩溃等异常。
可以设为"no"关闭这个特性。
UDNS
指定是否应该对远程主机名进⾏反向解析,以检查此主机名是否与其IP地址真实对应。默认值为"yes"。
ULogin
是否在交互式会话的登录过程中使⽤。默认值是"no"。
ws是什么意思
如果开启此指令,那么 X11Forwarding 将会被禁⽌,因为不知道如何处理 cookies 。
需要注意的是,是禁⽌⽤于远程执⾏命令的。
如果指定了 UPrivilegeSeparation ,那么它将在认证完成后被禁⽤。
UPrivilegeSeparation
是否让通过创建⾮特权⼦进程处理接⼊请求的⽅法来进⾏权限分离。默认值是"yes"。
认证成功后,将以该认证⽤户的⾝份创建另⼀个⼦进程。
这样做的⽬的是为了防⽌通过有缺陷的⼦进程提升权限,从⽽使系统更加安全。
X11DisplayOfft
指定 X11 转发的第⼀个可⽤的显⽰区(display)数字。默认值是 10 。
这个可以⽤于防⽌ sshd 占⽤了真实的 X11 服务器显⽰区,从⽽发⽣混淆。
X11Forwarding
是否允许进⾏ X11 转发。默认值是"no",设为"yes"表⽰允许。
如果允许X11转发并且代理的显⽰区被配置为在含有通配符的地址(X11ULocalhost)上监听。
那么将可能有额外的信息被泄漏。由于使⽤X11转发的可能带来的风险,此指令默认值为"no"。
需要注意的是,禁⽌X11转发并不能禁⽌⽤户转发X11通信,因为⽤户可以安装他们⾃⼰的转发器。
如果启⽤了 ULogin ,那么X11转发将被⾃动禁⽌。
X11ULocalhost
是否应当将X11转发服务器绑定到本地loopback地址。默认值是"yes"。
sshd 默认将转发服务器绑定到本地loopback地址并将 DISPLAY 环境变量的主机名部分设为"localhost"。
这可以防⽌远程主机连接到 proxy display 。不过某些⽼旧的X11客户端不能在此配置下正常⼯作。
为了兼容这些⽼旧的X11客户端,你可以设为"no"。
XAuthLocation
指定程序的绝对路径。默认值是/usr/X11R6/bin/xauth
在命令⾏参数和配置⽂件中使⽤的时间值可以通过下⾯的格式指定:time[qualifier] 。
漫长近义词其中的time是⼀个正整数,⽽qualifier可以是下列单位之⼀:
<⽆> 秒
s | S 秒
m | M 分钟
h | H ⼩时
d | D 天
w | W 星期
可以通过指定多个数值来累加时间,⽐如:
1h30m 1 ⼩时 30 分钟 (90 分钟)
/
etc/ssh/sshd_config
的主配置⽂件。这个⽂件的宿主应当是root,权限最⼤可以是"644"。
OpenSSH is a derivative of the original and free ssh 1.2.12 relea by
洗车行业>简单学习Tatu Ylonen. Aaron Campbell, Bob Beck, Markus Friedl, Niels Provos, Theo
de Raadt and Dug Song removed many bugs, re-added newer features and cre-
ated OpenSSH. Markus Friedl contributed the support for SSH protocol
versions 1.5 and 2.0. Niels Provos and Markus Friedl contributed support
for privilege paration.
OpenBSD 4.2 January 1, 2008 9
Vbird⽹络篇⾥的说明:
# 1. 关于 SSH Server 的整体设定,包含使⽤的 port 啦,以及使⽤的密码演算⽅式
# 先留意⼀下,在预设的⽂件内,只要是被批注的设定值(#),即为『默认值!』
Port 22
# SSH 预设使⽤ 22 这个 port,也可以使⽤多个 port,即重复使⽤ port 这个设定项⽬! # 例如想要开放 sshd 在 22 与 443 ,则多加⼀⾏内容为: # Port 443
# 这样就好了!不过,不建议修改 port number
rotocol 1,2
# 选择的 SSH 协议版本,可以是 1 也可以是 2 ,
# 如果要同时⽀持两者,就必须要使⽤ 2,1 这个分隔了(Protocol 1,2)! # ⽬前我们会建议您,直接使⽤ Protocol 2 即可!
#ListenAddress 0.0.0.0
# 监听的主机适配卡!举个例⼦来说,如果您有两个 IP,
# 分别是 192.168.0.100 及 192.168.2.20 ,那么只想要
# 开放 192.168.0.100 时,就可以写如同下⾯的样式:
ListenAddress 192.168.0.100
# 只监听来⾃ 192.168.0.100 这个 IP 的 SSH 联机。
# 如果不使⽤设定的话,则预设所有接⼝均接受 SSH
#PidFile /var/run/sshd.pid
# 可以放置 SSHD 这个 PID 的⽂件!左列为默认值
LoginGraceTime 2m
# 当使⽤者连上 SSH rver 之后,会出现输⼊密码的画⾯,在该画⾯中,
# 在多久时间内没有成功连上 SSH rver ,就断线!若⽆单位则预设时间为秒!
Compression yes
# 是否可以使⽤压缩指令?当然可以
软盘是什么# 2. 说明主机的 Private Key 放置的档案,预设使⽤下⾯的档案即可!
HostKey /etc/ssh/ssh_host_key # SSH version 1 使⽤的私钥
HostKey /etc/ssh/ssh_host_rsa_key # SSH version 2 使⽤的 RSA 私钥