This commit is contained in:
Leon 2021-08-04 11:30:00 +08:00 committed by GitHub
parent 84e6b32f24
commit a81f5e199a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -35,7 +35,7 @@ ENABLE_WEB_PANEL_ENV="--env ENABLE_WEB_PANEL=true"
log() {
echo -e "\e[32m$1 \e[0m\n"
echo -e "\e[32m\n$1 \e[0m\n"
}
inp() {
@ -43,12 +43,12 @@ inp() {
}
warn() {
echo -e "\e[31m$1 \e[0m\n"
echo -e "\e[31m\n$1 \e[0m\n"
}
cancelrun() {
if [ $# -gt 0 ]; then
echo "\e[31m $1 \e[0m"
echo -e "\e[31m $1 \e[0m"
fi
exit 1
}
@ -56,9 +56,9 @@ cancelrun() {
docker_install() {
echo "检测 Docker......"
if [ -x "$(command -v docker)" ]; then
echo "检测到 Docker 已安装!"
echo "检测到 Docker 已安装!"
else
if [ -r /etc/os-release ]; then
if [ -r /etc/os-release ]; then
lsb_dist="$(. /etc/os-release && echo "$ID")"
fi
if [ $lsb_dist == "openwrt" ]; then
@ -76,8 +76,8 @@ docker_install() {
# 配置文件保存目录
docker_install
warn "\n降低学习成本,小白回车到底,一路默认选择"
echo -n -e "\e[33m\n一、请输入配置文件保存的绝对路径(示例:/root),回车默认为当前目录:\e[0m"
warn "降低学习成本,小白回车到底,一路默认选择"
echo -n -e "\e[33m一、请输入配置文件保存的绝对路径(示例:/root),回车默认为当前目录:\e[0m"
read jd_path
if [ -z "$jd_path" ]; then
JD_PATH=$SHELL_FOLDER
@ -100,7 +100,7 @@ NINJA_PATH=$JD_PATH/ql/ninja
if [ ! -z "$(docker images -q $DOCKER_IMG_NAME:$TAG 2> /dev/null)" ]; then
HAS_IMAGE=true
OLD_IMAGE_ID=$(docker images -q --filter reference=$DOCKER_IMG_NAME:$TAG)
inp "\n检测到先前已经存在的镜像,是否拉取最新的镜像:\n1) 拉取[默认]\n2) 不拉取"
inp "检测到先前已经存在的镜像,是否拉取最新的镜像:\n1) 拉取[默认]\n2) 不拉取"
echo -n -e "\e[36m输入您的选择->\e[0m"
read update
if [ "$update" = "2" ]; then
@ -112,7 +112,7 @@ fi
check_container_name() {
if [ ! -z "$(docker ps -a | grep $CONTAINER_NAME 2> /dev/null)" ]; then
HAS_CONTAINER=true
inp "\n检测到先前已经存在的容器,是否删除先前的容器:\n1) 删除[默认]\n2) 不删除"
inp "检测到先前已经存在的容器,是否删除先前的容器:\n1) 删除[默认]\n2) 不删除"
echo -n -e "\e[36m输入您的选择->\e[0m"
read update
if [ "$update" = "2" ]; then
@ -137,65 +137,65 @@ input_container_name() {
input_container_name
# 是否安装 WatchTower
inp "\n是否安装 containrrr/watchtower 自动更新 Docker 容器:\n1) 安装\n2) 不安装[默认]"
inp "是否安装 containrrr/watchtower 自动更新 Docker 容器:\n1) 安装\n2) 不安装[默认]"
echo -n -e "\e[36m输入您的选择->\e[0m"
read watchtower
if [ "$watchtower" = "1" ]; then
INSTALL_WATCH=true
fi
inp "\n请选择容器的网络类型:\n1) host[默认]\n2) bridge"
inp "请选择容器的网络类型:\n1) host[默认]\n2) bridge"
echo -n -e "\e[36m输入您的选择->\e[0m"
read net
if [ "$net" = "2" ]; then
NETWORK="bridge"
fi
inp "\n是否在启动容器时自动启动挂机程序:\n1) 开启[默认]\n2) 关闭"
inp "是否在启动容器时自动启动挂机程序:\n1) 开启[默认]\n2) 关闭"
echo -n -e "\e[36m输入您的选择->\e[0m"
read hang_s
if [ "$hang_s" = "2" ]; then
ENABLE_HANGUP_ENV=""
fi
inp "\n是否启用青龙面板:\n1) 启用[默认]\n2) 不启用"
inp "是否启用青龙面板:\n1) 启用[默认]\n2) 不启用"
echo -n -e "\e[36m输入您的选择->\e[0m"
read pannel
if [ "$pannel" = "2" ]; then
ENABLE_WEB_PANNEL_ENV=""
fi
inp "\n根据设备是否映射端口:\n1) 映射[默认]\n2) 不映射"
inp "根据设备是否映射端口:\n1) 映射[默认]\n2) 不映射"
echo -n -e "\e[36m输入您的选择->\e[0m"
read port
#配置已经创建完成,开始执行
log "\n1.开始创建配置文件目录"
log "1.开始创建配置文件目录"
PATH_LIST=($CONFIG_PATH $DB_PATH $REPO_PATH $RAW_PATH $SCRIPT_PATH $LOG_PATH $JBOT_PATH $NINJA_PATH)
for i in ${PATH_LIST[@]}; do
mkdir -p $i
done
if [ $HAS_CONTAINER = true ] && [ $DEL_CONTAINER = true ]; then
log "\n2.1.删除先前的容器"
log "2.1.删除先前的容器"
docker stop $CONTAINER_NAME >/dev/null
docker rm $CONTAINER_NAME >/dev/null
fi
if [ $HAS_IMAGE = true ] && [ $PULL_IMAGE = true ]; then
if [ ! -z "$OLD_IMAGE_ID" ] && [ $HAS_CONTAINER = true ] && [ $DEL_CONTAINER = true ]; then
log "\n2.2.删除旧的镜像"
log "2.2.删除旧的镜像"
docker image rm $OLD_IMAGE_ID
fi
log "\n2.3.开始拉取最新的镜像"
log "2.3.开始拉取最新的镜像"
docker pull $DOCKER_IMG_NAME:$TAG
if [ $? -ne 0 ] ; then
cancelrun "** 错误: 拉取不到镜像!"
fi
fi
log "\n3.开始创建容器并执行"
log "3.开始创建容器并执行"
run_port(){
docker run -dit \
@ -273,7 +273,7 @@ if [ $? -ne 0 ] ; then
fi
if [ $INSTALL_WATCH = true ]; then
log "\n3.1.开始创建容器并执行"
log "3.1.开始创建容器并执行"
docker run -d \
--name watchtower \
--restart always \
@ -291,11 +291,11 @@ if [ ! -f "$CONFIG_PATH/config.sh" ]; then
fi
fi
log "\n4.下面列出所有容器"
log "4.下面列出所有容器"
docker ps
# Nginx 静态解析检测
log "\n5.开始检测 Nginx 静态解析"
log "5.开始检测 Nginx 静态解析"
echo "开始扫描静态解析是否在线!"
ps -fe|grep nginx|grep -v grep
if [ $? -ne 0 ]; then
@ -307,41 +307,41 @@ else
fi
if [ "$port" = "2" ]; then
log "\n6.安装已完成,请自行调整端口映射并进入面板一次以便进行内部配置"
log "6.安装已完成,请自行调整端口映射并进入面板一次以便进行内部配置"
else
log "\n6.安装已完成,请进入面板一次以便进行内部配置"
log "\n6.1.用户名和密码已显示,请登录 ip:5700"
log "6.安装已完成,请进入面板一次以便进行内部配置"
log "6.1.用户名和密码已显示,请登录 ip:5700"
cat $CONFIG_PATH/auth.json
fi
# 防止 CPU 占用过高导致死机
echo -e "\n---------- 机器累了,休息 20s趁机去操作一下吧 ----------"
echo -e "---------- 机器累了,休息 20s趁机去操作一下吧 ----------"
sleep 20
# 显示 auth.json
inp "\n是否显示被修改的密码:\n1) 显示[默认]\n2) 不显示"
inp "是否显示被修改的密码:\n1) 显示[默认]\n2) 不显示"
echo -n -e "\e[36m输入您的选择->\e[0m"
read display
if [ "$display" != "2" ]; then
cat $CONFIG_PATH/auth.json
log "\n6.2.用被修改的密码登录面板并进入"
log "6.2.用被修改的密码登录面板并进入"
fi
# token 检测
inp "\n是否已进入面板:\n1) 进入[默认]\n2) 未进入"
inp "是否已进入面板:\n1) 进入[默认]\n2) 未进入"
echo -n -e "\e[36m输入您的选择->\e[0m"
read access
log "\n6.3.观察 token 是否成功生成"
log "6.3.观察 token 是否成功生成"
cat $CONFIG_PATH/auth.json
if [ "$access" != "2" ]; then
if [ "$(grep -c "token" $CONFIG_PATH/auth.json)" != 0 ]; then
log "\n7.开始青龙内部配置"
log "7.开始青龙内部配置"
docker exec -it $CONTAINER_NAME bash -c "$(curl -fsSL https://gitee.com/allin1code/a1/raw/master/1customCDN.sh)"
else
warn "\n7.未检测到 token取消内部配置"
warn "7.未检测到 token取消内部配置"
fi
else
exit 0
fi
log "全面部署已完成enjoy!!!"
log "全面部署已完成enjoy!!!"