CTF-Web安全

Docker使用及部署CTF题目

2019-07-14  本文已影响7人  简言之_
image

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

docker安装

docker常用命令

docker pull [OPTIONS] NAME[:TAG|@DIGEST]
    从Docker Hub下载java最新版镜像。
    docker pull java
    
    从Docker Hub下载REPOSITORY为java的所有镜像。
    docker pull -a java```
docker build [options] path | url | - .(最后的点不能丢)
eg:docker build -t warmup .
eg: docker build -f /path/to/a/Dockerfile .
eg: docker build github.com/creack/docker-firefox
docker run [options] [host port]:[docker port] [image]
用到的option: -d 后台运行
               -P 随机把容器的端口映射到一个主机未使用的高端口
               -p 格式为主机端口:容器端口 ,自选端口映射
               -i  以交互模式运行容器,常与-t连用
               -t  为容器重新分配一个伪输入终端,常与-i连用
eg:docker run -i -d -P warmup 
eg: docker run -d -p 100:80 -p 32768:80 warmup
docker images 或者 docker image ls
docker ps
docker start [container id]
docker stop  [container id]
docker rm [container id]
docker cp  dest_path [container id]:container_path ##主机cp到容器
docker cp  [container id]:container_path dest_path ##容器cp到主机
将主机/www/runoob目录拷贝到容器96f7f14e99ab的/www目录下
docker cp /www/runoob 96f7f14e99ab:/www/

 将容器96f7f14e99ab的/www目录拷贝到主机的/tmp目录中
docker cp 96f7f14e99ab:/www /tmp/

 将主机/www/runoob目录拷贝到容器96f7f14e99ab中,目录重命名为www
docker cp /www/runoob 96f7f14e99ab:/www

docker部署CTF题目

由于要部署web题,所以选择了一个apache-php5

docker pull registry.cn-hangzhou.aliyuncs.com/lxepoo/apache-php5

然后运行镜像,并绑定一下端口。

docker run -d -p 8085:80 registry.cn-hangzhou.aliyuncs.com/lxepoo/apache-php5

此时会返回一个值,表示该运行docker的id。以后如果想访问这个容器,需要通过该id。
也可通过docker ps查看正在运行的容器,得到容器id

然后将本地源码文件拷贝到docker,使用docker的cp命令(在id前几位没有重复的情况下,可以取前几位。)
docker cp ./ f7d233:/var/www/
docker exec -it f7d233 bash

    -d :分离模式: 在后台运行
    -i :即使没有附加也保持STDIN 打开
    -t :分配一个伪终端
Ctrl+p+q

参考:
菜鸟教程-Docker 命令大全
通过docker部署ctf题目
记docker复现CTF题的一次流程

上一篇下一篇

猜你喜欢

热点阅读