5718 开发板更换ssh默认端口

应客户要求,提升ssh登录安全性,搜索到的方法有:

1 增加账户密码,并指定尝试密码次数,防止暴力破解
2 由于root权限过大,禁止root用户登录
3 更改ssh默认端口22为其他端口
4 采用密钥登录:将公钥添加到服务器的某个账户上,然后在客户端利用私钥即可完成认证并登录
5 增加用户黑白名单,指定用户才能登录
6 增加IP黑白名单,指定IP设备才能登录

最终挑选1,3实施。

 

1增加密码很简单,登录后直接

passwd

2更改22端口,本来以为也很简单,网上搜索都说更改配置文件

/etc/ssh/sshd_config

可翻遍了整个文件系统,也找不到sshd_config文件,询问飞凌客服,回复说他们的ssh不是用的openssh,而是更轻量级的dropbear.又是上网搜索,终于找到如下的配置文件

/etc/init.d/dropbear

#!/bin/sh
### BEGIN INIT INFO
# Provides:             sshd
# Required-Start:       $remote_fs $syslog $networking
# Required-Stop:        $remote_fs $syslog
# Default-Start:        2 3 4 5
# Default-Stop:         1
# Short-Description:    Dropbear Secure Shell server
### END INIT INFO
#
# Do not configure this file. Edit /etc/default/dropbear instead!
#

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/sbin/dropbear
NAME=dropbear
DESC="Dropbear SSH server"
PIDFILE=/var/run/dropbear.pid

DROPBEAR_PORT=22
DROPBEAR_EXTRA_ARGS=
NO_START=0

set -e

test ! -r /etc/default/dropbear || . /etc/default/dropbear
test "$NO_START" = "0" || exit 0
test -x "$DAEMON" || exit 0
test ! -h /var/service/dropbear || exit 0

readonly_rootfs=0
for flag in `awk '{ if ($2 == "/") { split($4,FLAGS,",") } }; END { for (f in FLAGS) print FLAGS[f] }' &2
        exit 1
        ;;
esac

exit 0

惊喜的发现 DROPBEAR_PORT=22 ,正准备更改,看到提示

Do not configure this file. Edit /etc/default/dropbear instead!

于是又打开 /etc/default/dropbear,发现只有一行

DROPBEAR_EXTRA_ARGS="-B"

于是添加

DROPBEAR_PORT=2222

保存,重启,竟然不生效。

又返回 /etc/init.d/dropbear,强制更改22端口,重启依然无效。

近乎绝望时,意外发现系统存在dropbear.service服务,默认状态为关闭,大喜,

systemctl start dropbear

此时更改的2222端口终于生效了,但重启后再次失效。使能后报错:

systemctl enable dropbear

root@ok5718-idk:~# systemctl enable dropbear
dropbear.service is not a native service, redirecting to systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable dropbear
System startup links for /etc/init.d/dropbear already exist.

无奈,只能新建myDropbear.sh,每次开机强制开启dropbear服务

vi /opt/locationServer/myDropbear.sh


#!/bin/sh
systemctl start dropbear

同时创建系统服务myDropbear.service

vi /etc/systemd/system/myDropbear.service

[Unit]
Description = myDropbear

[Service]
ExecStart = /opt/locationServer/myDropbear.sh
Restart = always
Type = simple

[Install]
WantedBy = multi-user.target

最后开启此服务

systemctl enable myDropbear.service

 

好了,终于可以屏蔽22端口,改用自定义了

你可能感兴趣的:(运维,ssh)