Compare commits
50 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
1d7a4ee67e | ||
![]() |
a4b7ce1866 | ||
![]() |
ef8503af3b | ||
![]() |
355c6796b7 | ||
![]() |
8eb725a33a | ||
![]() |
ead95a61fc | ||
![]() |
cf879b1378 | ||
![]() |
ab31965d13 | ||
![]() |
8a4cbdcb08 | ||
![]() |
b17b8b4a32 | ||
![]() |
dc893c2517 | ||
![]() |
2a3fc39c55 | ||
![]() |
934b6f9be3 | ||
![]() |
e39e9e91f8 | ||
![]() |
fa843d4333 | ||
![]() |
87f2692768 | ||
![]() |
d7469277ef | ||
![]() |
9354ec597c | ||
![]() |
a927740af1 | ||
![]() |
231b5e37df | ||
![]() |
b68b92accf | ||
![]() |
e16c54c01b | ||
![]() |
878cd098e7 | ||
![]() |
9227111abb | ||
![]() |
6363792157 | ||
![]() |
26f1abe052 | ||
![]() |
969f22937e | ||
![]() |
cf4851b942 | ||
![]() |
ac5b5fd7d7 | ||
![]() |
c3fd5565d2 | ||
![]() |
2802324b7c | ||
![]() |
67695e56c3 | ||
![]() |
b458b9c594 | ||
![]() |
4b8fa5349d | ||
![]() |
4765d71044 | ||
![]() |
67f983518c | ||
![]() |
3ebc860f20 | ||
![]() |
181b1899c3 | ||
![]() |
8df047e27b | ||
![]() |
06ac3158a3 | ||
![]() |
cbec5d9ee0 | ||
![]() |
9683a63c0f | ||
![]() |
0a70c8778d | ||
![]() |
90752dad5e | ||
![]() |
9674437fec | ||
![]() |
95e23e9c29 | ||
![]() |
9d712fc253 | ||
![]() |
a1ee787098 | ||
![]() |
dfe54ae93d | ||
![]() |
7629413a31 |
148
.cnb.yml
148
.cnb.yml
@ -6,84 +6,84 @@ $:
|
||||
build:
|
||||
dockerfile: .ide/Dockerfile
|
||||
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:amd64
|
||||
# services:
|
||||
# - docker
|
||||
# imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
|
||||
# env:
|
||||
# IMAGE_TAG: btpanel/baota:alpine-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
|
||||
# - runner:
|
||||
# tags: cnb:arch:arm64:v8
|
||||
# services:
|
||||
# - docker
|
||||
# imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
|
||||
# env:
|
||||
# IMAGE_TAG: btpanel/baota:alpine-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
|
||||
# - services:
|
||||
# - docker
|
||||
# imports: https://cnb.cool/btpanel/secret/-/blob/main/docker.yml
|
||||
# env:
|
||||
# IMAGE_TAG: btpanel/baota:alpine
|
||||
# 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:
|
||||
tags: cnb:arch:amd64
|
||||
services:
|
||||
- docker
|
||||
env:
|
||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest-linux-amd64
|
||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:alpine-linux-amd64
|
||||
stages:
|
||||
- name: docker login
|
||||
script: docker login -u ${CNB_TOKEN_USER_NAME} -p "${CNB_TOKEN}" ${CNB_DOCKER_REGISTRY}
|
||||
@ -101,7 +101,7 @@ $:
|
||||
services:
|
||||
- docker
|
||||
env:
|
||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest-linux-arm64
|
||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:alpine-linux-arm64
|
||||
stages:
|
||||
- name: docker login
|
||||
script: docker login -u ${CNB_TOKEN_USER_NAME} -p "${CNB_TOKEN}" ${CNB_DOCKER_REGISTRY}
|
||||
@ -120,7 +120,7 @@ $:
|
||||
services:
|
||||
- docker
|
||||
env:
|
||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:latest
|
||||
IMAGE_TAG: ${CNB_DOCKER_REGISTRY}/${CNB_REPO_SLUG_LOWERCASE}:alpine
|
||||
stages:
|
||||
- name: await the amd64
|
||||
type: cnb:await
|
||||
@ -145,6 +145,6 @@ $:
|
||||
options:
|
||||
name: ${CNB_REPO_NAME}
|
||||
tags:
|
||||
- latest-linux-amd64
|
||||
- latest-linux-arm64
|
||||
- alpine-linux-amd64
|
||||
- alpine-linux-arm64
|
||||
type: docker
|
46
Dockerfile
46
Dockerfile
@ -1,48 +1,40 @@
|
||||
FROM debian:bookworm
|
||||
FROM python:3.7.16-alpine
|
||||
|
||||
# 切换 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 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 \
|
||||
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 \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
# 切换 alpine 镜像源为腾讯云源,更新包列表并安装依赖
|
||||
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.tencent.com/g' /etc/apk/repositories \
|
||||
&& apk update && apk upgrade \
|
||||
&& apk add openrc openssh curl curl-dev libffi-dev openssl-dev shadow bash zlib-dev g++ make sqlite-dev libpcap-dev jpeg-dev dos2unix libev-dev build-base linux-headers gd-dev \
|
||||
&& apk cache clean \
|
||||
&& rm -rf /var/cache/apk/*
|
||||
|
||||
# 复制脚本
|
||||
COPY ["bt.sh", "init_mysql.sh", "/"]
|
||||
COPY ["bt.sh", "init_mysql.sh", "install_panel.sh", "/"]
|
||||
|
||||
# 转换启动脚本
|
||||
RUN dos2unix /bt.sh && dos2unix /init_mysql.sh
|
||||
RUN dos2unix /bt.sh && dos2unix /init_mysql.sh && dos2unix /install_panel.sh
|
||||
|
||||
# 下载并安装宝塔面板及 lnmp 环境
|
||||
RUN curl -sSO https://download.bt.cn/install/install_panel.sh \
|
||||
&& echo y | bash install_panel.sh -P 8888 --ssl-disable \
|
||||
RUN echo y | bash /install_panel.sh -P 8888 --ssl-disable \
|
||||
&& rm -rf /www/server/data/* \
|
||||
&& echo "docker_bt_d12" > /www/server/panel/data/o.pl \
|
||||
&& echo "docker_bt_alpine" > /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
|
||||
|
||||
&& chmod +x /init_mysql.sh \
|
||||
&& apk cache clean \
|
||||
&& rm -rf /var/cache/apk/*
|
||||
|
||||
# 配置宝塔面板安全入口和用户名及密码,以及 SSH 密码
|
||||
RUN echo btpanel | bt 6 \
|
||||
&& echo btpaneldocker | bt 5 \
|
||||
&& echo "/btpanel" > /www/server/panel/data/admin_path.pl \
|
||||
&& echo "root:btpaneldocker" | chpasswd
|
||||
&& echo "root:btpaneldocker" | chpasswd \
|
||||
&& echo "PermitRootLogin yes" | tee -a /etc/ssh/sshd_config
|
||||
|
||||
|
||||
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
|
3
bt.sh
3
bt.sh
@ -32,7 +32,8 @@ soft_start(){
|
||||
|
||||
pkill crond
|
||||
/sbin/crond
|
||||
|
||||
|
||||
ssh-keygen -A
|
||||
chmod 600 /etc/ssh/ssh_host_*
|
||||
/usr/sbin/sshd -D &
|
||||
}
|
||||
|
1489
install_panel.sh
Normal file
1489
install_panel.sh
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user