feat: 优化默认模板

This commit is contained in:
2023-08-25 14:53:06 +08:00
parent 424ad66262
commit e072242836
9 changed files with 158 additions and 148 deletions
+26 -32
View File
@@ -1,9 +1,8 @@
# Ver: 1.10 by Endial Fang (endial@126.com) # Ver: 1.10 by Endial Fang (endial@126.com)
# #
# 默认变量 ======================================================================== # 系统默认变量 ====================================================================
# 该部分变量为系统根据编译命令默认设置 # 该部分变量为系统根据编译命令默认设置
# `TARGETPLATFORM`:构建后的目标平台信息。如 `linux/amd64``linux/arm/v7``windows/amd64` # `TARGETPLATFORM`:构建后的目标平台信息。如 `linux/amd64``linux/arm/v7``windows/amd64`
# `TARGETOS`:目标平台信息(TARGETPLATFORM)中的操作系统部分,如:`linux`、`windows` # `TARGETOS`:目标平台信息(TARGETPLATFORM)中的操作系统部分,如:`linux`、`windows`
# `TARGETARCH`:目标平台信息(TARGETPLATFORM)中的平台架构部分,如:`amd64`、`arm` # `TARGETARCH`:目标平台信息(TARGETPLATFORM)中的平台架构部分,如:`amd64`、`arm`
@@ -33,12 +32,11 @@ ARG APP_VER
ARG APT_SOURCE ARG APT_SOURCE
ARG LOCAL_URL ARG LOCAL_URL
# 选择软件包源(Optional),以加速后续软件包安装 # 选择软件包源加速后续软件包安装
RUN select_source ${APT_SOURCE}; RUN select_source ${APT_SOURCE};
# 安装依赖的软件包及库(Optional) # 安装依赖的软件包及库
#RUN install_pkg xz-utils RUN install_pkg curl;
# dbuilder已安装: libtool libltdl7 libltdl-dev libssl3 libssl-dev
# 下载并解压软件包 # 下载并解压软件包
RUN set -eux; \ RUN set -eux; \
@@ -79,12 +77,9 @@ RUN set -eux; \
# 检测并生成依赖文件记录 # 检测并生成依赖文件记录
RUN set -eux; \ RUN set -eux; \
find /usr/local/${APP_NAME} -type f -executable -exec ldd '{}' ';' | \ find /usr/local/${APP_NAME} -type f -executable -exec ldd '{}' ';' | \
awk '/=>/ { print $(NF-1) }' | \ awk '/=>/ { print $(NF-1) }' | xargs -r basename -a | sort -u | \
sort -u | \ xargs -r dpkg-query --search 2>/dev/null | cut -d: -f1 | sort -u \
xargs -r readlink -f | \ >>/usr/local/${APP_NAME}/runDeps;
xargs -r dpkg-query --search 2>/dev/null | \
cut -d: -f1 | \
sort -u >>/usr/local/${APP_NAME}/runDeps;
# 1. 生成镜像 ===================================================================== # 1. 生成镜像 =====================================================================
FROM --platform=${TARGETPLATFORM:-linux/amd64} ${REGISTRY_URL}colovu/debian:12 FROM --platform=${TARGETPLATFORM:-linux/amd64} ${REGISTRY_URL}colovu/debian:12
@@ -100,13 +95,10 @@ ENV APP_NAME=${APP_NAME} \
APP_VER=${APP_VER} \ APP_VER=${APP_VER} \
APP_EXEC=${APP_NAME} \ APP_EXEC=${APP_NAME} \
APP_USER=${APP_NAME} \ APP_USER=${APP_NAME} \
APP_HOME=/srv/${APP_NAME} \ \
APP_BASE=/usr/local/${APP_NAME}
# 增加应用可执行文件及库文件搜索路径
ENV PATH="${PATH}:/usr/local/${APP_NAME}/bin" \
CLASSPATH=".:/usr/local/${APP_NAME}/lib" \ CLASSPATH=".:/usr/local/${APP_NAME}/lib" \
LD_LIBRARY_PATH="/usr/local/${APP_NAME}/lib" LD_LIBRARY_PATH="/usr/local/${APP_NAME}/lib" \
PATH="${PATH}:/usr/local/${APP_NAME}/bin"
LABEL \ LABEL \
"Version"="v${APP_VER}" \ "Version"="v${APP_VER}" \
@@ -114,31 +106,32 @@ LABEL \
"Github"="https://github.com/colovu/docker-${APP_NAME}" \ "Github"="https://github.com/colovu/docker-${APP_NAME}" \
"Vendor"="Endial Fang (endial@126.com)" "Vendor"="Endial Fang (endial@126.com)"
VOLUME ["/srv/${APP_NAME}"] # 默认提供的数据卷 # 配置容器的数据卷、工作目录及服务端口(必须保证端口在1024之上)
WORKDIR /srv/${APP_NAME} # 设置工作目录 VOLUME ["/srv/${APP_NAME}"]
EXPOSE 8080 8443 # 默认使用gosu切换为新建用户启动,必须保证端口在1024之上 WORKDIR /srv/${APP_NAME}
EXPOSE 8080 8443
# 从预处理过程中拷贝软件包,可以使用阶段编号或阶段命名定义来源 # 拷贝多阶段构建结果输出及客制化脚本
COPY --from=builder /usr/local/${APP_NAME} /usr/local/${APP_NAME} COPY --from=builder /usr/local/${APP_NAME} /usr/local/${APP_NAME}
# 拷贝应用使用的客制化脚本
COPY customer / COPY customer /
RUN set -eux; \ RUN set -eux; \
\ \
# 创建对应的用户及数据存储目录 # 创建对应的用户及数据存储目录
useradd -U -u 996 -d ${APP_HOME} -s /usr/sbin/nologin -r ${APP_USER}; \ useradd -U -u 996 -d /srv/${APP_NAME} -s /usr/sbin/nologin -r ${APP_USER}; \
mkdir -p /var/log/${APP_NAME} /var/run/${APP_NAME} /var/cache/${APP_NAME} ${APP_HOME}/{conf,data,cert}; \ mkdir -p /var/log/${APP_NAME} /var/run/${APP_NAME} /var/cache/${APP_NAME}; \
chown -R ${APP_USER}:${APP_USER} /var/log/${APP_NAME} /var/run/${APP_NAME} /var/cache/${APP_NAME} ${APP_HOME}; \ mkdir -p /srv/${APP_NAME}/conf /srv/${APP_NAME}/data /srv/${APP_NAME}/cert /srv/${APP_NAME}/log; \
chown -R ${APP_USER}:${APP_USER} /var/log/${APP_NAME} /var/run/${APP_NAME} /var/cache/${APP_NAME}; \
chown -R ${APP_USER}:${APP_USER} /usr/local/${APP_NAME} /srv/${APP_NAME}; \
\ \
/bin/bash -c "ln -sf ${APP_BASE}/etc/${APP_NAME} /etc/"; \ /bin/bash -c "ln -sf /usr/local/${APP_NAME}/etc/${APP_NAME} /etc/"; \
\ \
# 选择软件包源,以加速后续软件包安装 # 选择软件包源,以加速后续软件包安装
select_source ${APT_SOURCE}; \ select_source ${APT_SOURCE}; \
\ \
# 安装应用依赖的软件包及库 # 安装应用依赖的软件包及库
install_pkg curl; \ install_pkg curl; \
install_pkg `cat ${APP_BASE}/runDeps`; \ install_pkg `cat /usr/local/${APP_NAME}/runDeps`; \
\ \
# 执行后处理脚本 # 执行后处理脚本
overrideShell="/usr/local/overrides/overrides-${APP_VER}.sh"; \ overrideShell="/usr/local/overrides/overrides-${APP_VER}.sh"; \
@@ -147,11 +140,12 @@ RUN set -eux; \
# 验证安装的应用 # 验证安装的应用
${APP_EXEC} --version ; ${APP_EXEC} --version ;
# 应用健康状态检查
#HEALTHCHECK NONE #HEALTHCHECK NONE
#HEALTHCHECK --interval=30s --timeout=30s --retries=3 CMD curl -fs http://localhost:8080/ || exit 1 #HEALTHCHECK --interval=30s --timeout=30s --retries=3 CMD curl -fs http://localhost:8080/ || exit 1
#HEALTHCHECK --interval=10s --timeout=10s --retries=3 CMD netstat -ltun | grep 8080 #HEALTHCHECK --interval=10s --timeout=10s --retries=3 CMD netstat -ltun | grep 8080
# 容器入口脚本及应用启动命令 # 使用 dumb-init 启动入口 Shell,确保容器可以接收控制信号;并使用前台方式启动应用程序
ENTRYPOINT ["dumb-init", "entry.sh"] ENTRYPOINT ["dumb-init", "entry.sh"]
CMD ["run.sh"] CMD ["run.sh"]
#CMD ["tail", "-f", "/dev/null"] # 没有应用时,保证当前容器运行
#CMD [] # 空命令,启动容器时如不设置相应命令,容器会在启动后直接退出(一般用于基础镜像)
+3 -3
View File
@@ -25,7 +25,7 @@ Docker 快速启动命令:
```shell ```shell
# 从 Registry 服务器下载镜像并启动 # 从 Registry 服务器下载镜像并启动
$ docker run -d -e ALLOW_ANONYMOUS_LOGIN=yes --name imgname docker.colovu.com/colovu/imgname:latest $ docker run -d -e ALLOW_ANONYMOUS=yes --name imgname docker.colovu.com/colovu/imgname:latest
``` ```
- `docker.colovu.com/colovu/imgname:<TAG>`:镜像名称及版本标签 TAG;标签不指定时默认使用最新版本 - `docker.colovu.com/colovu/imgname:<TAG>`:镜像名称及版本标签 TAG;标签不指定时默认使用最新版本
@@ -60,9 +60,9 @@ $ docker-compose up -d
/srv/imgname/conf # 配置文件 /srv/imgname/conf # 配置文件
/srv/imgname/data # 数据文件,主要存放应用数据 /srv/imgname/data # 数据文件,主要存放应用数据
/srv/imgname/cert # 证书文件存放目录 /srv/imgname/cert # 证书文件存放目录
/var/imgname/binlog # 数据操作日志文件 /srv/imgname/binlog # 数据操作日志文件
/srv/imgname/log # 日志输出
/var/log/imgname # 日志输出
/var/run/imgname # 系统运行时文件,如 PID 文件 /var/run/imgname # 系统运行时文件,如 PID 文件
``` ```
+62 -72
View File
@@ -3,7 +3,6 @@
# #
# 应用通用业务处理函数 # 应用通用业务处理函数
# 加载依赖脚本
. /colovu/lib/libcommon.sh # 通用函数库 . /colovu/lib/libcommon.sh # 通用函数库
. /colovu/lib/libfile.sh . /colovu/lib/libfile.sh
@@ -13,55 +12,67 @@
. /colovu/lib/libservice.sh . /colovu/lib/libservice.sh
. /colovu/lib/libvalidations.sh . /colovu/lib/libvalidations.sh
# 函数列表 # 检测应用相应的配置文件是否存在,如果不存在,则从默认配置文件目录拷贝一份
# 默认配置文件路径:/etc/${APP_NAME}
# 目标配置文件路径:/srv/conf/${APP_NAME}
# 参数:
# $1 - 目标路径
# $2 - 源路径
# $* - 基础路径下的文件及目录列表,以" "分割
# 例子:
# ensure_config_file_exist /etc/${APP_NAME} conf.d server.conf
app_ensure_config_file_exist() {
local -r dist_path="${1:?dist paths is missing}"
local -r base_path="${2:?source paths is missing}"
local f=""
# 使用环境变量中以 "<PREFIX>" 开头的的全局变量更新指定配置文件中对应项(以"."分隔) shift 2
LOG_D "List to check in ${base_path}: $@"
while [ "$#" -gt 0 ]; do
f="${1}"
LOG_D " Process \"${f}\""
if [ -d "${base_path}/${f}" ]; then
[[ ! -d "${dist_path}/${f}" ]] && LOG_D " Create directory: ${dist_path}/${f}" && mkdir -p "${dist_path}/${f}"
[[ ! -z $(ls -A "${base_path}/${f}") ]] && app_ensure_config_file_exist "${dist_path}/${f}" "${base_path}/${f}" $(ls -A "${base_path}/${f}")
else
[[ ! -e "${dist_path}/${f}" ]] && LOG_D " Copy: ${base_path}/${f} to ${dist_path}" && cp "${base_path}/${f}" "${dist_path}"
fi
shift
done
}
# 检测以 "<PREFIX>" 开头的环境变量,并更新指定配置文件中对应配置项的值
# 如果需要全部转换为小写,可使用命令: tr '[:upper:]' '[:lower:]' # 如果需要全部转换为小写,可使用命令: tr '[:upper:]' '[:lower:]'
# 全局变量: # 环境变量与配置项替换规则 : 环境变量中下划线 ==> 配置参数中特殊字符
# <PREFIX>_* : # - "_" ==> "_"(下划线)
# 替换规则(变量中字符 ==> 替换后全局变量中字符): # - "__" ==> "."(半角点)
# - "." ==> "_" # - "___" ==> "-"(中划线)
# - "_" ==> "__" #
# - "-" ==> "___"
#
# 变量: # 变量:
# $1 - 配置文件 # $1 - 配置文件
# $2 - 前缀(不含结束的"_") # $2 - <PREFIX>前缀(不含结束的"_")
#
# 举例:
# CORE_CONF_fs_defaultFS 对应配置文件中的配置项:fs.defaultFS
app_configure_from_environment() { app_configure_from_environment() {
# Map environment variables to config properties local confFile="${1:?missing file}"
for var in "${!APP_CFG_@}"; do
key="$(echo "$var" | sed -e 's/^APP_CFG_//g' -e 's/_/\./g' | tr '[:upper:]' '[:lower:]')"
value="${!var}"
app_conf_set "$key" "$value"
done
local path="${1:?missing file}"
local envPrefix="${2:?missing parameters}" local envPrefix="${2:?missing parameters}"
LOG_D " File: ${path}" LOG_D "Configuration File: ${confFile}"
# Map environment variables to config properties
#for var in `printenv | grep ${envPrefix} | "${!${envPrefix}_@}"`; do if [[ ${file#*.} != "xml" ]]; then
# LOG_D " Process: ${var}" # 更新普通key-value配置文件,转换为小写后写入文件
# key="$(echo "${var}" | sed -e 's/^${envPrefix}_//g' -e 's/___/-/g' -e 's/__/_/g' -e 's/_/\./g')" for var in "${!APP_CFG_@}"; do
# value="${!var}" key="$(echo "$var" | sed -e 's/^APP_CFG_//g' -e 's/___/-/g' -e 's/__/./g' | tr '[:upper:]' '[:lower:]')"
# hadoop_common_xml_set "${path}" "${key}" "${value}" value="${!var}"
#done app_common_conf_set "$confFile" "$key" "$value"
#for var in $(printenv | grep ${envPrefix}); do done
# LOG_D " Process: ${var}" else
# key="$(echo "${var}" | sed -e 's/^${envPrefix}_//g' -e 's/___/-/g' -e 's/__/_/g' -e 's/_/\./g' )" # 更新xml配置文件,大小写不变写入文件
# value="${!var}" for var in $(eval echo \${!${envPrefix}_@}); do
# hadoop_common_xml_set "${path}" "${key}" "${value}" key=$(echo "$var" | sed -e 's/^'${envPrefix}'_//g' -e 's/___/-/g' -e 's/__/./g')
#done value="${!var}"
for c in `printenv | perl -sne 'print "$1 " if m/^${envPrefix}_(.+?)=.*/' -- -envPrefix=${envPrefix}`; do LOG_D " Process: ${key} => ${value}"
name=`echo ${c} | perl -pe 's/___/-/g; s/__/_/g; s/_/./g;'` app_common_xml_set "${confFile}" "${key}" "${value}"
key="${envPrefix}_${c}" done
#LOG_D " Process: ${key} => ${!key}" fi
value="${!key}"
hadoop_common_xml_set "${path}" "${name}" "${value}"
done
} }
# 将变量配置更新至配置文件 # 将变量配置更新至配置文件
@@ -96,26 +107,10 @@ app_common_conf_set() {
fi fi
} }
# 更新 server.properties 配置文件中指定变量值
# 变量:
# $1 - 变量
# $2 - 值(列表)
app_conf_set() {
app_common_conf_set "${APP_CONF_DIR}/zoo.cfg" "$@"
}
# 更新 log4j.properties 配置文件中指定变量值
# 变量:
# $1 - 变量
# $2 - 值(列表)
app_log4j_set() {
app_common_conf_set "${APP_CONF_DIR}/log4j.properties" "$@"
}
# 使用环境变量中配置,更新配置文件 # 使用环境变量中配置,更新配置文件
app_update_conf() { app_update_conf() {
LOG_I "Update configure files..." LOG_I "Update configure files..."
app_configure_from_environment "${APP_CONF_FILE}" "APP_CFG"
} }
# 生成默认配置文件 # 生成默认配置文件
@@ -126,8 +121,8 @@ app_generate_conf() {
echo "">> "${APP_CONF_FILE}" echo "">> "${APP_CONF_FILE}"
# 根据容器参数,设置配置文件 # 根据容器参数,设置配置文件
app_log4j_set "zookeeper.console.threshold" "${ZOO_LOG_LEVEL}" app_common_conf_set "${APP_CONF_DIR}/log4j.properties" "zookeeper.console.threshold" "${ZOO_LOG_LEVEL}"
app_log4j_set "zookeeper.log.dir" "${APP_LOG_DIR}" app_common_conf_set "${APP_CONF_DIR}/log4j.properties" "zookeeper.log.dir" "${APP_LOG_DIR}"
app_update_conf app_update_conf
} }
@@ -160,7 +155,7 @@ app_configure_heap_size() {
app_verify_minimum_env() { app_verify_minimum_env() {
local error_code=0 local error_code=0
LOG_D "Validating settings in APP_* env vars..." LOG_D "Validating settings in ENV vars..."
print_validation_error() { print_validation_error() {
LOG_E "$1" LOG_E "$1"
@@ -286,7 +281,7 @@ app_stop_server() {
app_is_server_running() { app_is_server_running() {
LOG_D "Check if ${APP_NAME} is running..." LOG_D "Check if ${APP_NAME} is running..."
local pid local pid
pid="$(get_pid_from_file "${APP_PID_FILE}")" pid="$(get_pid_from_file '/var/run/${APP_NAME}/${APP_NAME}.pid')"
LOG_D "${APP_NAME} PID: ${pid}" LOG_D "${APP_NAME} PID: ${pid}"
if [[ -n "${pid}" ]]; then if [[ -n "${pid}" ]]; then
@@ -296,10 +291,6 @@ app_is_server_running() {
fi fi
} }
app_is_server_not_running() {
! app_is_server_running
}
# 清理初始化应用时生成的临时文件 # 清理初始化应用时生成的临时文件
app_clean_tmp_file() { app_clean_tmp_file() {
LOG_D "Clean ${APP_NAME} tmp files for init..." LOG_D "Clean ${APP_NAME} tmp files for init..."
@@ -411,15 +402,15 @@ app_custom_init() {
LOG_D "Sourcing $f"; . "$f" LOG_D "Sourcing $f"; . "$f"
fi fi
;; ;;
*.sql) *.sql)
LOG_D "Executing $f"; LOG_D "Executing $f";
postgresql_execute "${PG_DATABASE}" "${PG_INITSCRIPTS_USERNAME}" "${PG_INITSCRIPTS_PASSWORD}" < "$f" postgresql_execute "${PG_DATABASE}" "${PG_INITSCRIPTS_USERNAME}" "${PG_INITSCRIPTS_PASSWORD}" < "$f"
;; ;;
*.sql.gz) *.sql.gz)
LOG_D "Executing $f"; LOG_D "Executing $f";
gunzip -c "$f" | postgresql_execute "${PG_DATABASE}" "${PG_INITSCRIPTS_USERNAME}" "${PG_INITSCRIPTS_PASSWORD}" gunzip -c "$f" | postgresql_execute "${PG_DATABASE}" "${PG_INITSCRIPTS_USERNAME}" "${PG_INITSCRIPTS_PASSWORD}"
;; ;;
*) *)
LOG_D "Ignoring $f" ;; LOG_D "Ignoring $f" ;;
esac esac
done done
@@ -431,6 +422,5 @@ app_custom_init() {
LOG_I "Custom init for ${APP_NAME} already done before, skipping initialization." LOG_I "Custom init for ${APP_NAME} already done before, skipping initialization."
fi fi
fi fi
} }
+17 -8
View File
@@ -7,21 +7,30 @@
# -e: 命令执行错误则报错(errexit); -u: 变量未定义则报错(nounset); -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错 # -e: 命令执行错误则报错(errexit); -u: 变量未定义则报错(nounset); -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错
set -euo pipefail set -euo pipefail
. /colovu/lib/libcommon.sh # 加载通用函数库 . /colovu/lib/libcommon.sh # 加载通用函数库
. /usr/local/bin/environment.sh # 设置环境变量
LOG_I "** Processing entry.sh **" LOG_I "** Processing entry.sh **"
# 检测是否仅打印帮助信息(CMD 命令第一个参数以'-'起始) # 优先处理'-'开始的版本信息、帮助信息显示命令,如果是该类命令,处理后退出容器
[[ "${1:0:1}" == '-' ]] && "${APP_EXEC:-${APP_NAME:-/bin/bash}}" "$@" || exit [[ "${1:0:1}" == '-' ]] && print_command_help
# 判断是否为 root 用户 # 处理 root 用户**且**使用默认启动脚本时的初始化
if [[ "$(id -u)" == '0' ]]; then if [[ "$(id -u)" == '0' ]] && [[ "$1" == "run.sh" ]]; then
print_image_welcome print_welcome_info
/usr/local/bin/setup.sh /usr/local/bin/setup.sh
# 使用非 root 用户执行 CMD 命令,并替换当前进程
# 执行应用启动脚本并替换当前进程
exec gosu "${APP_USER}" "$@" exec gosu "${APP_USER}" "$@"
fi fi
# 处理 root 用户**且**使用init.sh脚本时的初始化
if [[ "$(id -u)" == '0' ]] && [[ "$1" == "init.sh" ]]; then
/usr/local/bin/setup.sh
/usr/local/bin/init.sh
fi
# 处理非以上情形的自定义命令
LOG_I "Start container with command: $@" LOG_I "Start container with command: $@"
# 执行'$@'定义的指令,并替换当前进程
exec "$@" exec "$@"
+12 -5
View File
@@ -3,11 +3,10 @@
# #
# 应用环境变量定义及初始化 # 应用环境变量定义及初始化
# 通用设置
export ENV_DEBUG=${ENV_DEBUG:-false} export ENV_DEBUG=${ENV_DEBUG:-false}
export ALLOW_ANONYMOUS="${ALLOW_ANONYMOUS:-no}" export ALLOW_ANONYMOUS="${ALLOW_ANONYMOUS:-no}"
# 通过读取变量名对应的 *_FILE 文件,获取变量值;如果对应文件存在,则通过传入参数设置的变量值会被文件中对应的值覆盖 # 通过读取变量名对应的`*_FILE`文件,获取变量值
# 变量优先级: *_FILE > 传入变量 > 默认值 # 变量优先级: *_FILE > 传入变量 > 默认值
app_env_file_lists=( app_env_file_lists=(
APP_PASSWORD APP_PASSWORD
@@ -21,15 +20,23 @@ for env_var in "${app_env_file_lists[@]}"; do
done done
unset app_env_file_lists unset app_env_file_lists
# 应用路径参数 # 应用路径参数Dockerfile 已定义:APP_NAME、APP_VER,可能定义 APP_USER、APP_EXEC
export APP_EXEC="${APP_EXEC:-${APP_NAME}}"
export APP_USER="${APP_USER:-${APP_NAME}}"
export APP_GROUP="${APP_USER:-${APP_NAME}}"
export APP_HOME="${APP_HOME:-/srv/${APP_NAME}}"
export APP_BASE="${APP_BASE:-/usr/local/${APP_NAME}}"
export APP_DEF_DIR="${APP_BASE}/etc/${APP_NAME}" export APP_DEF_DIR="${APP_BASE}/etc/${APP_NAME}"
export APP_CONF_DIR="/srv/${APP_NAME}/conf" export APP_CONF_DIR="/srv/${APP_NAME}/conf"
export APP_DATA_DIR="/srv/${APP_NAME}/data" export APP_DATA_DIR="/srv/${APP_NAME}/data"
export APP_CERT_DIR="/srv/${APP_NAME}/cert"
export APP_LOG_DIR="/srv/${APP_NAME}/log"
export APP_CACHE_DIR="/var/cache/${APP_NAME}"
export APP_RUN_DIR="/var/run/${APP_NAME}"
# 应用配置参数 # 应用配置参数
export APP_CONF_FILE=${APP_CONF_DIR}/default.conf export APP_CONF_FILE=${APP_CONF_DIR}/default.conf
# 内部变量
export APP_PID_FILE="${APP_PID_FILE:-/var/run/${APP_NAME}/${APP_NAME}.pid}" export APP_PID_FILE="${APP_PID_FILE:-/var/run/${APP_NAME}/${APP_NAME}.pid}"
# 个性化变量 # 个性化变量
+25
View File
@@ -0,0 +1,25 @@
#!/bin/bash
# Ver: 1.2 by Endial Fang (endial@126.com)
#
# 应用初始化脚本
# 设置 shell 执行参数,可使用'-'(打开)'+'(关闭)控制。常用:
# -e: 命令执行错误则报错; -u: 变量未定义则报错; -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错
set -euo pipefail
. /usr/local/bin/environment.sh # 设置环境变量
. /usr/local/bin/common.sh # 应用专用函数库
LOG_I "** Processing init.sh **"
trap "app_stop_server" EXIT
app_verify_minimum_env
# 执行应用预初始化操作
app_custom_preinit
# 执行应用初始化操作
app_default_init
# 执行用户自定义初始化脚本
app_custom_init
+6 -8
View File
@@ -1,25 +1,23 @@
#!/bin/bash #!/bin/bash
# Ver: 1.5 by Endial Fang (endial@126.com) # Ver: 1.5 by Endial Fang (endial@126.com)
# #
# 应用启动脚本 # 应用启动脚本;组合默认的配置参数及容器启动时传入的 CMD 参数,启动应用
# 组合默认的配置参数及容器启动时传入的 CMD 参数,启动应用
# 设置 shell 执行参数,可使用'-'(打开)'+'(关闭)控制。常用: # 设置 shell 执行参数,可使用'-'(打开)'+'(关闭)控制。常用:
# -e: 命令执行错误则报错(errexit); -u: 变量未定义则报错(nounset); -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错 # -e: 命令执行错误则报错(errexit); -u: 变量未定义则报错(nounset); -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错
set -euo pipefail set -euo pipefail
. /colovu/lib/liblog.sh # 日志输出函数库
. /usr/local/bin/environment.sh # 设置环境变量 . /usr/local/bin/environment.sh # 设置环境变量
LOG_I "** Processing run.sh **" LOG_I "** Processing run.sh **"
# 获取命令的实际路径信
readonly START_COMMAND="$(command -v ${APP_EXEC:-${APP_NAME}})" readonly START_COMMAND="$(command -v ${APP_EXEC:-${APP_NAME}})"
# 配置默认启动参数(应用配置文件、前台方式启动) # 配置默认启动参数(应用配置文件、前台方式启动)
flags=("-c" "${APP_CONF_FILE:-}") flags=()
[[ -z "${APP_EXTRA_FLAGS:-}" ]] || flags+=("${APP_EXTRA_FLAGS[@]}") [[ -n "${APP_CONF_FILE:-}" ]] && flags+=("-c" "${APP_CONF_FILE}")
[[ -n "${APP_EXTRA_FLAGS:-}" ]] && flags+=("${APP_EXTRA_FLAGS[@]}")
# 使用 "$@" 添加镜像默认 CMD 内容或自定义命令内容
flags+=("$@") flags+=("$@")
LOG_I "Start ${APP_NAME} with command: ${START_COMMAND[@]} ${flags[@]}" LOG_I "Start ${APP_NAME} with command: ${START_COMMAND[@]} ${flags[@]}"
+7 -20
View File
@@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
# Ver: 1.3 by Endial Fang (endial@126.com) # Ver: 1.3 by Endial Fang (endial@126.com)
# #
# 应用环境及依赖文件设置脚本 # 应用环境及依赖文件设置脚本;当前脚本以‘root’用户执行
# 设置 shell 执行参数,可使用'-'(打开)'+'(关闭)控制。常用: # 设置 shell 执行参数,可使用'-'(打开)'+'(关闭)控制。常用:
# -e: 命令执行错误则报错(errexit); -u: 变量未定义则报错(nounset); -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错 # -e: 命令执行错误则报错(errexit); -u: 变量未定义则报错(nounset); -x: 打印实际待执行的命令行; -o pipefail: 设置管道中命令遇到失败则报错
@@ -16,33 +16,20 @@ set -euo pipefail
LOG_I "** Processing setup.sh **" LOG_I "** Processing setup.sh **"
trap "app_stop_server" EXIT APP_DIRS=(/var/log/${APP_NAME} /var/run/${APP_NAME} /var/cache/${APP_NAME} ${APP_HOME})
APP_DIRS+=(${APP_HOME}/conf ${APP_HOME}/data ${APP_HOME}/cert ${APP_HOME}/log)
APP_DIRS="/var/log/${APP_NAME} /var/run/${APP_NAME} /var/cache/${APP_NAME} ${APP_HOME}" LOG_I "Ensure directory exists: ${APP_DIRS[@]}"
APP_DIRS+="${APP_HOME}/conf ${APP_HOME}/data ${APP_HOME}/cert" for dir in ${APP_DIRS[@]}; do
LOG_I "Ensure directory exists: ${APP_DIRS}"
for dir in ${APP_DIRS}; do
ensure_dir_exists ${dir} ensure_dir_exists ${dir}
done done
# 检测指定文件是否在配置文件存储目录存在,如果不存在则拷贝(新挂载数据卷、手动删除都会导致不存在) # 检测指定文件是否在配置文件存储目录存在,如果不存在则拷贝(新挂载数据卷、手动删除都会导致不存在)
LOG_I "Check config files in: ${APP_CONF_DIR}" LOG_I "Check config files in: ${APP_CONF_DIR}"
if [[ ! -z "$(ls -A "${APP_DEF_DIR}")" ]]; then if [[ -z "$(ls -A "${APP_CONF_DIR}")" ]]; then
ensure_config_file_exist "${APP_DEF_DIR}" $(ls -A "${APP_DEF_DIR}") app_ensure_config_file_exist "${APP_CONF_DIR}" "${APP_DEF_DIR}" $(ls -A "${APP_DEF_DIR}")
fi fi
# 解决使用non-root后,[emerg] open() "/dev/stdout" failed (13: Permission denied) # 解决使用non-root后,[emerg] open() "/dev/stdout" failed (13: Permission denied)
LOG_D "Change permissions of stdout/stderr to 0662" LOG_D "Change permissions of stdout/stderr to 0662"
chmod 0662 /dev/stdout /dev/stderr chmod 0662 /dev/stdout /dev/stderr
app_verify_minimum_env
# 执行应用预初始化操作
app_custom_preinit
# 执行应用初始化操作
app_default_init
# 执行用户自定义初始化脚本
app_custom_init
Binary file not shown.