SSH的性能调优

本文发布时间: 2019-Mar-21
首先我们要做的是修改 SSH 端口,禁止 root 登陆,修改的文件为/etc/ssh/sshd_config$ sudo vi /etc/ssh/sshd_configPort 4484 #一个别人猜不到的端口号PermitRootLogin no$ sudo /etc/init.d/ssh restart然后我们禁用密码登陆,使用 RSA 私钥登录,Amazon EC2 服务器本来就是只允许使用私钥登录的,但是这样的话我如果想在别的电脑上临时 SSH 上来,又没带私钥文件的情况下,就很麻烦。所以我又手动开启了密码验证登录。$ ssh-keygen -t rsa #在客户端生成密钥$ ssh-copy-id -i .ssh/id_rsa.pub server #把公钥拷贝至服务器也可以手动将.shh/id_rsa.pub拷贝至服务器用户目录的.ssh中,记得修改访问权限◦# $ scp .shh/id_rsa.pub server:~/.ssh◦# 在服务器中◦$ cd ./.ssh/◦$ mv id_rsa.pub authorized_keys◦$ chmod 400 authorized_keys◦$ vi /etc/ssh/sshd_config◦RSAAuthentication yes #RSA认证◦PubkeyAuthentication yes #开启公钥验证◦AuthorizedKeysFile .ssh/authorized_keys #验证文件路径◦PasswordAuthentication no #禁止密码认证◦PermitEmptyPasswords no #禁止空密码◦UsePAM no #禁用PAM◦$ sudo /etc/init.d/ssh restart# 最后保存,重启denyhosts 是 Python 语言写的一个程序,它会分析 sshd 的日志文件,当发现重复的失败登录时就会记录 IP 到 /etc/hosts.deny 文件,从而达到自动屏 IP 的功能。如果靠人工手动添加的话工作量是非常大的。现今 denyhosts 在各个发行版软件仓库里都有,而且也不需要过多配置,方便简单易用,那么首先是安装:$ sudo apt-get install denyhosts# Debian/Ubuntu:$ yum install denyhosts# RedHat/CentOS$ yaourtdenyhosts #Archlinux$ emerge -avdenyhosts#Gentoo默认配置就能很好的工作,如要个性化设置可以修改 /etc/denyhosts.conf:◦$ vi /etc/denyhosts.conf◦SECURE_LOG = /var/log/auth.log #ssh 日志文件,它是根据这个文件来判断的。◦HOSTS_DENY = /etc/hosts.deny #控制用户登陆的文件◦PURGE_DENY = #过多久后清除已经禁止的,空表示永远不解禁◦BLOCK_SERVICE = sshd #禁止的服务名,如还要添加其他服务,只需添加逗号跟上相应的服务即可◦DENY_THRESHOLD_INVALID = 5 #允许无效用户失败的次数◦DENY_THRESHOLD_VALID = 10 #允许普通用户登陆失败的次数◦DENY_THRESHOLD_ROOT = 1 #允许root登陆失败的次数◦DENY_THRESHOLD_RESTRICTED = 1◦WORK_DIR = /var/lib/denyhosts #运行目录◦SUSPICIOUS_LOGIN_REPORT_ALLOWED_HOSTS=YES◦HOSTNAME_LOOKUP=YES #是否进行域名反解析◦LOCK_FILE = /var/run/denyhosts.pid #程序的进程ID◦ADMIN_EMAIL = root@localhost #管理员邮件地址,它会给管理员发邮件◦SMTP_HOST = localhost◦SMTP_PORT = 25◦SMTP_FROM = DenyHosts<nobody@localhost>◦SMTP_SUBJECT = DenyHosts Report◦AGE_RESET_VALID=5d #用户的登录失败计数会在多久以后重置为0,(h表示小时,d表示天,m表示月,w表示周,y表示年)◦AGE_RESET_ROOT=25d◦AGE_RESET_RESTRICTED=25d◦AGE_RESET_INVALID=10d◦RESET_ON_SUCCESS = yes #如果一个ip登陆成功后,失败的登陆计数是否重置为0◦DAEMON_LOG = /var/log/denyhosts #自己的日志文件◦DAEMON_SLEEP = 30s #当以后台方式运行时,每读一次日志文件的时间间隔。◦DAEMON_PURGE = 1h #当以后台方式运行时,清除机制在 HOSTS_DENY 中终止旧条目的时间间隔,这个会影响PURGE_DENY的间隔。


(以上内容不代表本站观点。)
---------------------------------
本网站以及域名有仲裁协议。
本網站以及域名有仲裁協議。

2024-Mar-04 02:08pm
栏目列表