feat: 优化默认模板
This commit is contained in:
+26
-32
@@ -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 [] # 空命令,启动容器时如不设置相应命令,容器会在启动后直接退出(一般用于基础镜像)
|
||||||
|
|||||||
@@ -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 文件
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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 "$@"
|
||||||
|
|||||||
@@ -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}"
|
||||||
|
|
||||||
# 个性化变量
|
# 个性化变量
|
||||||
|
|||||||
Executable
+25
@@ -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
|
||||||
@@ -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[@]}"
|
||||||
|
|||||||
@@ -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.
Reference in New Issue
Block a user