boxxy

boxxy

Linux应用程序文件重定向工具 提升系统整洁度

boxxy是一款Linux工具,用于管理应用程序的文件和目录。它通过Linux命名空间技术,实现文件重定向功能,强制应用将文件放置在指定位置,无需使用符号链接。boxxy支持上下文相关规则、项目本地配置、环境变量注入和后台进程运行,提供灵活的文件管理方案,有助于保持系统整洁。

boxxyLinux文件重定向配置管理命名空间Github开源项目

boxxy

boxxy(区分大小写)是一个用于约束不守规矩的 Linux 应用程序的工具,它可以强制这些应用程序将文件和目录放在正确的位置,而无需使用符号链接!

boxxy 是 amyware discord 服务器 的一部分。

如果你喜欢我的作品,可以考虑在 Patreon 上支持我:

<img src="https://i.imgur.com/YFjoCd1.png" width="162" height="38" />

仅限 Linux!boxxy 使用 Linux 命名空间来实现其功能。

例如,考虑 tmux。它想要将其配置文件放在 ~/.tmux.conf 中。使用 boxxy,你可以将其配置文件放在 ~/.config/tmux/tmux.conf 中:

# ~/.config/boxxy/boxxy.yaml rules: - name: "将 tmux 配置从 ~/.tmux.conf 重定向到 ~/.config/tmux/tmux.conf" target: "~/.tmux.conf" rewrite: "~/.config/tmux/tmux.conf" mode: "file"

asciicast

动机

最近我不得不使用 AWS CLI。它想要将数据保存在 ~/.aws 中,但我不希望它随意地弄乱我的 $HOME。boxxy 让我可以强制它将数据放在一个合适的位置。

特性

  • 约束任何程序,强制它将文件/目录放在你想要的位置
  • 上下文相关的约束,即根据你的配置,在不同的目录中应用不同的规则
  • 最小化开销
  • 可选的不可变文件系统(除规则重写外),即只有你在规则中指定的文件/目录是可写的
  • 0.5.0:boxxy 可以扫描你的主目录,自动为你推荐规则!boxxy 扫描图片
  • 0.6.0:boxxy 可以使用项目本地的 boxxy.yaml 文件,并可以为你加载 .env 文件!0.6.0 功能图片
  • 0.6.1:boxxy 规则可以注入环境变量:0.6.1 功能图片
  • 0.7.2:boxxy 可以使用 --daemon 标志将被约束的进程分叉到后台。
  • 0.8.0:boxxy 可以通过命令行使用 --rule 传递规则,并使用 --no-config 禁用加载配置文件。
  • 0.8.2:解释如何正确运行 AppImages:0.8.2 功能图片

潜在缺点

  • 新项目,版本号为 0.x.y,附带所有相关警告
  • 无法在容器内使用 sudo(参见 #6
  • 主要针对我的使用场景进行测试

使用示例

git:(mistress) | ▶ cat ~/.config/boxxy/boxxy.yaml rules: - name: "将 AWS CLI 配置存储在 ~/.config/aws 中" target: "~/.aws" rewrite: "~/.config/aws" git:(mistress) | ▶ boxxy aws configure INFO boxxy > 加载了 1 条规则 INFO boxxy::enclosure > 应用规则 '将 AWS CLI 配置存储在 ~/.config/aws 中' INFO boxxy::enclosure > 重定向:~/.aws -> ~/.config/aws INFO boxxy::enclosure > 已约束 "aws" ♥ AWS Access Key ID [****************d]: a AWS Secret Access Key [****************c]: b Default region name [b]: c Default output format [a]: d git:(mistress) | ▶ ls ~/.aws git:(mistress) | ▶ ls ~/.config/aws config credentials git:(mistress) | ▶ cat ~/.config/aws/config [default] region = c output = d git:(mistress) | ▶

建议用法

  • alias aws="boxxy aws"(对其他工具重复此操作)
  • 使用上下文将项目配置分开存储在磁盘上
  • 点文件!
  • 停止使用符号链接!!!
  • 编写代码时不再有开发配置文件

配置

boxxy 配置文件位于 ~/.config/boxxy/boxxy.yaml。如果不存在,将为你创建一个空的配置文件。

rules: # 规则名称。用户友好的名称,供你参考 - name: "将 aws-cli 从 ~/.aws 重定向到 ~/.config/aws" # 规则的目标,即将被重写覆盖的文件/目录。 target: "~/.aws" # 规则的重写,即将替代目标使用的文件/目录。 rewrite: "~/.config/aws" - name: "在 ~/Projects/my-cool-startup 中使用不同的 k8s 配置" target: "~/.kube/config" rewrite: "~/Projects/my-cool-startup/.kube/config" # 规则的上下文。上下文中列出的任何路径都是此规则适用的路径。 # 如果未指定上下文,则规则全局适用。 context: - "~/Projects/my-cool-startup" # 此规则的模式,可以是 `directory` 或 `file`。默认为 `directory`。 # 当目标是文件时必须指定以获得正确的行为。 # 需要指定是因为目标文件/目录可能还不存在。 mode: "file" # 此规则适用的命令列表。如果未指定命令, # 则规则适用于所有使用 boxxy 运行的程序。 only: - "kubectl"

语法

rules: - name: "任何有效字符串" # 必需 target: "路径" # 必需 rewrite: "路径" # 必需 context: # 可选 - "路径" - "路径" mode: "directory | file" # 可选 only: # 可选 - "二进制名称" - "二进制名称" env: # 可选 KEY: "值"

开发

  1. 设置 pre-commit:pre-commit install
  2. 确保它能构建:cargo build
  3. 开始开发!
  4. 使用你选择的命令进行测试,例如 cargo run -- ls -lah ~/.config

它是如何工作的?

  • 在 /tmp 中创建临时目录
  • 设置新的用户/挂载命名空间
  • / 绑定挂载到临时目录
  • 以读写方式绑定挂载规则挂载点,以便目标程序可以使用它们
  • / 重新挂载为只读
  • 运行!

致谢

编辑推荐精选

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
OmniParser

OmniParser

帮助AI理解电脑屏幕 纯视觉GUI元素的自动化解析方案

开源工具通过计算机视觉技术实现图形界面元素的智能识别与结构化处理,支持自动化测试脚本生成和辅助功能开发。项目采用模块化设计,提供API接口与多种输出格式,适用于跨平台应用场景。核心算法优化了元素定位精度,在动态界面和复杂布局场景下保持稳定解析能力。

OmniParser界面解析交互区域检测Github开源项目
Grok3

Grok3

埃隆·马斯克旗下的人工智能公司 xAI 推出的第三代大规模语言模型

Grok3 是由埃隆·马斯克旗下的人工智能公司 xAI 推出的第三代大规模语言模型,常被马斯克称为“地球上最聪明的 AI”。它不仅是在前代产品 Grok 1 和 Grok 2 基础上的一次飞跃,还在多个关键技术上实现了创新突破。

腾讯元宝

腾讯元宝

腾讯自研的混元大模型AI助手

腾讯元宝是腾讯基于自研的混元大模型推出的一款多功能AI应用,旨在通过人工智能技术提升用户在写作、绘画、翻译、编程、搜索、阅读总结等多个领域的工作与生活效率。

AI助手AI对话AI工具腾讯元宝智能体热门 AI 办公助手
Windsurf Wave 3

Windsurf Wave 3

Windsurf Editor推出第三次重大更新Wave 3

新增模型上下文协议支持与智能编辑功能。本次更新包含五项核心改进:支持接入MCP协议扩展工具生态,Tab键智能跳转提升编码效率,Turbo模式实现自动化终端操作,图片拖拽功能优化多模态交互,以及面向付费用户的个性化图标定制。系统同步集成DeepSeek、Gemini等新模型,并通过信用点数机制实现差异化的资源调配。

AI IDE
Cursor

Cursor

增强编程效率的AI代码编辑器

Cursor作为AI驱动的代码编辑工具,助力开发者效率大幅度提升。该工具简化了扩展、主题和键位配置的导入,可靠的隐私保护措施保证代码安全,深受全球开发者信赖。此外,Cursor持续推出更新,不断优化功能和用户体验。

AI开发辅助编程AI工具CursorAI代码编辑器
Manus

Manus

全面超越基准的 AI Agent助手

Manus 是一款通用人工智能代理平台,能够将您的创意和想法迅速转化为实际成果。无论是定制旅行规划、深入的数据分析,还是教育支持与商业决策,Manus 都能高效整合信息,提供精准解决方案。它以直观的交互体验和领先的技术,为用户开启了一个智慧驱动、轻松高效的新时代,让每个灵感都能得到完美落地。

飞书��知识问答

飞书知识问答

飞书官方推出的AI知识库 上传word pdf即可部署AI私有知识库

基于DeepSeek R1大模型构建的知识管理系统,支持PDF、Word、PPT等常见文档格式解析,实现云端与本地数据的双向同步。系统具备实时网络检索能力,可自动关联外部信息源,通过语义理解技术处理结构化与非结构化数据。免费版本提供基础知识库搭建功能,适用于企业文档管理和个人学习资料整理场景。

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
DeepEP

DeepEP

DeepSeek开源的专家并行通信优化框架

DeepEP是一个专为大规模分布式计算设计的通信库,重点解决专家并行模式中的通信瓶颈问题。其核心架构采用分层拓扑感知技术,能够自动识别节点间物理连接关系,优化数据传输路径。通过实现动态路由选择与负载均衡机制,系统在千卡级计算集群中维持稳定的低延迟特性,同时兼容主流深度学习框架的通信接口。

下拉加载更多