-
Notifications
You must be signed in to change notification settings - Fork 14
setup docker
Dnomd343 edited this page Oct 16, 2021
·
3 revisions
echoIP支持Docker容器部署,在Docker Hub或Github Package可以查看已构建的镜像。
镜像可以从多个源拉取,其数据完全相同,国内用户建议首选阿里云镜像。
# Docker Hub
shell> docker pull docker.io/dnomd343/echoip
# Github Package
shell> docker pull ghcr.io/dnomd343/echoip
# 阿里云个人镜像
shell> docker pull registry.cn-shenzhen.aliyuncs.com/dnomd343/echoip
使用以下命令确认Docker环境
# 若正常输出则跳过本步
shell> docker --version
···Docker版本信息···
使用以下命令安装Docker
# RH系
shell> sudo yum update
···
# Debian系
shell> sudo apt update && sudo apt upgrade
···
# 使用Docker官方脚本安装
shell> sudo wget -qO- https://get.docker.com/ | bash
···
# 安装成功后将输出Docker版本信息
shell> docker --version
Docker version ···, build ···
启动容器并映射端口
# 映射容器服务到宿主机1601端口,容器路径可替换为上述其他源
# 如果服务器在境外,需要使用socks链路回国获取qqwry.dat文件
# 此时需要加入 -e SOCKS5_CN="···" 指定socks5接口
shell> docker run -d --restart=always --name echoip -p 1601:1601 dnomd343/echoip
# 查看容器状态
shell> docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
48d4b7a644e8 dnomd343/echoip "sh init.sh" 12 seconds ago Created echoip
容器开启后会自动拉取 qqwry.dat
离线数据库,如果网络较慢可能需要数分钟时间,期间查询信息不完整,且由于容器内部配置了Redis缓存,缓存过期前(默认为一个小时)将一直保持不完整信息,因此务必在确认数据库拉取完成后再执行查询,拉取期间可以用htop等进程管理工具查看docker内部进程,将存在以下信息
sh init.sh
|--sh /var/www/echoIP/backend/qqwryUpdate.sh
|--wget http://update.cz88.net/ip/qqwry.rar
在该进程结束后请测试以下命令确认qqwry.dat数据库是否正常
# 拉取完成
shell> curl 127.0.0.1:1601/version
echoip -> v1.4
qqwry.dat -> 2021-07-07
ipip.net -> 2019-07-03
# 拉取失败
shell> curl 127.0.0.1:1601/version
echoip -> v1.4
qqwry.dat -> --
ipip.net -> 2019-07-03
# 该情况一般出现在国外VPS上,重启容器再次拉取即可
若服务器1601端口未配置防火墙,在浏览器输入 http://服务器IP:1601/
即可访问echoIP页面。
# 测试容器是否正常工作
shell> curl 127.0.0.1:1601/8.8.8.8
···8.8.8.8的详细信息···
常用容器操作命令
# 删除容器
shell> docker rm -f echoip
···
# 列出全部镜像
shell> docker images
···
# 删除镜像
shell> docker rmi dnomd343/echoip
···
这里使用Nginx作为示例,其他Web服务原理类似。
# 进入Nginx配置目录
shell> cd /etc/nginx/conf.d
# 下载配置文件
shell> wget https://raw.githubusercontent.com/dnomd343/echoIP/master/conf/nginx/docker.conf -O ip.conf
# 修改配置文件中域名、证书、端口等信息
shell> vim ip.conf
如果你的网络无法正常访问Github,将下述内容写入配置文件亦可。
server {
listen 80;
listen [::]:80;
server_name ip.343.re; # 改为自己的域名
location / {
if ($http_user_agent !~* (curl|wget)) {
return 301 https://$server_name$request_uri;
}
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://127.0.0.1:1601;
}
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name ip.343.re; # 改为自己的域名
ssl_certificate /etc/ssl/certs/343.re/fullchain.pem; # 改为自己的证书
ssl_certificate_key /etc/ssl/certs/343.re/privkey.pem;
gzip on;
gzip_buffers 32 4K;
gzip_comp_level 6;
gzip_min_length 100;
gzip_types application/javascript text/css text/xml;
gzip_disable "MSIE [1-6]\.";
gzip_vary on;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://127.0.0.1:1601;
}
}
重启Nginx服务
shell> nginx -s reload
将配置的域名DNS解析到当前服务器,即可用该域名访问echoIP服务。