From f7c907cc84cb594d4aa37993415363f3f682d901 Mon Sep 17 00:00:00 2001 From: xiao Date: Tue, 7 Jan 2025 14:41:10 +0800 Subject: [PATCH] =?UTF-8?q?refactor:=20=E7=AE=80=E5=8C=96=20Dockerfile=20?= =?UTF-8?q?=E5=B9=B6=E7=A7=BB=E9=99=A4=E8=87=AA=E5=AE=9A=E4=B9=89=E5=90=AF?= =?UTF-8?q?=E5=8A=A8=E8=84=9A=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Dockerfile | 41 +++------------------- bt.sh | 97 --------------------------------------------------- init_mysql.sh | 41 ---------------------- 3 files changed, 5 insertions(+), 174 deletions(-) delete mode 100644 bt.sh delete mode 100644 init_mysql.sh diff --git a/Dockerfile b/Dockerfile index 2ffdade..76dfd35 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,42 +1,11 @@ -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 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_lts.sh \ - && echo y | bash install_lts.sh -P 8888 --ssl-disable \ - && btpip config set global.index-url https://mirrors.tencent.com/pypi/simple \ - && rm -rf /www/server/data/* \ - && echo "docker_bt_ltsd12" > /www/server/panel/data/o.pl \ - && echo '["memuA", "memuAsite", "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/* \ - && chmod +x /bt.sh \ - && chmod +x /init_mysql.sh - +FROM docker.cnb.cool/btpanel/btpanel:9.0_lts_fresh + # 安装 lib 库 RUN curl -o /www/server/panel/install/lib.sh http://download.bt.cn/install/0/lib.sh \ - && sh /www/server/panel/install/lib.sh + && sh /www/server/panel/install/lib.sh \ + && 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 - ENTRYPOINT ["/bin/sh","-c","/bt.sh"] # 暴漏特定端口 diff --git a/bt.sh b/bt.sh deleted file mode 100644 index 363a612..0000000 --- a/bt.sh +++ /dev/null @@ -1,97 +0,0 @@ -#!/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 +"%Y%m%d%H%M%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_ltsd12" ] && [ "${O_pl}" != "docker_btlnmp_ltsd12" ];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 \ No newline at end of file diff --git a/init_mysql.sh b/init_mysql.sh deleted file mode 100644 index f773276..0000000 --- a/init_mysql.sh +++ /dev/null @@ -1,41 +0,0 @@ -#!/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<