登陆一台Linux RedHat As4的服务器,发现有很多网络连接,为本机去连接其他服务器的22端口。再一看进程,好多ssh-scan的进程。估计是密码设得太简单,被人家黑了。处理思路:找到ssh-scan进程的相应程序文件,删除之。

先查看定时任务,没有看到有异常的定时任务。

最后处理步骤如下:

1、ps -ef|grep ssh-scan (或ps –ajxf)

ps -ef|grep ssh
500       8923     1  0 Jul02 ?        00:00:22 ./scanssh
500       8928     1  0 Jul02 ?        00:00:22 ./scanssh
500       8929     1  0 Jul02 ?        00:00:20 ./scanssh
500       8937     1  0 Jul02 ?        00:00:18 ./scanssh
500       8938     1  0 Jul02 ?        00:00:21 ./scanssh
500       8939     1  0 Jul02 ?        00:00:21 ./scanssh
500       8941     1  0 Jul02 ?        00:00:18 ./scanssh
500       8948     1  0 Jul02 ?        00:00:17 ./scanssh
500       8949     1  0 Jul02 ?        00:00:14 ./scanssh
500       8953     1  0 Jul02 ?        00:00:21 ./scanssh
500       8955     1  0 Jul02 ?        00:00:17 ./scanssh
500       8957     1  0 Jul02 ?        00:00:27 ./scanssh
500       8966     1  0 Jul02 ?        00:00:22 ./scanssh
500       8967     1  0 Jul02 ?        00:00:22 ./scanssh
500       8968     1  0 Jul02 ?        00:00:22 ./scanssh
500       8969     1  0 Jul02 ?        00:00:10 ./scanssh
500       8971     1  0 Jul02 ?        00:00:21 ./scanssh
500       8975     1  0 Jul02 ?        00:00:00 ./scanssh
500       8980     1  0 Jul02 ?        00:00:00 ./scanssh
500       8984     1  0 Jul02 ?        00:00:18 ./scanssh
500       8986     1  0 Jul02 ?        00:00:06 ./scanssh
500       8996     1  0 Jul02 ?        00:00:03 ./scanssh
500       9015     1  0 Jul02 ?        00:00:31 ./scanssh
500       9016     1  0 Jul02 ?        00:00:21 ./scanssh
500       9019     1  0 Jul02 ?        00:00:19 ./scanssh
500       9025     1  0 Jul02 ?        00:00:21 ./scanssh
500       9026     1  0 Jul02 ?        00:00:20 ./scanssh
500       9031     1  0 Jul02 ?        00:00:37 ./scanssh
500       9059     1  0 Jul02 ?        00:00:00 ./scanssh
500       9061     1  0 Jul02 ?        00:00:00 ./scanssh
500       9062     1  0 Jul02 ?        00:00:00 ./scanssh
500       9066     1  0 Jul02 ?        00:00:20 ./scanssh
500       9067     1  0 Jul02 ?        00:00:21 ./scanssh
500       9077     1  0 Jul02 ?        00:00:20 ./scanssh
500      18696     1  0 Jun28 ?        00:00:00 ./scanssh
500      18697     1  0 Jun28 ?        00:00:00 ./scanssh
500      18698     1  0 Jun28 ?        00:00:00 ./scanssh
500      18699     1  0 Jun28 ?        00:00:00 ./scanssh
500      18706     1  0 Jun28 ?        00:00:00 ./scanssh
500      18715     1  0 Jun28 ?        00:00:00 ./scanssh
500      18716     1  0 Jun28 ?        00:00:05 ./scanssh
500      18727     1  0 Jun28 ?        00:00:00 ./scanssh
500      18731     1  0 Jun28 ?        00:00:00 ./scanssh
500      18733     1  0 Jun28 ?        00:00:00 ./scanssh
500      18740     1  0 Jun28 ?        00:00:00 ./scanssh
500      18741     1  0 Jun28 ?        00:00:02 ./scanssh
500      18747     1  0 Jun28 ?        00:00:00 ./scanssh
500      18760     1  0 Jun28 ?        00:00:04 ./scanssh
500      18762     1  0 Jun28 ?        00:00:00 ./scanssh
500      18767     1  0 Jun28 ?        00:00:00 ./scanssh
500      18770     1  0 Jun28 ?        00:00:01 ./scanssh
500      18789     1  0 Jun28 ?        00:00:00 ./scanssh
500      18791     1  0 Jun28 ?        00:00:00 ./scanssh
500      18800     1  0 Jun28 ?        00:00:00 ./scanssh
500      18821     1  0 Jun28 ?        00:00:00 ./scanssh
500      18822     1  0 Jun28 ?        00:00:00 ./scanssh
500      18823     1  0 Jun28 ?        00:01:10 ./scanssh
500      18824     1  0 Jun28 ?        00:00:00 ./scanssh
500      18828     1  0 Jun28 ?        00:01:17 ./scanssh
500      18829     1  0 Jun28 ?        00:00:04 ./scanssh
500      18832     1  0 Jun28 ?        00:00:00 ./scanssh
500      18833     1  0 Jun28 ?        00:00:00 ./scanssh
500      18836     1  0 Jun28 ?        00:00:00 ./scanssh
500      18838     1  0 Jun28 ?        00:00:00 ./scanssh
500      18841     1  0 Jun28 ?        00:00:02 ./scanssh
500      18842     1  0 Jun28 ?        00:00:03 ./scanssh
500      18863     1  0 Jun28 ?        00:00:02 ./scanssh
500      18866     1  0 Jun28 ?        00:00:00 ./scanssh
500      18884     1  0 Jun28 ?        00:00:00 ./scanssh
500      18896     1  0 Jun28 ?        00:00:02 ./scanssh
500      18899     1  0 Jun28 ?        00:00:00 ./scanssh
500      18902     1  0 Jun28 ?        00:00:00 ./scanssh
500      18907     1  0 Jun28 ?        00:00:00 ./scanssh
500      18916     1  0 Jun28 ?        00:00:16 ./scanssh
500      18917     1  0 Jun28 ?        00:00:00 ./scanssh
500      18938     1  0 Jun28 ?        00:00:04 ./scanssh
500      18942     1  0 Jun28 ?        00:00:00 ./scanssh
500      18943     1  0 Jun28 ?        00:00:02 ./scanssh
500      18947     1  0 Jun28 ?        00:00:00 ./scanssh
500      18951     1  0 Jun28 ?        00:00:00 ./scanssh
500      18953     1  0 Jun28 ?        00:00:00 ./scanssh
500      18969     1  0 Jun28 ?        00:00:00 ./scanssh
500      18982     1  0 Jun28 ?        00:00:00 ./scanssh
500      18988     1  0 Jun28 ?        00:00:00 ./scanssh
500      19018     1  0 Jun28 ?        00:00:13 ./scanssh
500      19027     1  0 Jun28 ?        00:00:00 ./scanssh
500      19053     1  0 Jun28 ?        00:00:30 ./scanssh
500      19061     1  0 Jun28 ?        00:00:00 ./scanssh
500      19086     1  0 Jun28 ?        00:00:19 ./scanssh
500      19095     1  0 Jun28 ?        00:00:00 ./scanssh
500      19103     1  0 Jun28 ?        00:00:00 ./scanssh
500      19111     1  0 Jun28 ?        00:00:00 ./scanssh
root     24539 27230  0 11:32 ?        00:00:00 sshd: swzj [priv]
swzj     24541 24539  0 11:32 ?        00:00:00 sshd: swzj@pts/6
root     27230     1  0 Apr12 ?        00:01:34 /usr/sbin/sshd
root     27657 24598  0 13:28 pts/6    00:00:00 grep ssh

2、找到ssh-scan对应的进程号PID,如有一个是19061 。

3、进入到/proc/PID对应的目录,cd /proc/19061

4、ls -al,查看cwd和exe对应的选项,找到应用程序所在目录。

5、将其全部杀死后killall -9 scanssh,删除对应目录。

6、将用户密码全部修改。

用netstat -an|grep 22看,仍然有很多连接,reboot服务器,系统运行正常。

另,参考链接:http://www.vvvk.net/archives/311#more-311

附录:/PROC目录介绍

原文:http://www.freeos.com/articles/2879/  translated by bugzilla_zhu

Proc 文件系统是一个实时的,常驻内存的文件系统,它跟踪进程在你机器上的运行情况和你系统的状态。继续阅读你可以学到很多/proc文件系统的知识。

/proc伪文件系统最令人震惊的是它事实上不存在于任何的媒介上。/proc文件系统是常驻虚拟内存并且维持着操作系统的动态数据的一个伪文件系统。大部分的/proc文件系统信息被实时更新来与当前操作系统的状态一致。/proc文件系统的内容能被任何有相应权限的人读取。但是,/proc文件系统的特定的部分只能被这个进程的拥有者和root用户读取。/proc文件系统的内容从特定的/proc目录得到数据并且显示出来,它们有很多用途。

在linux下,我们有工具像lscpi,scanpci和pnpdump,它们帮助我们检测大量的PCI,ISA 硬件芯片设置并且帮助我们对io,dma和irq的值作最好的选择。通过查看/proc文件系统的各种参数的值,我们可以看到许多内核和进程的当前状态。我们用dmesg命令举个例子。

bash# dmesg

Dmesg 帮助我们确定已经被内核检测到和初始化的设备。我们有工具像"ps"和"top",给我们一个准确的快照,这个快照是关于进程在机器上运行的状态和一个当前运行在机器上的清醒和睡眠的进程的列表。你曾经想过这些通过"ps"和"top"进程给出的信息的准确的出处吗?这些进程的信息来自/proc文件系统,当进程发生改变的时候它随时更新。

让我们看一下linux机器的root目录的列表快照。

drwxr-xr-x 14 root root 291 Oct 25 18:47 opt
dr-xr-xr-x 86 root root 0 Nov 30 2000 proc <--
drwx--x--x 16 root root 841 Nov 20 00:10 root
drwxr-xr-x 5 root root 4627 Oct 15 11:42 sbin

因为/proc文件系统是一个虚拟的文件系统并且常驻内存,每次当你的linux机器重启的时候它被重新创建。看一下上面的root目录。proc目录的大小是0并且最后一次修改时间是当前日期。

使用/proc/sys文件系统来解析内核参数。

/proc文件系统的另一个非常重要的部分是/proc/sys目录。在这个目录下你可以对指定的内核参数做实时的改变。一个好的例子如下。

/proc/sys/net/ipv4/ip_forward

当你cat这个文件的内容的时候你可以看到以上这个文件中ip_forward有一个默认值为"0"。这意味着通过这个机器作IP转发是不允许的。但是通过改变这个文件中的值从"0"到"1",这个配置能实时地被改变。然后我们立刻可以在我们的linux机器上作IP转发,不用重启系统。

/proc文件系统的内容

/proc目录列表如下。实际的列表很长。我们下面给出的是一个比较短的版本。

1 114 1210 1211 1212 1227 133 137 148 160 161 163 167 168 169
170 171 172 173 174 186 190 193 194 195 203 206 207 208 209
210 211 220 221 222 223 224 225 226 227 229 230 234 246 253 279
296 3 4 5 500 501 6 667 668 669 683 684 685 7 711 712 713 737 763
764 765 766 773 774 775 782 79 88 92 asound bus cmdline config.gz
cpuinfo devices dma fb filesystems fs ide interrupts ioports
kcore kcore_elf kmsg ksyms loadavg locks lvm mdstat meminfo
memstat misc modules mounts net partitions pci rtc scsi self
slabinfo stat swaps sys tty uptime version

在上面的快照中你看到的每一个数字和单词都是/proc目录的内容。让我们学习更多这个目录中用数字命名的内容。

数字命名的目录

1 114 1210 1211 1212 1227 133 137 148 160 161 163 167 168 169
170 171 172 173 174 186 190 193 194 195 203 206 207 208 209
210 211 220 221 222 223 224 225 226 227 229 230 234 246 253 279
296 3 4 5 500 501 6 667 668 669 683 684 685 7 711 712 713 737 763
764 765 766 773 774 775 782 79 88 92

你看到的大量在这里列出的目录是进程,在我们对/proc文件系统作快照的时候它们正运行在你的机器上。让我们看一下目录的内容。

freeos:~ # cd /proc
freeos:/proc # ls -la 114
total 0
dr-xr-xr-x 3 named named 0 Nov 30 12:20 .
dr-xr-xr-x 89 root root 0 Nov 30 2000 ..
-r--r--r-- 1 root root 0 Nov 30 12:20 cmdline
lrwx------ 1 root root 0 Nov 30 12:20 cwd -> /var/named
-r-------- 1 root root 0 Nov 30 12:20 environ
lrwx------ 1 root root 0 Nov 30 12:20 exe -> /usr/sbin/named
dr-x------ 2 root root 0 Nov 30 12:20 fd
pr--r--r-- 1 root root 0 Nov 30 12:20 maps
-rw------- 1 root root 0 Nov 30 12:20 mem
lrwx------ 1 root root 0 Nov 30 12:20 root -> /
-r--r--r-- 1 root root 0 Nov 30 12:20 stat
-r--r--r-- 1 root root 0 Nov 30 12:20 statm
-r--r--r-- 1 root root 0 Nov 30 12:20 status

在我们执行命令之前我们需要作为root登录,因为大量的运行在系统上的进程可能被其他人拥有。通常你只有权限访问你开启的进程。在作为root登录之后,对任意的目录执行以上的命令并且与以上的输出作比较。

你有没有注意到你得到的输出与上面列出的内容有任何相似之处?是的,所有你选择查看的无关的目录的内容都是一样的,因为这些目录包括大量的进程的参数和状态,它的PID是你所在的当前目录的名字。各个参数的值和状态信息当然因进程不同而不同。

看上面输出的第一行。

-r--r--r-- 1 root root 0 Nov30 12:20 cmdline

"cmdline",这个文件包含整个用来产生进程的命令行。这个文件的内容是命令行参数包括传递来启动进程的所有参数。所有包含在这个文件的信息即命令和各个启动参数,没有任何的格式和任何的空格。

lrwx------ 1 root root 0 Nov 30 12:20 cwd -> /var/named

"cwd",像我们从上面看见的,这是一个符号链接,它指向进程的当前工作目录。

-r-------- 1 root root 0 Nov 30 12:20 environ

"environ"包括在VARIABL=value为这个进程定义的所有的环境变量。正如"cmdline"一样,包含在文件中的命令和各个参数的信息没有任何的格式和空格。

lrwx------ 1 root root 0 Nov 30 12:20 exe -> /usr/sbin/named

"exe",这是一个符号链接指向启动当前进程的可执行文件。

dr-x------ 2 root root 0 Nov 30 12:20 fd

"fd",这个目录包括被指定进程打开的文件描述符。

pr--r--r-- 1 root root 0 Nov 30 12:20 maps

"maps",当你打出这个命名管道的内容,你可以看到进程的地址空间部分,当前被映射到一个文件。这个部分,从左到右是:和这个映射有关的地址空间,和这个映射有关的权限,距离文件开始(即这个映射开始的地方)的偏移量,这个映射文件所在的设备,文件的inode号,最后是文件名本身。

"root",这是一个符号链接指向这个进程的/proc目录。

-r--r--r-- 1 root root 0 Nov 30 12:20 status

"status",这个文件给你有关进程名的信息,它的当前的状态,睡眠或者清醒,它的PID,UID,PPID和大量其它基本信息。这个信息可以在一个更简单和结构化的语法中看到,通过使用工具如"ps"和"top"。

关于大量/proc/*目录的基本信息

这个信息已经存在LASG, 第三章《/proc  文件系统》中。

/proc/cpuinfo

关于处理器,诸如它的类型,产地,型号和性能。

/proc/devices

当前运行的内核配置的设备的驱动列表。

/proc/dma

显示DMA通道此刻正在被使用。

/proc/filesystems

内核配置的文件系统。

/proc/interrupts

显示在使用的中断,和每个中断已经使用的次数

/proc/ioports

哪一个I/O端口正在使用

转载于:https://blog.51cto.com/gkeke/767816

ssh-scan处理手记相关推荐

  1. 手把手教你用Python进行SSH暴力破解

    暴力破解属于密码破解的一种,也是最常见的破解方法之一,通过不断的尝试来达到破解的目的,所以暴力破解的本质就是一种枚举. 现在也有很多流行的破解软件,不过个人觉得装上kail其实也就啥都有了,但是今天我 ...

  2. Metasploit终端下的辅助扫描工具 (auxiliary模块讲解)

    (辅助扫描工具主要用于网络攻防前期的踩点.信息搜集) ###一.操作环境 虚拟机Kali(IP:192.168.1.92) 为方便学习开启ssh端口 # 进入ssh配置文件 >>vi /e ...

  3. DEFCON CHINABCTF的一些随笔

    萌新的第一次线下决赛,毫无意外的被打爆,打扰了我太菜了,告辞! 下面记录一下这次的收获吧. 靶场渗透 这次靶场是打的真的爽,也学习了很多东西.从一个博客开始到服务器到内网最后拿域控权限,打的真的爽啊. ...

  4. 手把手搭建开源蜜罐系统MHN

    cd opt curl -O https://bootstrap.pypa.io/get-pip.py pip install pyOpenSSL ndg-httpsclient pyasn1 apt ...

  5. 利用nmap scan ssh server支持的algorithms

    [root@labvm3 scripts]# pwd /usr/share/nmap/scripts 如果VM有多网卡,需要-e指定网卡名 [root@labvm3 scripts]# nmap -s ...

  6. 在手机ssh客户端在云主机上yum快速安装 php nginx手记

    最近在学习Linux下的程序安装,发现坑不少. 以下是按照网上搜到的百度经验自己发现的问题和经验. 1.首先要申请一个云主机,我由于是学习,申请了一个三丰免费云主机进行测试. 2.手机ssh手机终端J ...

  7. 【GP6安装配置】 Greenplum6.2.1 安装手记(下)

    作者:lianghc 本文分为两部分 参数配置:[GP6安装配置] Greenplum6.2.1 安装手记(上) 执行安装:[GP6安装配置] Greenplum6.2.1 安装手记(下) 目录 3. ...

  8. 一次 SSH 攻击与处理小记

    这是我在简书看到的一个作者经历,结合小编自己的一些实践,抛砖引玉,给大家分享一下. 有段时间发现集群异常卡顿.担心的事情终于发生了,使用命令 lastb 查看了一下,我的天呢,好多未知的 IP,我随便 ...

  9. Linux/ubuntu 服务器开启6010端口-X11服务-ssh连接

    此文首发于我的个人博客:Linux/ubuntu 服务器开启6010端口-X11服务-ssh连接 - zhang0peter的个人博客 晚上在检查我的Linux-ubuntu服务器的端口状况时发现开启 ...

  10. SSH-Auditor:一款SSH弱密码探测工具

    SSH-Auditor:一款SSH弱密码探测工具 freebuf 2018-09-16  ssh-auditor是一款可帮助你探测所在网络中ssh弱密码的工具. 特性 以下操作ssh-auditor都 ...

最新文章

  1. iphone smtp服务器没有响应,电子邮件卡在iPhone或iPad上的发件箱?如何修复iOS中的未发送邮件 | MOS86...
  2. java中对JVM的深度解析、调优工具、垃圾回收
  3. Spark学习(四) -- Spark作业提交
  4. 003_推箱子-事件
  5. hive通过外表把数据存到mysql中_hive数据去重
  6. C++自己实现一个String类(腾讯阿里面试题目)
  7. Java 程序员必备的一些流程图
  8. Unity3D游戏开发之仿仙剑奇侠传一2D游戏 (一)
  9. plsql使用方法(主要是sql语句)
  10. C++11常见编译与链接错误解决总结
  11. 一点击文件夹里的wps文件就卡死,不管放在哪个盘
  12. 2021-11-12每日刷题打卡
  13. 惠云转债上市价格预测
  14. 重型音乐金属核后期分轨混音教程教学培训(基础+进阶+重型音色调音指南+剪辑+修音+美感设计+实战+母带处理)|MZD Studios
  15. (四)基于区块链的自动抽奖系统从0到1实现
  16. 半年面试,我总结出了java面试笔记
  17. CTPN-自然文本场景检测学习笔记
  18. 鸿蒙系统与nblot,华为鸿蒙操作系统,和想象中的不一样
  19. Java实现零钱通功能
  20. Delphi编程语言初学总结

热门文章

  1. 计算机专业研究生应该如何规划,【图片】2020考研,老学长教你如何规划!【计算机考研吧】_百度贴吧...
  2. 用java输入学生姓名查询成绩_编写一个Java程序,提示用户输入学生数量,学生姓名和他们的成绩,并按照成绩的降序打印学生姓名...
  3. linux 安装系统 逻辑卷,Linux逻辑卷工具lvm的使用教程
  4. android 弹窗ui,Android 弹出窗口与对话框 UI设计
  5. 计算机专业人毕业设计外文翻译,计算机专业毕业设计外文翻译.doc
  6. android判断点击次数_Android应用统计-使用时长及次数统计(一)
  7. python修改服务器ip,[python+Bat]读表修改机房IP
  8. TVM:在树莓派上部署预训练的模型
  9. python arduino c_从Python向Arduino LCD发送一个字符串
  10. python框架是干什么的_django框架是干什么的