Files
tools/examples/remote_example.sh
Wang Defa b34e1ef872 feat: 为所有脚本添加远程库加载支持
## 功能概述

实现了智能远程库加载机制,允许脚本从远程 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 自动删除
2025-12-26 15:00:06 +08:00

63 lines
1.9 KiB
Bash
Executable File

#!/bin/bash
# ============================================================================
# 文件名: remote_example.sh
# 描述: 使用远程库的示例脚本
# 作者: Cloud Tools Project
# 版本: 1.0.0
# ============================================================================
set -euo pipefail
#
# 远程库加载方式(二选一)
#
# 方式 1: 直接使用远程加载器(推荐)
# 这会从远程仓库下载最新的公共库
if command -v curl &>/dev/null || command -v wget &>/dev/null; then
# 下载并执行远程加载器
if command -v curl &>/dev/null; then
# shellcheck disable=SC1090
source <(curl -fsSL https://gitea.bcde.io/wangdefa/tools/raw/branch/main/common/remote_loader.sh)
else
# shellcheck disable=SC1090
source <(wget -qO- https://gitea.bcde.io/wangdefa/tools/raw/branch/main/common/remote_loader.sh)
fi
else
echo "[ERROR] 需要 curl 或 wget 来下载远程库" >&2
exit 1
fi
# 方式 2: 使用本地的远程加载器(如果已经克隆了仓库)
# SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
# PROJECT_ROOT="$(dirname "$SCRIPT_DIR")"
# source "${PROJECT_ROOT}/common/remote_loader.sh"
#
# 主函数 - 使用远程加载的公共库
#
main() {
log_info "============ 远程库使用示例 ============"
# 使用日志函数
log_info "这是一条普通信息"
log_success "这是一条成功信息"
log_warning "这是一条警告信息"
log_error "这是一条错误信息(但不会退出)"
# 使用错误处理函数
log_info "检查命令是否存在..."
if check_command "bash"; then
log_success "bash 命令存在"
fi
# 使用 run_command 执行命令
log_info "执行示例命令..."
run_command "列出当前目录" ls -lah
log_success "所有功能正常!"
}
# 执行主函数
main "$@"