Compare commits
38 Commits
Author | SHA1 | Date | |
---|---|---|---|
b21ccb6344 | |||
09fb13638e | |||
eefc67c34f | |||
2a5d694708 | |||
![]() |
ec7393435d | ||
![]() |
466dccaf9b | ||
![]() |
1622719b66 | ||
![]() |
b9a3bb1342 | ||
![]() |
583e94973a | ||
![]() |
b7548bb509 | ||
![]() |
02f02aef88 | ||
![]() |
71eab61a5d | ||
![]() |
3306ff3ef3 | ||
![]() |
5fb61374d0 | ||
![]() |
7d64f66acb | ||
![]() |
7704973d73 | ||
![]() |
bcc6565dc2 | ||
![]() |
0237f60bdd | ||
![]() |
6fb41b2423 | ||
![]() |
058032aaac | ||
![]() |
8da406ce23 | ||
![]() |
03a3701ff4 | ||
![]() |
38cae6fb5c | ||
![]() |
4061313742 | ||
![]() |
f22c403daa | ||
![]() |
48d1bc7fd5 | ||
![]() |
b80f88f5ab | ||
![]() |
cc6fb795a1 | ||
![]() |
883071c25b | ||
![]() |
9ff3d5d87a | ||
![]() |
bae411eb28 | ||
![]() |
c3f9ced0f2 | ||
![]() |
0c9522e569 | ||
![]() |
b2849efc84 | ||
![]() |
428764cc0d | ||
![]() |
7c2e2badeb | ||
![]() |
bb49891b74 | ||
![]() |
9a1fba71e7 |
121
.cnb.yml
121
.cnb.yml
@ -5,7 +5,105 @@ $:
|
|||||||
docker:
|
docker:
|
||||||
build:
|
build:
|
||||||
dockerfile: .ide/Dockerfile
|
dockerfile: .ide/Dockerfile
|
||||||
|
issue.open:
|
||||||
|
- stages:
|
||||||
|
- name: issue-notice
|
||||||
|
image: tencentcom/wecom-message
|
||||||
|
imports: https://cnb.cool/btpanel/secret/-/blob/main/wework-robots.yml
|
||||||
|
settings:
|
||||||
|
robot: $CNB_WARRIOR_ROBOT
|
||||||
|
msgType: markdown
|
||||||
|
content: |
|
||||||
|
> **有人提issue啦**
|
||||||
|
> **标 题:** $CNB_ISSUE_TITLE
|
||||||
|
> **发起人:** $CNB_ISSUE_OWNER
|
||||||
|
> **查看:** [$CNB_EVENT_URL]($CNB_EVENT_URL)
|
||||||
|
issue.reopen:
|
||||||
|
- stages:
|
||||||
|
- name: issue-notice
|
||||||
|
image: tencentcom/wecom-message
|
||||||
|
imports: https://cnb.cool/btpanel/secret/-/blob/main/wework-robots.yml
|
||||||
|
settings:
|
||||||
|
robot: $CNB_WARRIOR_ROBOT
|
||||||
|
content: |
|
||||||
|
> **$CNB_BUILD_USER重新打开了一个issue**
|
||||||
|
> **标 题:** $CNB_ISSUE_TITLE
|
||||||
|
> **发起人:** $CNB_ISSUE_OWNER
|
||||||
|
> **查 看:** [$CNB_EVENT_URL]($CNB_EVENT_URL)
|
||||||
|
|
||||||
push:
|
push:
|
||||||
|
- runner:
|
||||||
|
tags: cnb:arch:amd64
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
|
||||||
|
env:
|
||||||
|
IMAGE_TAG: btpanel/baota:latest-linux-amd64
|
||||||
|
stages:
|
||||||
|
- name: docker login
|
||||||
|
script: docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWD"
|
||||||
|
- name: docker build
|
||||||
|
script: docker build -t ${IMAGE_TAG} .
|
||||||
|
- name: docker push
|
||||||
|
script: docker push ${IMAGE_TAG}
|
||||||
|
- name: resolve
|
||||||
|
type: cnb:resolve
|
||||||
|
options:
|
||||||
|
key: build-amd64
|
||||||
|
|
||||||
|
- runner:
|
||||||
|
tags: cnb:arch:arm64:v8
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
|
||||||
|
env:
|
||||||
|
IMAGE_TAG: btpanel/baota:latest-linux-arm64
|
||||||
|
stages:
|
||||||
|
- name: docker login
|
||||||
|
script: docker login -u "$DOCKER_USERNAME" -p "$DOCKER_PASSWD"
|
||||||
|
- name: docker build
|
||||||
|
script: docker build -t ${IMAGE_TAG} .
|
||||||
|
- name: docker push
|
||||||
|
script: docker push ${IMAGE_TAG}
|
||||||
|
- name: resolve
|
||||||
|
type: cnb:resolve
|
||||||
|
options:
|
||||||
|
key: build-arm64
|
||||||
|
|
||||||
|
- services:
|
||||||
|
- docker
|
||||||
|
imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
|
||||||
|
env:
|
||||||
|
IMAGE_TAG: btpanel/baota:latest
|
||||||
|
stages:
|
||||||
|
- name: await the amd64
|
||||||
|
type: cnb:await
|
||||||
|
options:
|
||||||
|
key: build-amd64
|
||||||
|
- name: await the arm64
|
||||||
|
type: cnb:await
|
||||||
|
options:
|
||||||
|
key: build-arm64
|
||||||
|
- name: manifest
|
||||||
|
image: cnbcool/manifest
|
||||||
|
settings:
|
||||||
|
username: $DOCKER_USERNAME
|
||||||
|
password: $DOCKER_PASSWD
|
||||||
|
target: ${IMAGE_TAG}
|
||||||
|
template: ${IMAGE_TAG}-OS-ARCH
|
||||||
|
platforms:
|
||||||
|
- linux/amd64
|
||||||
|
- linux/arm64
|
||||||
|
- name: clear
|
||||||
|
image: lumir/remove-dockerhub-tag
|
||||||
|
args:
|
||||||
|
- --user
|
||||||
|
- $DOCKER_USERNAME
|
||||||
|
- --password
|
||||||
|
- $DOCKER_PASSWD
|
||||||
|
- ${IMAGE_TAG}-linux-amd64
|
||||||
|
- ${IMAGE_TAG}-linux-arm64
|
||||||
|
|
||||||
- runner:
|
- runner:
|
||||||
tags: cnb:arch:amd64
|
tags: cnb:arch:amd64
|
||||||
services:
|
services:
|
||||||
@ -22,7 +120,7 @@ $:
|
|||||||
- name: resolve
|
- name: resolve
|
||||||
type: cnb:resolve
|
type: cnb:resolve
|
||||||
options:
|
options:
|
||||||
key: build-amd64
|
key: cnb-build-amd64
|
||||||
|
|
||||||
- runner:
|
- runner:
|
||||||
tags: cnb:arch:arm64:v8
|
tags: cnb:arch:arm64:v8
|
||||||
@ -40,9 +138,12 @@ $:
|
|||||||
- name: resolve
|
- name: resolve
|
||||||
type: cnb:resolve
|
type: cnb:resolve
|
||||||
options:
|
options:
|
||||||
key: build-arm64
|
key: cnb-build-arm64
|
||||||
|
|
||||||
- services:
|
- runner:
|
||||||
|
tags: cnb:arch:amd64
|
||||||
|
cpus: 2
|
||||||
|
services:
|
||||||
- docker
|
- docker
|
||||||
env:
|
env:
|
||||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest
|
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest
|
||||||
@ -50,11 +151,11 @@ $:
|
|||||||
- name: await the amd64
|
- name: await the amd64
|
||||||
type: cnb:await
|
type: cnb:await
|
||||||
options:
|
options:
|
||||||
key: build-amd64
|
key: cnb-build-amd64
|
||||||
- name: await the arm64
|
- name: await the arm64
|
||||||
type: cnb:await
|
type: cnb:await
|
||||||
options:
|
options:
|
||||||
key: build-arm64
|
key: cnb-build-arm64
|
||||||
- name: manifest
|
- name: manifest
|
||||||
image: cnbcool/manifest
|
image: cnbcool/manifest
|
||||||
settings:
|
settings:
|
||||||
@ -64,4 +165,12 @@ $:
|
|||||||
template: ${IMAGE_TAG}-OS-ARCH
|
template: ${IMAGE_TAG}-OS-ARCH
|
||||||
platforms:
|
platforms:
|
||||||
- linux/amd64
|
- linux/amd64
|
||||||
- linux/arm64
|
- linux/arm64
|
||||||
|
- name: remove tag
|
||||||
|
type: artifact:remove-tag
|
||||||
|
options:
|
||||||
|
name: ${CNB_REPO_NAME}
|
||||||
|
tags:
|
||||||
|
- latest-linux-amd64
|
||||||
|
- latest-linux-arm64
|
||||||
|
type: docker
|
22
.cnb/ISSUE_TEMPLATE/0-feature-request.yml
Normal file
22
.cnb/ISSUE_TEMPLATE/0-feature-request.yml
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
name: feature request
|
||||||
|
description: 该模版用于提需求
|
||||||
|
labels:
|
||||||
|
- feature
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
感谢用户提出的改进 宝塔面板Docker镜像 的想法。
|
||||||
|
|
||||||
|
请尽可能填写以下内容
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 这个特性将解决什么问题?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 设想的解决方案?如有
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 您考虑过哪些替代方案?如有
|
20
.cnb/ISSUE_TEMPLATE/2-bug-report.yml
Normal file
20
.cnb/ISSUE_TEMPLATE/2-bug-report.yml
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
name: bug report
|
||||||
|
description: 该模版用于反馈 bug
|
||||||
|
labels:
|
||||||
|
- bug
|
||||||
|
body:
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 提供报错说明&截图?如有,可更快的确认问题
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 提供一下报错日志?如环境/插件安装日志,或其他报错信息
|
||||||
|
validations:
|
||||||
|
required: false
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 描述一下重现步骤?
|
||||||
|
validations:
|
||||||
|
required: false
|
13
.cnb/ISSUE_TEMPLATE/3-experience-report.yml
Normal file
13
.cnb/ISSUE_TEMPLATE/3-experience-report.yml
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
name: experience improve
|
||||||
|
description: 该模版用于反馈体验问题
|
||||||
|
labels:
|
||||||
|
- 体验优化
|
||||||
|
body:
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 描述一下体验不好的点
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
- type: textarea
|
||||||
|
attributes:
|
||||||
|
label: 优化建议?如有
|
1
.cnb/ISSUE_TEMPLATE/config.yml
Normal file
1
.cnb/ISSUE_TEMPLATE/config.yml
Normal file
@ -0,0 +1 @@
|
|||||||
|
blank_issues_enabled: true
|
38
.gitea/workflows/build-docker-images.yml
Normal file
38
.gitea/workflows/build-docker-images.yml
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
name: Docker Image Build and Push
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
version:
|
||||||
|
description: '版本标签'
|
||||||
|
required: true
|
||||||
|
default: '9.5.0'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-and-push-multiarch:
|
||||||
|
name: Build and Push Multi-Arch Docker Image
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout code
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v2
|
||||||
|
|
||||||
|
- name: Login to Docker Hub
|
||||||
|
uses: docker/login-action@v2
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_PASSWORD }}
|
||||||
|
|
||||||
|
- name: Build and push multi-arch Docker images
|
||||||
|
uses: docker/build-push-action@v4
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
file: ./Dockerfile
|
||||||
|
platforms: linux/amd64,linux/arm64
|
||||||
|
push: true
|
||||||
|
tags: |
|
||||||
|
ldxw/btpanel:latest
|
||||||
|
ldxw/btpanel:${{ github.event.inputs.version }}
|
||||||
|
|
80
Dockerfile
80
Dockerfile
@ -1,13 +1,10 @@
|
|||||||
FROM debian:bookworm
|
FROM debian:bookworm
|
||||||
|
|
||||||
# 切换 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 \
|
||||||
RUN apt update && apt upgrade -y
|
&& apt install -y \
|
||||||
|
|
||||||
# 安装前置依赖
|
|
||||||
RUN apt install -y \
|
|
||||||
locales \
|
locales \
|
||||||
wget iproute2 openssh-server libgd-dev cmake make gcc g++ autoconf \
|
wget iproute2 openssh-server libgd-dev cmake make gcc g++ autoconf \
|
||||||
libsodium-dev libonig-dev libssh2-1-dev libc-ares-dev libaio-dev sudo curl dos2unix \
|
libsodium-dev libonig-dev libssh2-1-dev libc-ares-dev libaio-dev sudo curl dos2unix \
|
||||||
@ -15,53 +12,44 @@ RUN apt install -y \
|
|||||||
diffutils unzip tar libbz2-dev libncurses5 libncurses5-dev libtool libevent-dev libssl-dev libsasl2-dev \
|
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 \
|
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 \
|
libc-client2007e-dev psmisc patch git e2fsprogs libxslt1-dev xz-utils libgd3 libwebp-dev libvpx-dev \
|
||||||
libfreetype6-dev libjpeg62-turbo libjpeg62-turbo-dev
|
libfreetype6-dev libjpeg62-turbo libjpeg62-turbo-dev iptables libudev-dev libldap2-dev \
|
||||||
|
&& apt clean \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# 配置区域设置
|
# 复制脚本
|
||||||
RUN locale-gen en_US.UTF-8
|
COPY ["bt.sh", "init_mysql.sh", "/"]
|
||||||
|
|
||||||
ENV LANG en_US.UTF-8
|
# 转换启动脚本
|
||||||
ENV LANGUAGE en_US:en
|
RUN dos2unix /bt.sh && dos2unix /init_mysql.sh
|
||||||
ENV LC_ALL en_US.UTF-8
|
|
||||||
|
|
||||||
# 复制 bt.sh 文件
|
# 下载并安装宝塔面板及 lnmp 环境
|
||||||
COPY bt.sh /bt.sh
|
|
||||||
|
|
||||||
# 转换 bt.sh 文件的换行符
|
|
||||||
RUN dos2unix /bt.sh
|
|
||||||
|
|
||||||
# 设置构建参数
|
|
||||||
ARG RANDOM_NAME
|
|
||||||
|
|
||||||
# 设置一个btd12-前缀的随机主机名
|
|
||||||
RUN echo "btd12-${RANDOM_NAME}" > /etc/hostname
|
|
||||||
|
|
||||||
# 下载并安装宝塔面板
|
|
||||||
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 \
|
||||||
|
#&& btpip config set global.index-url https://mirrors.tencent.com/pypi/simple \
|
||||||
|
&& rm -rf /www/server/data/* \
|
||||||
|
&& echo "docker_bt_d12" > /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
|
||||||
|
|
||||||
|
|
||||||
# 配置宝塔面板安全入口和用户名及密码
|
# 配置宝塔面板安全入口和用户名及密码,以及 SSH 密码
|
||||||
RUN echo btpanel | bt 6 \
|
RUN echo btpanel | bt 6 \
|
||||||
&& echo btpaneldocker | bt 5 \
|
&& echo btpaneldocker | bt 5 \
|
||||||
&& echo "/btpanel" > /www/server/panel/data/admin_path.pl
|
&& echo "/btpanel" > /www/server/panel/data/admin_path.pl \
|
||||||
|
&& echo "root:btpaneldocker" | chpasswd
|
||||||
# 设置 root 用户密码
|
|
||||||
RUN echo "root:btpaneldocker" | chpasswd
|
# 打包宝塔面板,并清除www
|
||||||
|
RUN bt 2 \
|
||||||
# 赋予 bt.sh 可执行权限
|
&& tar -zcf /www.tar.gz /www \
|
||||||
RUN chmod +x /bt.sh
|
&& rm -rf /www
|
||||||
|
|
||||||
# 清理缓存
|
|
||||||
RUN apt clean \
|
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
# 设置标识文件
|
|
||||||
RUN echo "dk_lib_test_d12" > /www/server/panel/data/o.pl
|
|
||||||
|
|
||||||
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 curl -i http://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
|
58
README.md
Normal file
58
README.md
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
> 此 Docker 镜像由宝塔面板官方发布,镜像版本为宝塔面板 9.3.0 正式版和 9.0.0_lts 稳定版,镜像会随着宝塔面板更新,目前支持`x86_64`和`arm64`架构。
|
||||||
|
|
||||||
|

|
||||||
|

|
||||||
|

|
||||||
|
|
||||||
|
## 使用方法
|
||||||
|
> 以下命令中的镜像默认使用 CNB 仓库镜像,如需直接从 DockerHub 拉取,请替换镜像地址,如将`docker.cnb.cool/btpanel/btpanel:latest`替换为`btpanel:baota:latest`
|
||||||
|
|
||||||
|
### Docker Run
|
||||||
|
- 复制下方的命令,无需映射端口使用本地网络直接部署宝塔面板docker镜像
|
||||||
|
```bash
|
||||||
|
docker run -d --restart unless-stopped --name baota --net=host -v ~/www:/www docker.cnb.cool/btpanel/btpanel:latest
|
||||||
|
```
|
||||||
|
- 复制下方的命令,映射指定端口部署宝塔面板docker镜像
|
||||||
|
```bash
|
||||||
|
docker run -d --restart unless-stopped --name baota -p 8888:8888 -p 22:22 -p 443:443 -p 80:80 -p 888:888 -v ~/www:/www docker.cnb.cool/btpanel/btpanel:latest
|
||||||
|
```
|
||||||
|
|
||||||
|
### Docker Compose
|
||||||
|
```yml
|
||||||
|
services:
|
||||||
|
btpanel:
|
||||||
|
image: docker.cnb.cool/btpanel/btpanel:latest # 宝塔面板官方镜像(国内源),也可直接使用dockerhub镜像 btpanel/baota:latest
|
||||||
|
deploy:
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
cpus: "2.0" # 最大CPU核心限制,根据实际情况调整
|
||||||
|
memory: "1024M" # 最大内存限制,根据实际情况调整
|
||||||
|
restart_policy:
|
||||||
|
condition: always
|
||||||
|
ports:
|
||||||
|
- "38888:8888" # 宝塔面板对外访问端口,默认38888
|
||||||
|
- "8080:80" # Web服务端口,默认8080
|
||||||
|
- "8443:443" # HTTPS服务端口,默认8443
|
||||||
|
- "33306:3306" # MySQL服务端口,默认33306,不需要暴露到容器外可删除
|
||||||
|
- "22022:22" # SSH服务端口,默认22022,不需要暴露到容器外可删除
|
||||||
|
- "32888:888" # PHPMyAdmin服务端口,默认32888,不需要暴露到容器外可删除
|
||||||
|
volumes:
|
||||||
|
- "/www:/www" # 持久化存储宝塔面板数据,默认/www,可根据实际情况调整目录
|
||||||
|
labels:
|
||||||
|
createdBy: "bt_apps"
|
||||||
|
```
|
||||||
|
## 如果面板需要使用Docker
|
||||||
|
参考格式 本地docker环境挂载进面板docker使用
|
||||||
|
```yml
|
||||||
|
- "/usr/bin/docker:/usr/bin/docker"
|
||||||
|
- "/run/docker.sock:/run/docker.sock"
|
||||||
|
```
|
||||||
|
|
||||||
|
## 镜像说明
|
||||||
|
除标注了`9.0_lts`稳定版的标签外,其他镜像均为`9.3.0/9.2.0`正式版
|
||||||
|
- `latest`:基于`Debian12`镜像打包,安装了宝塔面板和后续安装环境所用的依赖。
|
||||||
|
- `nas`:基于`Debian12`镜像打包,安装了宝塔面板和`Nginx 1.27`(amd架构)或`Nginx openresty`(arm64架构)
|
||||||
|
- `9.0_lts_fresh`:基于`Debian12`镜像打包,安装了宝塔面板稳定版。
|
||||||
|
- `9.0_lts_lib`:基于`Debian12`镜像打包,安装了宝塔面板稳定版和和后续安装环境所用的依赖。
|
||||||
|
- `slim`:基于`debian:bookworm-slim`镜像打包,仅安装了宝塔面板,体积较小。
|
||||||
|
|
101
bt.sh
101
bt.sh
@ -1,5 +1,96 @@
|
|||||||
/etc/init.d/bt restart
|
#!/bin/bash
|
||||||
pkill crond
|
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
|
||||||
/sbin/crond
|
export PATH
|
||||||
/usr/sbin/sshd -D &
|
|
||||||
tail -f /dev/null
|
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_d12" ] && [ "${O_pl}" != "docker_btlnmp_d12" ];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
init_mysql.sh
Normal file
41
init_mysql.sh
Normal 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
|
Loading…
x
Reference in New Issue
Block a user