## 功能概述 实现了智能远程库加载机制,允许脚本从远程 Gitea 仓库动态下载公共库, 同时保留本地库优先的策略,确保脚本可以独立运行而不依赖本地项目结构。 ## 变更内容 ### 新增文件 - **common/remote_loader.sh**: 核心远程加载器 - 支持 curl/wget 双重下载方式 - 临时文件自动清理机制 - 环境变量可配置仓库 URL - **examples/remote_example.sh**: 纯远程模式示例 - 演示完全独立的远程加载脚本 - 适合单文件分发场景 - **examples/hybrid_loader_template.sh**: 混合模式模板 - 本地优先 + 远程回退策略 - 适合仓库内脚本 - **examples/REMOTE_LOADER_README.md**: 完整使用文档 - 三种使用模式详解 - 故障排除指南 - 最佳实践建议 ### 更新脚本(版本 2.1.0) 所有主要脚本均升级到 2.1.0 版本,支持智能库加载: - **linux/create_raid0_array.sh** - **linux/repartition_disks.sh** - **linux/install_oh_my_zsh.sh** - **gcp/create_ai_projects.sh** - **gcp/delete_all_projects.sh** - **oci/create_instance.sh** - **common/demo_usage.sh** ## 加载策略 1. 检查 FORCE_REMOTE=1 环境变量 → 强制远程 2. 检查本地库存在性 → 优先使用本地 3. 本地不存在 → 自动回退远程 4. 远程失败 → 友好错误提示 ## 使用示例 ### 本地模式(默认) ```bash ./linux/create_raid0_array.sh ``` ### 强制远程模式 ```bash FORCE_REMOTE=1 ./linux/create_raid0_array.sh ``` ### 自定义仓库 URL ```bash REMOTE_LIB_URL=https://example.com/repo ./script.sh ``` ## 技术特性 - ✅ 向后兼容:默认使用本地库,行为不变 - ✅ 离线可用:本地库存在时无需网络 - ✅ 独立分发:支持单文件脚本分发 - ✅ 错误处理:详细的错误信息和诊断建议 - ✅ 环境可配:REMOTE_LIB_URL 和 FORCE_REMOTE - ✅ 自动清理:临时文件通过 trap 自动删除
238 lines
6.1 KiB
Bash
Executable File
238 lines
6.1 KiB
Bash
Executable File
#!/bin/bash
|
||
# ============================================================================
|
||
# 文件名: demo_usage.sh
|
||
# 描述: 公共函数库功能演示和使用示例
|
||
# 作者: Cloud Tools Project
|
||
# 版本: 2.1.0(支持远程库加载)
|
||
# ============================================================================
|
||
|
||
set -euo pipefail
|
||
|
||
# ============================================================================
|
||
# 远程库加载配置
|
||
# ============================================================================
|
||
|
||
# 远程仓库 URL(可通过环境变量覆盖)
|
||
readonly REMOTE_BASE_URL="${REMOTE_LIB_URL:-https://gitea.bcde.io/wangdefa/tools/raw/branch/main}"
|
||
|
||
# 获取脚本目录(用于本地加载)
|
||
readonly SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||
readonly PROJECT_ROOT="$(dirname "$SCRIPT_DIR")"
|
||
|
||
#
|
||
# 智能加载公共库
|
||
#
|
||
# 加载策略:
|
||
# 1. 如果 FORCE_REMOTE=1,强制使用远程库
|
||
# 2. 否则尝试使用本地库
|
||
# 3. 本地库不存在时自动回退到远程库
|
||
#
|
||
load_common_libs() {
|
||
local use_remote=false
|
||
|
||
# 检查是否强制远程
|
||
if [[ "${FORCE_REMOTE:-0}" == "1" ]]; then
|
||
echo "[INFO] 强制使用远程库 (FORCE_REMOTE=1)" >&2
|
||
use_remote=true
|
||
# 检查本地库是否存在
|
||
elif [[ -f "${PROJECT_ROOT}/common/logging.sh" ]] && [[ -f "${PROJECT_ROOT}/common/error_handler.sh" ]]; then
|
||
# shellcheck disable=SC1091
|
||
source "${PROJECT_ROOT}/common/logging.sh"
|
||
# shellcheck disable=SC1091
|
||
source "${PROJECT_ROOT}/common/error_handler.sh"
|
||
return 0
|
||
else
|
||
echo "[WARN] 本地库不存在,使用远程库" >&2
|
||
use_remote=true
|
||
fi
|
||
|
||
# 使用远程库
|
||
if [[ "$use_remote" == "true" ]]; then
|
||
if command -v curl &>/dev/null; then
|
||
echo "[INFO] 使用 curl 下载远程库..." >&2
|
||
# shellcheck disable=SC1090
|
||
if source <(curl -fsSL "${REMOTE_BASE_URL}/common/remote_loader.sh" 2>/dev/null); then
|
||
return 0
|
||
fi
|
||
elif command -v wget &>/dev/null; then
|
||
echo "[INFO] 使用 wget 下载远程库..." >&2
|
||
# shellcheck disable=SC1090
|
||
if source <(wget -qO- "${REMOTE_BASE_URL}/common/remote_loader.sh" 2>/dev/null); then
|
||
return 0
|
||
fi
|
||
fi
|
||
|
||
echo "[ERROR] 无法加载公共库" >&2
|
||
echo "[ERROR] - 本地库不存在" >&2
|
||
echo "[ERROR] - 远程下载失败(需要 curl 或 wget)" >&2
|
||
echo "[ERROR] - 仓库 URL: ${REMOTE_BASE_URL}" >&2
|
||
exit 1
|
||
fi
|
||
}
|
||
|
||
# 加载公共库
|
||
load_common_libs
|
||
|
||
#
|
||
# 示例 1: 基本日志使用
|
||
#
|
||
example_basic_logging() {
|
||
log_info "============ 示例 1: 基本日志使用 ============"
|
||
|
||
log_debug "这是调试信息(默认不显示)"
|
||
log_info "这是普通信息"
|
||
log_warning "这是警告信息"
|
||
log_error "这是错误信息(但不会退出)"
|
||
log_success "这是成功信息"
|
||
|
||
echo ""
|
||
}
|
||
|
||
#
|
||
# 示例 2: 日志级别控制
|
||
#
|
||
example_log_levels() {
|
||
log_info "============ 示例 2: 日志级别控制 ============"
|
||
|
||
log_info "当前日志级别: INFO"
|
||
log_debug "这条调试信息不会显示"
|
||
|
||
log_info "切换到 DEBUG 级别..."
|
||
log_set_level "DEBUG"
|
||
log_debug "现在调试信息可以显示了!"
|
||
|
||
log_info "恢复到 INFO 级别..."
|
||
log_set_level "INFO"
|
||
|
||
echo ""
|
||
}
|
||
|
||
#
|
||
# 示例 3: 错误检查
|
||
#
|
||
example_error_checking() {
|
||
log_info "============ 示例 3: 错误检查 ============"
|
||
|
||
# 临时禁用自动退出
|
||
disable_exit_on_error
|
||
|
||
# 检查命令
|
||
if check_command "bash"; then
|
||
log_success "bash 命令存在"
|
||
fi
|
||
|
||
if ! check_command "nonexistent_command"; then
|
||
log_warning "nonexistent_command 不存在(这是预期的)"
|
||
fi
|
||
|
||
# 检查文件
|
||
if check_file "${SCRIPT_DIR}/logging.sh"; then
|
||
log_success "logging.sh 文件存在"
|
||
fi
|
||
|
||
# 检查变量非空
|
||
local test_var="hello"
|
||
if check_not_empty "$test_var" "test_var"; then
|
||
log_success "test_var 变量非空"
|
||
fi
|
||
|
||
# 重新启用自动退出
|
||
enable_exit_on_error
|
||
|
||
echo ""
|
||
}
|
||
|
||
#
|
||
# 示例 4: 命令执行和重试
|
||
#
|
||
example_command_execution() {
|
||
log_info "============ 示例 4: 命令执行 ============"
|
||
|
||
# 执行简单命令
|
||
run_command "列出文件失败" ls -la "${SCRIPT_DIR}"
|
||
|
||
log_info "执行成功的命令"
|
||
|
||
# 临时禁用自动退出来演示重试
|
||
disable_exit_on_error
|
||
|
||
log_info "尝试执行一个会失败的命令(演示重试)"
|
||
retry_command 3 1 "命令失败" false
|
||
|
||
# 重新启用
|
||
enable_exit_on_error
|
||
|
||
echo ""
|
||
}
|
||
|
||
#
|
||
# 示例 5: 日志文件输出
|
||
#
|
||
example_log_file() {
|
||
log_info "============ 示例 5: 日志文件输出 ============"
|
||
|
||
local temp_log="/tmp/common_lib_example_$$.log"
|
||
|
||
log_info "设置日志输出到文件: $temp_log"
|
||
log_set_file "$temp_log"
|
||
|
||
log_info "这条消息会同时输出到控制台和文件"
|
||
log_success "日志文件功能正常"
|
||
|
||
log_info "日志文件内容:"
|
||
cat "$temp_log"
|
||
|
||
# 清理
|
||
rm -f "$temp_log"
|
||
|
||
echo ""
|
||
}
|
||
|
||
#
|
||
# 示例 6: 时间戳控制
|
||
#
|
||
example_timestamp() {
|
||
log_info "============ 示例 6: 时间戳控制 ============"
|
||
|
||
log_info "默认启用时间戳"
|
||
|
||
log_info "禁用时间戳..."
|
||
log_disable_timestamp
|
||
log_info "这条消息没有时间戳"
|
||
|
||
log_info "启用时间戳..."
|
||
log_enable_timestamp
|
||
log_info "时间戳已恢复"
|
||
|
||
echo ""
|
||
}
|
||
|
||
#
|
||
# 主函数
|
||
#
|
||
main() {
|
||
# 配置日志
|
||
log_set_level "INFO"
|
||
log_enable_timestamp
|
||
|
||
log_success "==================================================="
|
||
log_success " 公共函数库使用示例"
|
||
log_success "==================================================="
|
||
echo ""
|
||
|
||
# 执行所有示例
|
||
example_basic_logging
|
||
example_log_levels
|
||
example_error_checking
|
||
example_command_execution
|
||
example_log_file
|
||
example_timestamp
|
||
|
||
log_success "==================================================="
|
||
log_success " 所有示例执行完成!"
|
||
log_success "==================================================="
|
||
}
|
||
|
||
# 执行主函数
|
||
main "$@"
|