背景
CTFd是时下比较流行的CTF平台,其安装和部署也是比较容易。虽然facebookCTF界面够炫够酷,但是其太吃资源。相对来讲CTFd页面简约流畅,于是选择自己搭建CTFd来折腾一番。
准备
本次环境搭建使用的是阿里云的ECS,ubuntu16.04 64位。
开工
1、安装git
sudo apt-get install git
2、安装pip
sudo apt-get install python-pip
3、安装Flask
sudo pip install Flask
4、下载CTFd
进入/var/www目录
sudo git clone https://github.com/isislab/CTFd.git
5、安装CTFd
cd CTFd
sudo ./prepare.sh
6、修改CTFd
执行完第5步后所需的依赖应该都已经安装好了。先别急着运行CTFd。先修改CTFd/config.py文件,对数据库进行相关的设置(这里以MYSQL为例)
7、mysql设置
进入mysql,新建一个ctfd数据库
create datebase ctfd;
exit;
8、运行CTFd
sudo python serve.py
运行后,别忙着设置,先退出
9、设置ctfd数据库字段,防止字符乱码
再次进入mysql数据库,输入下面的命令:
use ctfd;
ALTER TABLE awards CONVERT TO CHARACTER SET utf8;
ALTER TABLE challenges CONVERT TO CHARACTER SET utf8;
ALTER TABLE config CONVERT TO CHARACTER SET utf8;
ALTER TABLE containers CONVERT TO CHARACTER SET utf8;
ALTER TABLE files CONVERT TO CHARACTER SET utf8;
ALTER TABLE keys CONVERT TO CHARACTER SET utf8;
ALTER TABLE pages CONVERT TO CHARACTER SET utf8;
ALTER TABLE solves CONVERT TO CHARACTER SET utf8;
ALTER TABLE tags CONVERT TO CHARACTER SET utf8;
ALTER TABLE teams CONVERT TO CHARACTER SET utf8;
ALTER TABLE tracking CONVERT TO CHARACTER SET utf8;
ALTER TABLE wrong_keys CONVERT TO CHARACTER SET utf8;
10、开始运行
sudo python serve.py
部署(正戏开始~)
完成以上步骤只是在本地搭起服务器,要是想在公网访问,还需要安装gunicorn。
1、pip install gunicorn
2、sudo gunicorn --bind 0.0.0.0:8000 - w 4 "CTFd:create_app()"
此时在浏览器访问你的服务器公网ip:4000就可以进入平台了
但是这样运行起来性能还是不好,所以我采用了nginx+uwsgi的方法来提高性能
首先安装nginx和uwsgi
apt-get install nginx
pip install uwsgi
修改/etc/nginx/nginx.conf配置
server {
listen 80;
server_name 公网IP;
location / {
include uwsgi_params;
uwsgi_pass unix:/tmp/uwsgi.sock;
}
修改/var/www/CTFd/ctfd.ini文件配置
[uwsgi]
# Where you've put CTFD
chdir = /var/www/ctfd/
之后进入/var/www/CTFd目录,运行
uwsgi -s /tmp/uwsgi.sock --chmod-socket=666 -w 'CTFd:create_app()'
然后在浏览器访问你的公网IP,应该就OK了。
自定义
你可以自己修改网站的logo、管理页面的配置,总之能做的事情有很多。
文章到这里就结束了,希望可以帮到有需要的人~
参考文献
https://github.com/CTFd/CTFd/wiki/Deployment
http://flask.pocoo.org/docs/0.10/deploying/uwsgi/#configuring-nginx