使用docker搭建pwn题靶机

一,基于ubuntu制作docker image

以基于ubuntu:16.04制作一个pwn题环境为例

  1. 拉取镜像

     docker pull ubuntu:16.04
    
  2. 安装必要工具

     // start a container
     $ docker run -it ubuntu:16.04 /bin/bash
     ....
     // install some tools such as xinetd
     $ sed -i "s/http:\/\/archive.ubuntu.com/http:\/\/mirrors.aliyun.com/g" /etc/apt/sources.list
     $ apt-get update && apt-get -y dist-upgrade
     $ apt-get install -y lib32z1 xinetd build-essential python python-dev
     $ exit
     // return to host
    
  3. 打包成新的镜像

     $ docker commit CONTAINER_HASH pwn_server:16.04
    

    其中 CONTAINER_HASH 为第二步(安装必要工具)中启动的容器的 HASH

之后就可以使用 pwn_server:16.04 启动题目了,这么做有两个优点

  1. 避免每个题目都要重新build
  2. 保证所有基于16.04的pwn题的libc都相同

二,用image启动靶机

目录结构

首先新建一个目录,把题目相关文件都放在该文件夹下

➜ ls
pwn  pxi start.sh flag

其中

  • pwn 为题目 binary 文件(建议binary文件统一命名为pwn,否则需要修改 xinetd脚本)
  • pxi 为 xinetd 脚本,用于配置 pwn题服务,复制下面的模板即可
  • start.sh 为启动container时运行的脚本,复制下面的模板即可
  • flag ,将flag写入该文件中

pxi

service pwn
{
    disable = no
    socket_type = stream
    protocol    = tcp
    wait        = no
    user        = root
    type        = UNLISTED
    port        = 8888
    bind        = 0.0.0.0
    server      = /usr/sbin/chroot
    server_args = --userspec=ctf:ctf / timeout 30 ./home/ctf/pwn
    banner_fail = /etc/banner_fail

    # safety options
    per_source    = 10 # the maximum instances of this service per source IP address
    rlimit_cpu    = 60 # the maximum number of CPU seconds that the service may use
    rlimit_as     = 1024M # the Address Space resource limit for the service
    #access_times = 2:00-9:00 12:00-24:00

    #Instances   = 20 #process limit
    #per_source  = 5 #link ip limit

    #log warning die
    log_on_success  = PID HOST EXIT DURATION
    log_on_failure  = HOST ATTEMPT 
    log_type =FILE /var/log/myservice.log 8388608 15728640
}

start.sh

#!/bin/sh
useradd -m ctf
sleep 2
chmod 555 -R /home/ctf
cp /home/ctf/pxi /etc/xinetd.d/pwn
/etc/init.d/xinetd restart
trap : TERM INT; sleep infinity & wait
# /bin/sh

docker 启动命令

debug 版

这个版本用来调试题目环境。启动container之后会有一个交互式的shell,可以用来进行多种后续操作。

docker run -p $PORT:8888 -v `pwd`:/home/ctf -ti $IMAGE_NAME /bin/sh
e.g.
 docker run -p 3737:8888 -v `pwd`:/home/ctf -ti pwn_debug:16.04 /bin/bash

其中:

  • $PORT 为host端映射的端口,请自行修改
  • $IMAGE_NAME 为使用的image的名称(示例中使用的pwn_debug:16.04 是我基于 pwn_server:16.04 额外安装了vim, nc 等工具,方便调试)

release版

这个版本用来部署题目。没有shell

chmod 555 -R . && docker run --name $NAME -p $PORT:8888 -v `pwd`:/home/ctf -d $IMAGE_NAME /home/ctf/start.sh
e.g.
    **chmod 555 -R . && docker run --name vm_pwn -p 2005:8888 -v `pwd`:/home/ctf -d pwn_server:16.04 /home/ctf/start.sh

其中:

  • $NAME为container的名称,建议以题目的名称命名,方便管理
  • $PORT 为host端映射的端口,请自行修改
  • $IMAGE_NAME 为使用的image的名称(示例中使用的pwn_server:16.04 即为基于ubuntu制作的docker image)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容

  • 一、Docker 简介 Docker 两个主要部件:Docker: 开源的容器虚拟化平台Docker Hub: 用...
    R_X阅读 4,346评论 0 27
  • 五、Docker 端口映射 无论如何,这些 ip 是基于本地系统的并且容器的端口非本地主机是访问不到的。此外,除了...
    R_X阅读 1,670评论 0 7
  • docker基本概念 1. Image Definition 镜像 Image 就是一堆只读层 read-only...
    慢清尘阅读 8,669评论 1 21
  • p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 13.0px 'Helv...
    乾坤菠菜籽阅读 1,823评论 0 6
  • 爷爷奶奶 舅公 妈妈 姑姑姑父 三叔三婶 小叔小婶 大姐姐 我 程颖 大毛 小毛 吴馨悦 耀耀 17个人在一起过了...
    小小少年东尼阅读 150评论 0 0