VPS购买后基础防护工作
1、通过查看Auth.log,检查SSH是否被扫
查看用密码登陆成功的IP地址及次数,Debian12默认无/var/log/auth.log文件 ,详见此文解决:Debian无/var/log/auth.log文件问题解决
grep "Accepted password for root" /var/log/auth.log | awk '{print $11}' | sort | uniq -c | sort -nr | more
查看用密码登陆失败的IP地址及次数
grep "Failed password for root" /var/log/auth.log | awk '{print $11}' | sort | uniq -c | sort -nr | more
Ubuntu Debian更改默认端口
可直接替换ssh_config配置文件里的Port 22为其它端口,但是为了保守起见,先增加一行Port *****
保留22是为了防止个别防火墙屏蔽了其它端口导致无法连接VPS(如没单独指定22,新指定的*****端口防火墙也没放行,那么可能无法通过SSH连接VPS或服务器)。为了防止不必要问题的产生,所以要给自己保留条“后路”。
nano /etc/ssh/sshd_config
或直接命令改
sed -i "s/Port .*/Port 需要的新端口/g" /etc/ssh/sshd_config
Debian9还需要修改一下/etc/ssh/sshd_config配置,nano编辑一下 nano /etc/ssh/sshd_config ,修改去除端口号前的“#”
重启ssh
/etc/init.d/sshd restart #centos系统 /etc/init.d/ssh restart #debian,ubuntu系统
使用新端口登陆,如果能登陆成功,再删除Port 22这行代码,同样需要重启ssh
改登陆端口不是万能的,毕竟扫一下端口也就秒秒钟事情,之所以改端口,只是为了避免最简单的暴力扫描登陆,建议对多次登陆ssh失败的ip进行限制,可以参考这篇教程 SSH多次登录失败后限制IP
2、Debian/Ubuntu更新软件及系统
Debian/Ubuntu 系统在用户登录时会显示欢迎信息,当有软件、系统升级时会看到“有xx个软件包可以更新,其中有xx个安全更新,有可用的高版本系统”。例如Ubuntu:
95 packages can be updated. 56 updates are security updates. New release '16.04.3 LTS' available
有时候用了
apt-get update && apt-get upgrade
还是会提示有更新,那么可以使用以下更新顺序进行更新软件操作。
apt-get update apt-get upgrade apt-get full-upgrade apt-get dist-upgrade reboot
这四个升级命令都有什么区别呢?
根据 apt-get 的官方手册:
update – 从服务器更新可用的软件包列表。
upgrade – 根据列表,更新已安装的软件包。upgrade 不会删除在列表中已经没有的软件包,也不会安装有依赖需求但尚未安装的软件包。
full-upgrade – 根据列表,更新已安装的软件包。full-upgrade 可能会为了解决软件包冲突而删除一些已安装的软件包。
dist-upgrade – 根据列表,更新已安装的软件包。dist-upgrade 可能会为了解决软件包冲突而删除一些已安装的软件包,也可能会为了解决软件包依赖问题安装新的软件包。
升级系统到高版本,理论上只需敲do-release-upgrade命令即可
do-release-upgrade
但是也有出错情况,比如ubuntu 14.04升级到16.04,如果直接执行 do-release-upgrade 升级命令,可能会遇到:需要的依赖关系未安装 的报错信息:
The required dependency 'apt (>= 1.0.1ubuntu2.13)' is not installed.
此时我们需要先更新 apt 到 1.0.1ubuntu2.13 以上才能进行升级操作。
apt-get update apt-get upgrade do-release-upgrade reboot
3、Debian/Ubuntu新增普通管理员账户并设置管理员权限
在Linux系统下,$
是普通管理员命令标识,#
是系统管理员命令标识
更改已有用户账户密码
我们可以使用 passwd
命令来更改账户的命令,执行后输入两次新密码即可。例如为 root
账户修改密码:
sudo passwd root
新增用户账户
可以通过 adduser
命令来新增账户:
sudo adduser username
同样的需要输入两次密码,其他的设置项直接按回车即可。
新创建的用户只有普通用户权限,如果想要安装软件或更新软件包,还需要赋予账户管理员权限才行。
4、Debian 9允许root用户登录和以ssh方式登录
4.1允许以root用户登录操作系统
遇到Debian9不允许以root用户登录的时候,用其他用户登录系统中,然后su到root用户下进行操作也是一样的效果,但总有奇葩主机商禁止了root用户和root用户ssh访问,只能自己手动操作,或者DD全新系统了。
4.1.1 修改/etc/gdm3/daemon.conf文件,新增下面一行
[security] AllowRoot = true
4.1.2 修改/etc/pam.d/gdm-password,注释掉下面内容
#auth required pam_succeed_if.so user != root quiet_success
然后重启操作系统,就可以使用root用户登录操作系统了。
4.2以root身份通过ssh登录操作系统
4.2.1修改/etc/ssh/sshd_config,将“#PermitRootLogin prohibit-password”
修改为
PermitRootLogin yes
4.2.2重启ssh即可
service sshd restart
或
/etc/init.d/ssh restart
接下来就可以用root帐户进行ssh登录操作了。
近期评论