Mirai环境搭建

20200805 -

引言

关于Mirai的环境搭建,我记得能搜到很多结果。不过我当时并没有想要启动mirai的所有功能。毕竟其实他的代码也有缺陷,现在想扫出来结果也有点难了。后面可能还是需要这些功能来辅助扫描结果,其他功能还是要开启。这里先记录一个别人的搭建步骤,后面再来记录我自己的。

搭建过程

[1]他人环境搭建

在这个环境的部署过程中,需要下载很多东西,包括各种乱七八糟的东西,还有交叉编译的环境,为了获得CNC的服务器,还要有go的启动环境。我个人觉得,还是弄一个docker的环境更好。

自己的docker搭建过程

为了搭建mirai的docker环境,需要下载各种乱七八糟的库,同时因为github访问有时候也不稳定,所以mirai的源码,以及go程序需要的库也都是提前下好的。

新建文件夹

mkidr mirai
cd mirai
mkdir cross-env
mkdir go
mkdir mirai
#以下文件放置于 cross-env
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-armv4l.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-armv5l.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-i586.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-i686.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-m68k.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-mips.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-mipsel.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-powerpc.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-sh4.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-sparc.tar.bz2
https://www.uclibc.org/downloads/binaries/0.9.30.1/cross-compiler-x86_64.tar.bz2
http://distro.ibiblio.org/slitaz/sources/packages/c/cross-compiler-armv6l.tar.bz2
#以下文件放置于go
https://dl.google.com/go/go1.14.7.linux-amd64.tar.gz
https://codeload.github.com/go-sql-driver/mysql/zip/master
https://codeload.github.com/mattn/go-shellwords/zip/maste
#以下文件放置于mirai
https://codeload.github.com/jgamblin/Mirai-Source-Code/zip/master

编写Dockerfile

FROM centos:7
ADD go/go1.14.7.linux-amd64.tar.gz /usr/local/

ADD cross-env/cross-compiler-armv4l.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-armv5l.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-armv6l.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-i586.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-m68k.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-mips.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-mipsel.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-powerpc.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-sh4.tar.bz2 /etc/xcompile/
ADD cross-env/cross-compiler-sparc.tar.bz2 /etc/xcompile/

COPY go/go-shellwords-master.zip /root/mirai/go/
COPY go/mysql-master.zip /root/mirai/go/
COPY mirai/Mirai-Source-Code-master.zip /root/mirai/
ENV GOPATH /root/go/
ENV GOHOME /usr/local/go
ENV PATH $GOHOME/bin/:$PATH

RUN cd /root/ && \
    yum install -y unzip && \
    mkdir -p /root/go/{bin,pkg,src} && \ 
    mkdir -p /root/go/src/github.com/go-sql-driver && \
    mkdir -p /root/go/src/github.com/mattn && \
    unzip mirai/go/mysql-master.zip -d /root/go/src/github.com/go-sql-driver && \
    unzip mirai/go/go-shellwords-master.zip -d /root/go/src/github.com/mattn && \
    cd /root/go/src/github.com/go-sql-driver && mv mysql-master mysql && \
    cd /root/go/src/github.com/mattn && mv go-shellwords-master go-shellwords  && \
    yum -y install gcc git bzip2 mysql-server mysql mysql-devel glibc-static ElectricFence  && \
    cd /root/mirai/ && unzip Mirai-Source-Code-master.zip && \
    mv Mirai-Source-Code-master Mirai-Source-Code 
    
ENV PATH $PATH:/etc/xcompile/cross-compiler-armv4l/bin:/etc/xcompile/cross-compiler-armv5l/bin:/etc/xcompile/cross-compiler-armv6l/bin:/etc/xcompile/cross-compiler-i586/bin:/etc/xcompile/cross-compiler-m68k/bin:/etc/xcompile/cross-compiler-mips/bin:/etc/xcompile/cross-compiler-mipsel/bin:/etc/xcompile/cross-compiler-powerpc/bin:/etc/xcompile/cross-compiler-sh4/bin:/etc/xcompile/cross-compiler-sparc/bin

WORKDIR /root/mirai/Mirai-Source-Code

构建镜像

mirai路径下,执行命令构建镜像。

docker build -t mirai:base .

完成后,即可构建一个mirai:base的镜像供使用。

参考文章

[1] Mirai-botnet 环境搭建步骤

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
官网下载的tar.gz包,亲测可用! tar -c: 建立压缩档案 -x:解压 -t:查看内容 -r:向压缩归档文件末尾追加文件 -u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个。下面的参数是根据需要在压缩或解压档案时可选的。 -z:有gzip属性的 -j:有bz2属性的 -Z:有compress属性的 -v:显示所有过程 -O:将文件解开到标准输出 下面的参数-f是必须的 -f: 使用档案名字,切记,这个参数是最后一个参数,后面只能接档案名。 # tar -cf all.tar *.jpg 这条命令是将所有.jpg的文件打成一个名为all.tar的包。-c是表示产生新的包,-f指定包的文件名。 # tar -rf all.tar *.gif 这条命令是将所有.gif的文件增加到all.tar的包里面去。-r是表示增加文件的意思。 # tar -uf all.tar logo.gif 这条命令是更新原来tar包all.tar中logo.gif文件,-u是表示更新文件的意思。 # tar -tf all.tar 这条命令是列出all.tar包中所有文件,-t是列出文件的意思 # tar -xf all.tar 这条命令是解出all.tar包中所有文件,-x是解开的意思 压缩 tar –cvf jpg.tar *.jpg //将目录里所有jpg文件打包成tar.jpg tar –czf jpg.tar.gz *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用gzip压缩,生成一个gzip压缩过的包,命名为jpg.tar.gz tar –cjf jpg.tar.bz2 *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用bzip2压缩,生成一个bzip2压缩过的包,命名为jpg.tar.bz2 tar –cZf jpg.tar.Z *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用compress压缩,生成一个umcompress压缩过的包,命名为jpg.tar.Z rar a jpg.rar *.jpg //rar格式的压缩,需要先下载rar for Linux zip jpg.zip *.jpg //zip格式的压缩,需要先下载zip for linux 解压 tar –xvf file.tar //解压 tar包 tar -xzvf file.tar.gz //解压tar.gz tar -xjvf file.tar.bz2 //解压 tar.bz2 tar –xZvf file.tar.Z //解压tar.Z unrar e file.rar //解压rar unzip file.zip //解压zip 总结 1、*.tar 用 tar –xvf 解压 2、*.gz 用 gzip -d或者gunzip 解压 3、*.tar.gz和*.tgz 用 tar –xzf 解压 4、*.bz2 用 bzip2 -d或者用bunzip2 解压 5、*.tar.bz2用tar –xjf 解压 6、*.Z 用 uncompress 解压 7、*.tar.Z 用tar –xZf 解压 8、*.rar 用 unrar e解压 9、*.zip 用 unzip 解压

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值