1 个不稳定版本
0.0.13 | 2024年2月3日 |
---|
#2047 在 异步
99 每月下载
在 9 个crate中使用了 (2 个直接使用)
7KB
🕊️ peace – 无压力自动化
peace
是一个构建富有同情心和宽容的软件自动化的框架。
查看
指导原则
- 使用愉快。
- 符合人体工程学的API和指导,帮助用户正确操作。
- 输出易于理解。
特性
符号 | 意义 |
---|---|
🟢 | 表现良好 |
🟡 | 部分支持 |
⚫ | 计划中 |
🔵 | 设计兼容 |
🟣 | 有创意,表现良好 |
- 🟢 幂等性:多次调用会产生相同的结果。
- 🟢 整洁:每个对象的创建都与清理方式相匹配。
- 🟢 可理解性:以可理解的方式展示进度。
- 🔵 可理解性:错误报告与
miette
兼容。 - 🟡 可中断性:执行可以中断。
- 🟢 可恢复性:自动化可以在中断处恢复。
- 🟢 可区分性:状态和差异以YAML序列化。
- 🟢 高效性:通过
fn_graph
并发执行任务。 - 🟢 命名空间化:配置文件目录相互隔离环境。
- 🟢 类型安全:项和参数在代码中定义,而不是在配置中。
路线图
- 🟢 定义要管理的项。
- 🟢 定义项之间的依赖关系。
- 🟢 定义 "应用" 逻辑。
- 🟢 定义 "清理" 逻辑。
- 🟢 发现当前和目标状态。
- 🟢 定义状态之间的差异计算。
- 🟢 在多个命令间存储和调用参数。
- 🟢 保存和调用多个配置文件的状态差异。
- 🟢 类型安全的引用参数 -- 将自动化过程中生成的值作为后续项目的参数进行指定。
- 🟡 特性门控的增量功能。
- 🟡 常用项目的现成支持。
- 🟡 干运行。
- 🟣 WASM 支持。
- ⚫ 通过
tokio-graceful-shutdown
实现取消安全的中断。 - ⚫ 设计安全支持:加密值存储,按执行/时间基于代理解密。
- ⚫ 编写软件生命周期管理工具的教程。
- ⚫ 内置应用程序执行方法 -- 命令行界面、网络服务。
- ⚫ 基于
peace
的配置工作流二进制文件。 - ⚫ 带交互图的基于网络的用户界面。
- ⚫ 代理模式在服务器上运行
peace
(Web API 调用)。
其他想法
- 备份当前状态。
- 恢复先前的状态。
- 遥测/指标日志分析。
示例
示例使用 --package
而不是 --example
运行,因为每个示例都组织为其自己的包。
cargo run --package $example_name --all-features
# e.g.
cargo build --package download --all-features
cargo run -q --package download --all-features -- init https://ifconfig.me ip.json
for cmd in status goal diff ensure ensure diff clean clean diff
do
printf "=== ${cmd} ===\n"
cargo run -q --package download --all-features -- --format text $cmd
printf '\n'
done
# Look at metadata that Peace has saved
find .peace -type f -exec bash -c 'echo \# {}; cat {}; echo' \;
# Clean up the metadata directory
rm -rf .peace
WASM
可以使用 wasm-pack
将 download
示例构建为 WebAssembly 应用程序。
cd examples/download
wasm-pack build --target web
在 examples/download
目录中,启动一个 HTTP 服务器,并打开 https://127.0.0.1:8000/
python3 -m http.server 8000 # or
simple-http-server --nocache --port 8000 -i
许可证
许可协议为以下之一:
- Apache 许可协议,版本 2.0,(LICENSE-APACHE 或 https://www.apache.org/licenses/LICENSE-2.0)
- MIT 许可协议(LICENSE-MIT 或 https://opensource.org/licenses/MIT)
任选其一。
贡献
除非你明确声明,否则根据 Apache-2.0 许可协议定义,你提交给作品以包含在内的任何有意贡献,都将如上双许可,没有任何额外条款或条件。