Fork me on GitHub

记一次服务器被挖矿处理过程!

记一次服务器被挖矿处理过程
  1. 首先利用watch -n 1 nvidia-smi 命令查看GPU进程时发现几张显卡占用率都是100%

  2. 通过进程PID查看脚本所在路径

    ll /proc/pid
    

    cd /tmp/.dev
    #发现该目录存在python3的脚本代码
    #于是接下来我做了以下两个操作
    kill -9 pid #kill掉该进程
    rm -rf /tmp/.dev/python3 #删除该脚本
    #再检查nvidia-smi发现正常,本以为以及愉快的解决问题了,但是过了一会发现该显卡占有率又是100%
    #于是 开始百度 网上说是存在定时脚本 也发现了该进程还存在父进程,没有kill干净
    cat /proc/pid/status#根据子进程查看父进程
    kill -9 PPID
    
    crontab -l # 列出目前的时程表
    #然而并没有什么用,其定时命令在root下并不存在
    #在/tmp/.dev/目录下
    ll -a
    #发现文件的所有者属于test 且创建时间为4月30号
    #然后我就开始疯狂搜索test 和 4月30号创建的文件
    find / -name test #查找所有test文件
    find /etc -mtime 12 #前【n-1,n】天的所有创建文件
    
    #最后在/var/tmp目录下发现了脚本
    #同时在/var/spool目录下发现了一系列的定时脚本任务等一系列文件,其中Makefile惊到了我,鉴赏见下面第3部分
    #在/home/server/user/test目录下发现了挖矿程序PhoenixMiner 可以断定该挖矿是通过server用户下面的test用户进入到服务器的
    #在 /root/.ssh/known_hosts文件中植入了免密登录 不得不说非常厉害,10.80.0.3 
    #同时利用netstat -ntu命令,发现近期访问的也是该ip
    #不知道这个ip是本人还是肉鸡
    

  3. Makefile鉴赏 :感觉就是获取服务器的用户、密码、组等相关信息的脚本

    # Makefile to (re-)generate db versions of system database files.
    # Copyright (C) 1996-2013 Free Software Foundation, Inc.
    # This file is part of the GNU C Library.
    # Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
    #
    
    # The GNU C Library is free software; you can redistribute it and/or
    # modify it under the terms of the GNU Lesser General Public
    # License as published by the Free Software Foundation; either
    # version 2.1 of the License, or (at your option) any later version.
    
    # The GNU C Library is distributed in the hope that it will be useful,
    # but WITHOUT ANY WARRANTY; without even the implied warranty of
    # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    # Lesser General Public License for more details.
    
    # You should have received a copy of the GNU Lesser General Public
    # License along with the GNU C Library; if not, see
    # <http://www.gnu.org/licenses/>.
    
    DATABASES = $(wildcard /etc/passwd /etc/group /etc/ethers /etc/protocols \
    		       /etc/rpc /etc/services /etc/shadow /etc/gshadow \
    		       /etc/netgroup)
    
    VAR_DB = /var/db
    
    AWK = awk
    MAKEDB = makedb --quiet
    
    all: $(patsubst %,$(VAR_DB)/%.db,$(notdir $(DATABASES)))
    
    
    $(VAR_DB)/passwd.db: /etc/passwd
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) 'BEGIN { FS=":"; OFS=":" } \
    		 /^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print; \
    			   printf "=%s ", $$3; print }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    $(VAR_DB)/group.db: /etc/group
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) 'BEGIN { FS=":"; OFS=":" } \
    		 /^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print; \
    			   printf "=%s ", $$3; print; \
    			   if ($$4 != "") { \
    			     split($$4, grmems, ","); \
    			     for (memidx in grmems) { \
    			       mem=grmems[memidx]; \
    			       if (members[mem] == "") \
    				 members[mem]=$$3; \
    			       else \
    				 members[mem]=members[mem] "," $$3; \
    			     } \
    			     delete grmems; } } \
    		 END { for (mem in members) \
    			 printf ":%s %s %s\n", mem, mem, members[mem]; }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    $(VAR_DB)/ethers.db: /etc/ethers
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) '/^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print; \
    			   printf "=%s ", $$2; print }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    $(VAR_DB)/protocols.db: /etc/protocols
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) '/^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print; \
    			   printf "=%s ", $$2; print; \
    			   for (i = 3; i <= NF && !($$i ~ /^#/); ++i) \
    			     { printf ".%s ", $$i; print } }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    $(VAR_DB)/rpc.db: /etc/rpc
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) '/^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print; \
    			   printf "=%s ", $$2; print; \
    			   for (i = 3; i <= NF && !($$i ~ /^#/); ++i) \
    			     { printf ".%s ", $$i; print } }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    $(VAR_DB)/services.db: /etc/services
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) 'BEGIN { FS="[ \t/]+" } \
    		 /^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { sub(/[ \t]*#.*$$/, "");\
    			   printf ":%s/%s ", $$1, $$3; print; \
    			   printf ":%s/ ", $$1; print; \
    			   printf "=%s/%s ", $$2, $$3; print; \
    			   printf "=%s/ ", $$2; print; \
    			   for (i = 4; i <= NF && !($$i ~ /^#/); ++i) \
    			     { printf ":%s/%s ", $$i, $$3; print; \
    			       printf ":%s/ ", $$i; print } }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    $(VAR_DB)/shadow.db: /etc/shadow
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) 'BEGIN { FS=":"; OFS=":" } \
    		 /^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print }' $^ | \
    	(umask 077 && $(MAKEDB) -o $@ -)
    	@echo "done."
    	@if chgrp shadow $@ 2>/dev/null; then \
    	  chmod g+r $@; \
    	else \
    	  chown 0 $@; chgrp 0 $@; chmod 600 $@; \
    	  echo; \
    	  echo "Warning: The shadow password database $@"; \
    	  echo "has been set to be readable only by root.  You may want"; \
    	  echo "to make it readable by the \`shadow' group depending"; \
    	  echo "on your configuration."; \
    	  echo; \
    	fi
    
    $(VAR_DB)/gshadow.db: /etc/gshadow
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) 'BEGIN { FS=":"; OFS=":" } \
    		 /^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { printf ".%s ", $$1; print }' $^ | \
    	(umask 077 && $(MAKEDB) -o $@ -)
    	@echo "done."
    	@if chgrp shadow $@ 2>/dev/null; then \
    	  chmod g+r $@; \
    	else \
    	  chown 0 $@; chgrp 0 $@; chmod 600 $@; \
    	  echo; \
    	  echo "Warning: The shadow group database $@"; \
    	  echo "has been set to be readable only by root.  You may want"; \
    	  echo "to make it readable by the \`shadow' group depending"; \
    	  echo "on your configuration."; \
    	  echo; \
    	fi
    
    $(VAR_DB)/netgroup.db: /etc/netgroup
    	@echo -n "$(patsubst %.db,%,$(@F))... "
    	@$(AWK) 'BEGIN { ini=1 } \
    		 /^[ \t]*$$/ { next } \
    		 /^[ \t]*#/ { next } \
    		 /^[^#]/ { if (sub(/[ \t]*\\$$/, " ") == 0) end="\n"; \
    			   else end=""; \
    			   gsub(/[ \t]+/, " "); \
    			   sub(/^[ \t]*/, ""); \
    			   if (ini == 0) printf "%s%s", $$0, end; \
    			   else printf ".%s %s%s", $$1, $$0, end; \
    			   ini=end == "" ? 0 : 1; } \
    			   END { if (ini==0) printf "\n" }' $^ | \
    	$(MAKEDB) -o $@ -
    	@echo "done."
    
    
  4. 最后将2中的文件统统删掉。上报网管中心,安装杀毒软件!至此告一段落!

posted @ 2022-04-12 21:46  壶小旭  阅读(306)  评论(0编辑  收藏  举报