Compare commits

...

19 Commits
main ... fnos

Author SHA1 Message Date
xiao
e1ec3116cb feat: 新增根据环境变量修改用户名和密码的函数 2025-02-25 16:27:08 +08:00
xiao
37bcbde669 feat: 添加 iproute2 支持ip命令 2025-01-09 12:02:51 +08:00
xiao
b92545114d Update timestamp format in backup_database function for bt.sh scripts 2025-01-07 16:07:52 +08:00
xiao
14fe50fa2d 合并来自 nas-dev 的合并请求 #1
Update Dockerfiles to use Tencent Cloud PyPI mirror for faster pip installations
PR-URL: #1
2025-01-07 15:15:57 +08:00
xiao
e294fcbfbd 更新流水线 2025-01-07 15:15:07 +08:00
xiao
775f65d396 Update Dockerfiles to use Tencent Cloud PyPI mirror for faster pip installations 2025-01-07 12:17:40 +08:00
xiao
23721bd337 fix: update database backup directory check path in bt.sh scripts 2025-01-07 12:13:24 +08:00
xiao
1f0da1cb82 Add database backup function to bt.sh script 2025-01-07 11:11:47 +08:00
xiao
f54e0a9e41 chore: 更新 Dockerfile 中的宝塔面板打包命令 2025-01-06 14:03:09 +08:00
xiao
7e0a57ab0a 优化 bt.sh 脚本:增加对 /www 目录及其子目录的检查,确保数据恢复操作的正确性 2025-01-06 12:11:08 +08:00
xiao
961cd9a6d2 Update Docker image tags and build process for NAS development support 2025-01-06 09:30:38 +08:00
xiao
6495238639 refactor: 更新 Dockerfile 以使用更小的基础镜像并暴露特定端口 2024-12-21 09:17:17 +08:00
xiao
2a1994a6dc Update show_menu.json to include 'memuAwp' and maintain consistency across Dockerfile architectures 2024-12-17 10:22:39 +08:00
xiao
85b6be2b00 chore: 修复并完善 .cnb.yml 中的多架构构建和推送配置 2024-12-17 10:09:36 +08:00
xiao
7d403c5292 refactor: 优化 Dockerfile 以使用腾讯云源并简化安装和配置过程 2024-12-16 12:15:49 +08:00
xiao
33ed7d1791 refactor: 优化 Dockerfile 以简化安装和配置过程 2024-12-16 12:04:02 +08:00
xiao
7f46e1d7a9 docs:nas 2024-12-16 11:51:58 +08:00
xiao
a83ced9796 chore: 启用 Docker 镜像推送功能 2024-12-16 11:28:14 +08:00
xiao
3f9c6bf406 Update Docker image tags and build process for NAS support 2024-12-16 11:27:07 +08:00
6 changed files with 278 additions and 32 deletions

View File

@ -12,7 +12,7 @@ $:
- docker - docker
imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
env: env:
IMAGE_TAG: btpanel/baota:latest-linux-amd64 IMAGE_TAG: btpanel/baota:fnnas-linux-amd64
stages: stages:
- name: docker login - name: docker login
script: docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWD" script: docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWD"
@ -31,12 +31,12 @@ $:
- docker - docker
imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
env: env:
IMAGE_TAG: btpanel/baota:latest-linux-arm64 IMAGE_TAG: btpanel/baota:f n na s-linux-arm64
stages: stages:
- name: docker login - name: docker login
script: docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWD" script: docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWD"
- name: docker build - name: docker build
script: docker build -t ${IMAGE_TAG} . script: docker build -t ${IMAGE_TAG} -f ./arm64/Dockerfile ./arm64
- name: docker push - name: docker push
script: docker push ${IMAGE_TAG} script: docker push ${IMAGE_TAG}
- name: resolve - name: resolve
@ -48,7 +48,7 @@ $:
- docker - docker
imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
env: env:
IMAGE_TAG: btpanel/baota:latest IMAGE_TAG: btpanel/baota:fnnas
stages: stages:
- name: await the amd64 - name: await the amd64
type: cnb:await type: cnb:await
@ -83,7 +83,7 @@ $:
services: services:
- docker - docker
env: env:
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest-linux-amd64 IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:fnnas-linux-amd64
stages: stages:
- name: docker login - name: docker login
script: docker login -u ${CNB_TOKEN_USER_NAME} -p "${CNB_TOKEN}" ${CNB_DOCKER_REGISTRY} script: docker login -u ${CNB_TOKEN_USER_NAME} -p "${CNB_TOKEN}" ${CNB_DOCKER_REGISTRY}
@ -101,12 +101,12 @@ $:
services: services:
- docker - docker
env: env:
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest-linux-arm64 IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:fnnas-linux-arm64
stages: stages:
- name: docker login - name: docker login
script: docker login -u ${CNB_TOKEN_USER_NAME} -p "${CNB_TOKEN}" ${CNB_DOCKER_REGISTRY} script: docker login -u ${CNB_TOKEN_USER_NAME} -p "${CNB_TOKEN}" ${CNB_DOCKER_REGISTRY}
- name: docker build - name: docker build
script: docker build -t ${IMAGE_TAG} . script: docker build -t ${IMAGE_TAG} -f ./arm64/Dockerfile ./arm64
- name: docker push - name: docker push
script: docker push ${IMAGE_TAG} script: docker push ${IMAGE_TAG}
- name: resolve - name: resolve
@ -120,7 +120,7 @@ $:
services: services:
- docker - docker
env: env:
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:fnnas
stages: stages:
- name: await the amd64 - name: await the amd64
type: cnb:await type: cnb:await
@ -145,6 +145,6 @@ $:
options: options:
name: ${CNB_REPO_NAME} name: ${CNB_REPO_NAME}
tags: tags:
- latest-linux-amd64 - fnnas-linux-amd64
- latest-linux-arm64 - fnnas-linux-arm64
type: docker type: docker

View File

@ -1,17 +1,12 @@
FROM debian:bookworm FROM debian:bookworm-slim
# 切换 Debian 镜像源为腾讯云源,更新包列表并安装依赖 # 切换 Debian 镜像源为腾讯云源,更新包列表并安装依赖
RUN sed -i 's/deb.debian.org/mirrors.tencent.com/g' /etc/apt/sources.list.d/debian.sources \ RUN sed -i 's/deb.debian.org/mirrors.tencent.com/g' /etc/apt/sources.list.d/debian.sources \
&& apt update && apt upgrade -y \ && apt update && apt upgrade -y \
&& apt install -y \ && apt install -y \
locales \ locales \
wget iproute2 openssh-server libgd-dev cmake make gcc g++ autoconf \ wget iproute2 openssh-server cmake make gcc g++ autoconf sudo curl dos2unix build-essential \
libsodium-dev libonig-dev libssh2-1-dev libc-ares-dev libaio-dev sudo curl dos2unix \ && apt autoremove -y \
build-essential re2c cron bzip2 libzip-dev libc6-dev bison file rcconf flex vim m4 gawk less cpp binutils \
diffutils unzip tar libbz2-dev libncurses5 libncurses5-dev libtool libevent-dev libssl-dev libsasl2-dev \
libltdl-dev zlib1g-dev libglib2.0-0 libglib2.0-dev libkrb5-dev libpq-dev libpq5 gettext libcap-dev \
libc-client2007e-dev psmisc patch git e2fsprogs libxslt1-dev xz-utils libgd3 libwebp-dev libvpx-dev \
libfreetype6-dev libjpeg62-turbo libjpeg62-turbo-dev iptables libudev-dev libldap2-dev \
&& apt clean \ && apt clean \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
@ -21,14 +16,20 @@ COPY ["bt.sh", "init_mysql.sh", "/"]
# 转换启动脚本 # 转换启动脚本
RUN dos2unix /bt.sh && dos2unix /init_mysql.sh RUN dos2unix /bt.sh && dos2unix /init_mysql.sh
# 下载并安装宝塔面板及 lnmp 环境 # 下载并安装宝塔面板及 nginx
RUN curl -sSO https://download.bt.cn/install/install_panel.sh \ RUN curl -sSO https://download.bt.cn/install/install_panel.sh \
&& echo y | bash install_panel.sh -P 8888 --ssl-disable \ && echo y | bash install_panel.sh -P 8888 --ssl-disable \
&& rm -rf /www/server/data/* \ && btpip config set global.index-url https://mirrors.tencent.com/pypi/simple \
&& echo "docker_bt_d12" > /www/server/panel/data/o.pl \ && mkdir /lnmp \
&& echo '["memuA", "memuAsite", "memuAdatabase", "memuAcontrol", "memuAfiles", "memuAlogs", "memuAxterm", "memuAcrontab", "memuAsoft", "memuAconfig", "dologin", "memu_btwaf", "memuAssl"]' > /www/server/panel/config/show_menu.json \ && curl -o /lnmp/nginx.sh https://download.bt.cn/install/3/nginx.sh \
&& bash /lnmp/nginx.sh install 1.27 \
&& rm -rf /lnmp \
&& rm -rf /www/server/nginx/src \
&& echo "docker_bt_fnnas" > /www/server/panel/data/o.pl \
&& echo '["memuA", "memuAsite", "memuAwp", "memuAdatabase", "memuAcontrol", "memuAfiles", "memuAlogs", "memuAxterm", "memuAcrontab", "memuAsoft", "memuAconfig", "dologin", "memu_btwaf", "memuAssl"]' > /www/server/panel/config/show_menu.json \
&& apt clean \ && apt clean \
&& rm -rf /var/lib/apt/lists/* \ && rm -rf /var/lib/apt/lists/* \
&& rm -rf /www/reserve_space.pl \
&& chmod +x /bt.sh \ && chmod +x /bt.sh \
&& chmod +x /init_mysql.sh && chmod +x /init_mysql.sh
@ -39,10 +40,15 @@ RUN echo btpanel | bt 6 \
&& echo "/btpanel" > /www/server/panel/data/admin_path.pl \ && echo "/btpanel" > /www/server/panel/data/admin_path.pl \
&& echo "root:btpaneldocker" | chpasswd && echo "root:btpaneldocker" | chpasswd
# 打包宝塔面板并清除www
RUN bt 2 \
&& tar -zcf /www.tar.gz /www \
&& rm -rf /www
ENTRYPOINT ["/bin/sh","-c","/bt.sh"] ENTRYPOINT ["/bin/sh","-c","/bt.sh"]
# 暴漏所有端口 # 暴漏特定端口
EXPOSE 0-65535 EXPOSE 22 80 443 888 3306 8888
# 健康检查 # 健康检查
HEALTHCHECK --interval=5s --timeout=3s CMD prot="http"; if [ -f "/www/server/panel/data/ssl.pl" ]; then prot="https"; fi; curl -k -i $prot://127.0.0.1:$(cat /www/server/panel/data/port.pl)$(cat /www/server/panel/data/admin_path.pl) | grep -E '(200|404)' || exit 1 HEALTHCHECK --interval=5s --timeout=3s CMD prot="http"; if [ -f "/www/server/panel/data/ssl.pl" ]; then prot="https"; fi; curl -k -i $prot://127.0.0.1:$(cat /www/server/panel/data/port.pl)$(cat /www/server/panel/data/admin_path.pl) | grep -E '(200|404)' || exit 1

53
arm64/Dockerfile Normal file
View File

@ -0,0 +1,53 @@
FROM debian:bookworm
# 切换 Debian 镜像源为腾讯云源,更新包列表并安装依赖
RUN sed -i 's/deb.debian.org/mirrors.tencent.com/g' /etc/apt/sources.list.d/debian.sources \
&& apt update && apt upgrade -y \
&& apt install -y \
locales \
wget openssh-server cmake make gcc g++ autoconf sudo curl dos2unix build-essential \
&& apt autoremove -y \
&& apt clean \
&& rm -rf /var/lib/apt/lists/*
# 复制脚本
COPY ["bt.sh", "init_mysql.sh", "/"]
# 转换启动脚本
RUN dos2unix /bt.sh && dos2unix /init_mysql.sh
# 下载并安装宝塔面板及 lnmp 环境
RUN curl -sSO https://download.bt.cn/install/install_panel.sh \
&& echo y | bash install_panel.sh -P 8888 --ssl-disable \
&& btpip config set global.index-url https://mirrors.tencent.com/pypi/simple \
&& mkdir /lnmp \
&& curl -o /lnmp/nginx.sh https://download.bt.cn/install/3/nginx.sh \
&& bash /lnmp/nginx.sh install openresty \
&& rm -rf /lnmp \
&& rm -rf /www/server/nginx/src \
&& echo "docker_bt_nas" > /www/server/panel/data/o.pl \
&& echo '["memuA", "memuAsite", "memuAwp", "memuAdatabase", "memuAcontrol", "memuAfiles", "memuAlogs", "memuAxterm", "memuAcrontab", "memuAsoft", "memuAconfig", "dologin", "memu_btwaf", "memuAssl"]' > /www/server/panel/config/show_menu.json \
&& apt clean \
&& rm -rf /var/lib/apt/lists/* \
&& rm -rf /www/reserve_space.pl \
&& chmod +x /bt.sh \
&& chmod +x /init_mysql.sh
# 配置宝塔面板安全入口和用户名及密码,以及 SSH 密码
RUN echo btpanel | bt 6 \
&& echo btpaneldocker | bt 5 \
&& echo "/btpanel" > /www/server/panel/data/admin_path.pl \
&& echo "root:btpaneldocker" | chpasswd
# 打包宝塔面板并清除www
RUN tar -zcf /www.tar.gz /www \
&& rm -rf /www
ENTRYPOINT ["/bin/sh","-c","/bt.sh"]
# 暴漏所有端口
EXPOSE 0-65535
# 健康检查
HEALTHCHECK --interval=5s --timeout=3s CMD prot="http"; if [ -f "/www/server/panel/data/ssl.pl" ]; then prot="https"; fi; curl -k -i $prot://127.0.0.1:$(cat /www/server/panel/data/port.pl)$(cat /www/server/panel/data/admin_path.pl) | grep -E '(200|404)' || exit 1

97
arm64/bt.sh Normal file
View File

@ -0,0 +1,97 @@
#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
init_path=/etc/init.d
Root_Path=`cat /var/bt_setupPath.conf`
Setup_Path=$Root_Path/server/mysql
Data_Path=$Root_Path/server/data
O_pl=$(cat /www/server/panel/data/o.pl)
backup_database() {
if [ -d "${Data_Path}" ] && [ ! -z "$(ls -A ${Data_Path})" ]; then
if [ ! -d "${Setup_Path}" ] || [ -z "$(ls -A ${Setup_Path})" ]; then
timestamp=$(date +"%s")
tar czf /www/server/data_backup_$timestamp.tar.gz -C ${Data_Path} .
fi
fi
}
restore_panel_data() {
if [ -f /www.tar.gz ]; then
if [ ! -d /www ] || [ -z "$(ls -A /www)" ] || [ ! -d /www/server/panel ] || [ -z "$(ls -A /www/server/panel)" ] || [ ! -d /www/server/panel/pyenv ] || [ -z "$(ls -A /www/server/panel/pyenv)" ]; then
tar xzf /www.tar.gz -C / --skip-old-files
rm -rf /www.tar.gz
fi
fi
}
soft_start(){
# 扫描并启动所有服务
init_scripts=$(ls ${init_path})
for script in ${init_scripts}; do
case "${script}" in
"bt"|"mysqld"|"nginx"|"httpd")
continue
;;
esac
${init_path}/${script} start
done
if [ -f ${init_path}/nginx ]; then
${init_path}/nginx start
elif [ -f ${init_path}/httpd ]; then
${init_path}/httpd start
fi
${init_path}/bt stop
${init_path}/bt start
pkill crond
/sbin/crond
chmod 600 /etc/ssh/ssh_host_*
/usr/sbin/sshd -D &
}
init_mysql(){
if [ "${O_pl}" != "docker_btlamp_nas" ] && [ "${O_pl}" != "docker_btlnmp_nas" ];then
return
fi
if [ -d "${Data_Path}" ]; then
check_z=$(ls "${Data_Path}")
echo "check_z:"
echo ${check_z}
if [[ ! -z "${check_z}" ]]; then
echo "check_z is not empty"
return
fi
fi
if [ -f /init_mysql.sh ] && [ -d "${Setup_Path}" ];then
bash /init_mysql.sh
rm -f /init_mysql.sh
fi
}
is_empty_Data(){
return "$(ls -A ${Data_Path}/|wc -w)"
}
start_mysql(){
if [ -d "${Setup_Path}" ] && [ -f "${init_path}/mysqld" ];then
chown -R mysql:mysql ${Data_Path}
chgrp -R mysql ${Setup_Path}/.
${init_path}/mysqld start
fi
}
restore_panel_data > /dev/null
backup_database > /dev/null
is_empty_Data > /dev/null
init_mysql > /dev/null
start_mysql > /dev/null
soft_start > /dev/null
#tail -f /dev/null
${init_path}/bt log

41
arm64/init_mysql.sh Normal file
View File

@ -0,0 +1,41 @@
#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
Root_Path=`cat /var/bt_setupPath.conf`
Setup_Path=$Root_Path/server/mysql
Data_Path=$Root_Path/server/data
Mysql_Initialize(){
if [ -d "${Data_Path}" ]; then
check_z=$(ls "${Data_Path}")
if [[ ! -z "${check_z}" ]]; then
return
fi
fi
mkdir -p ${Data_Path}
chown -R mysql:mysql ${Data_Path}
chgrp -R mysql ${Setup_Path}/.
${Setup_Path}/bin/mysqld --initialize-insecure --basedir=${Setup_Path} --datadir=${Data_Path} --user=mysql
cat > /etc/ld.so.conf.d/mysql.conf<<EOF
${Setup_Path}/lib
EOF
ldconfig
ln -sf ${Setup_Path}/lib/mysql /usr/lib/mysql
ln -sf ${Setup_Path}/include/mysql /usr/include/mysql
/etc/init.d/mysqld start
mysqlpwd=`cat /dev/urandom | head -n 16 | md5sum | head -c 16`
${Setup_Path}/bin/mysqladmin -u root password "${mysqlpwd}"
cd "${Setup_Path}"
rm -f src.tar.gz
rm -rf src
/etc/init.d/mysqld start
rm -rf /init_mysql.sh
}
Mysql_Initialize

65
bt.sh
View File

@ -8,8 +8,25 @@ Setup_Path=$Root_Path/server/mysql
Data_Path=$Root_Path/server/data Data_Path=$Root_Path/server/data
O_pl=$(cat /www/server/panel/data/o.pl) O_pl=$(cat /www/server/panel/data/o.pl)
backup_database() {
if [ -d "${Data_Path}" ] && [ ! -z "$(ls -A ${Data_Path})" ]; then
if [ ! -d "${Setup_Path}" ] || [ -z "$(ls -A ${Setup_Path})" ]; then
timestamp=$(date +"%s")
tar czf /www/server/data_backup_$timestamp.tar.gz -C ${Data_Path} .
fi
fi
}
restore_panel_data() {
if [ -f /www.tar.gz ]; then
if [ ! -d /www ] || [ -z "$(ls -A /www)" ] || [ ! -d /www/server/panel ] || [ -z "$(ls -A /www/server/panel)" ] || [ ! -d /www/server/panel/pyenv ] || [ -z "$(ls -A /www/server/panel/pyenv)" ]; then
tar xzf /www.tar.gz -C / --skip-old-files
rm -rf /www.tar.gz
fi
fi
}
soft_start(){ soft_start(){
# 扫描并启动所有服务
init_scripts=$(ls ${init_path}) init_scripts=$(ls ${init_path})
for script in ${init_scripts}; do for script in ${init_scripts}; do
case "${script}" in case "${script}" in
@ -17,7 +34,6 @@ soft_start(){
continue continue
;; ;;
esac esac
${init_path}/${script} start ${init_path}/${script} start
done done
@ -38,15 +54,12 @@ soft_start(){
} }
init_mysql(){ init_mysql(){
if [ "${O_pl}" != "docker_btlamp_d12" ] && [ "${O_pl}" != "docker_btlnmp_d12" ];then if [ "${O_pl}" != "docker_btlamp_fnnas" ] && [ "${O_pl}" != "docker_btlnmp_fnnas" ];then
return return
fi fi
if [ -d "${Data_Path}" ]; then if [ -d "${Data_Path}" ]; then
check_z=$(ls "${Data_Path}") check_z=$(ls "${Data_Path}")
echo "check_z:"
echo ${check_z}
if [[ ! -z "${check_z}" ]]; then if [[ ! -z "${check_z}" ]]; then
echo "check_z is not empty"
return return
fi fi
fi fi
@ -68,9 +81,45 @@ start_mysql(){
fi fi
} }
check_bt_credentials() {
if [ -f "/www/server/panel/data/credentials_set" ]; then
echo "Credentials already set. Skipping."
return 0
fi
if [ -z "$btuser" ] && [ -z "$btpwd" ]; then
echo "No credentials provided. Skipping."
return 0
fi
echo "Waiting for BT panel to be ready..."
while true; do
${init_path}/bt status >/dev/null 2>&1
if [ $? -eq 0 ]; then
break
fi
sleep 1
echo "Retrying..."
done
if [ -n "$btuser" ]; then
echo "Updating username to $btuser..."
echo "$btuser" | ${init_path}/bt 6 || echo "Failed to update username."
fi
if [ -n "$btpwd" ]; then
echo "Updating password..."
echo "$btpwd" | ${init_path}/bt 5 || echo "Failed to update password."
fi
touch "/www/server/panel/data/credentials_set"
}
restore_panel_data > /dev/null
backup_database > /dev/null
is_empty_Data > /dev/null is_empty_Data > /dev/null
init_mysql > /dev/null init_mysql > /dev/null
start_mysql > /dev/null start_mysql > /dev/null
soft_start > /dev/null soft_start > /dev/null
#tail -f /dev/null check_bt_credentials > /dev/null
${init_path}/bt log ${init_path}/bt log