开发了一个管理本地开发环境的软件

作者:神奇的程序员日期:2026/5/5

333

前言

前阵子换了新电脑,我在整理本地开发环境时,看到一堆需要重新装的,顿时感觉好麻烦。想着都过去这么久了,应该有工具可以做到统一管理,实现快速安装、更新、切换版本吧。

经过一番查找后,找到了mise这个东西,只需要简单的一句命令就能安装java、node、redis、go等工具,而且还支持对这些工具做统一管理(更新、删除),支持三大主流平台(macOS/Windows/Linux)

命令行始终不方便,于是我萌生了一个做GUI的想法,花了亿点时间用Flutter把它开发出来了,欢迎各位有需要的开发者阅读本文。

项目地址

demo-img-1.png

主要解决什么问题?

对于我这种经常切换项目的人来说,纯命令行总感觉不是很直观。

比如我想知道:

  • 当前电脑装了哪些工具?
  • node、python、java、go这些工具当前用的是哪个版本?
  • 哪些项目里的mise.toml覆盖了全局版本?
  • 我现在执行安装、切换、卸载,到底会影响哪些文件?
  • 上一次通过界面执行命令失败了,具体错误是什么?

这些事情,命令行当然都能查,但需要来回敲命令,有时候还要打开配置文件对比。Mise GUI想做的就是把这些常用信息集中到一个界面里,让本地环境管理更直观一点。

实现效果

目前主要做了4个功能:

  • 环境总览
  • 工具版本
  • 项目覆盖
  • 配置管理

环境总览

总览页主要用于快速查看当前机器的开发环境状态。

这里会展示当前系统、已安装工具数量、项目覆盖情况、mise版本以及最近通过界面执行过的操作。

demo-img-1.png

工具版本

工具模块是本软件的核心功能之一。

它会展示每个工具的当前版本和最新版本,比如Flutter、Go、Java、Python等。

demo-img-2.png

点进某个工具后,可以查看这个工具的已安装版本、远端可安装版本、当前版本来源,以及这个版本会影响哪些项目。

这里还做了一些操作入口,比如:

  • 安装新版本
  • 切换当前版本
  • 升级到推荐版本
  • 卸载工具
  • 查看实际命令

这些操作不会直接执行,每次都会先进入命令预览。

安装新工具

安装工具时,只需要输入工具名和版本号。

如果工具支持远端版本查询,界面会把可选版本列出来,方便直接选择。

demo-img-3.png

确认后不会立刻执行,而是先展示即将运行的命令,例如:

1mise install redis@8.6.2
2mise use --global redis@8.6.2
3

同时也会提示这次操作会影响哪些文件、影响范围是什么、可能有什么风险。

这个设计主要是为了避免“点一下按钮,背后偷偷执行了一堆命令”的情况。毕竟本地开发环境这种东西,改之前最好知道自己在改什么。

项目覆盖

mise支持项目级配置,比如在项目目录里放一个mise.toml,就可以指定这个项目使用的工具版本。

这个很好用,但是项目一多之后,就很容易忘记哪个项目覆盖了全局版本。

所以我做了一个项目覆盖页面。

demo-img-4.png

你可以添加多个扫描目录,软件会递归查找里面的mise.toml,然后只展示和全局版本存在差异的项目。

比如全局node是20,但是某个项目指定了18,那么这里就能很直观地看出来。

比如:当你想排查“为什么这个项目跑出来的node版本和我想的不一样”,这个功能就派上用场了。

配置管理

配置页主要是用来查看和编辑全局配置以及项目配置。

demo-img-5.png

目前支持:

  • 查看全局配置文件:~/.config/mise/config.toml
  • 选择某个项目查看项目级mise.toml
  • 编辑配置文件
  • 保存前查看diff差异
  • 配置文件变化后自动刷新

此处我特意加了保存前的差异预览。因为配置文件不像普通表单,改错一个版本号或者删错一行,可能就会影响很多项目。

技术栈

这个项目是用Flutter写的,主要技术栈如下:

  • Flutter Desktop:用于构建跨平台桌面应用
  • Dart:主要开发语言
  • Riverpod:状态管理
  • GoRouter:页面路由
  • file_selector:选择扫描目录
  • Process.run:调用本机mise命令

整体代码结构大概是这样:

1lib/
2  app/                  # 应用启动、路由、主题和外壳
3  features/
4    dashboard/          # 环境总览
5    tools/              # 工具版本、安装、升级、卸载
6    projects/           # 扫描目录和项目覆盖
7    config/             # 全局与项目配置管理
8  repositories/         # 页面数据聚合
9  services/             # mise CLI、配置、历史、更新等底层服务
10  shared/ui/            # 通用面板、状态、对话框和预览组件
11

我没有把命令执行逻辑直接写在页面里,而是拆成了:

  • Page:负责界面展示和用户交互
  • Provider:负责页面状态
  • Repository:负责聚合页面需要的数据
  • Service:负责调用mise、读取配置、记录历史等底层逻辑

这样做的好处是后面要扩展功能时,不至于所有逻辑都堆在页面文件里。

和mise CLI的交互

这个软件本质上不是替代mise,而是给mise套了一层图形界面。

所以核心逻辑还是调用本机的mise CLI,例如:

1mise --version
2mise ls --json
3mise current
4mise outdated
5mise ls-remote --json node
6mise install node@20
7mise use --global node@20
8

Flutter里通过Process.run来执行这些命令,然后把输出结果解析成界面需要的数据。

这里有个比较麻烦的点:桌面应用启动时拿到的环境变量,不一定和终端里的环境变量完全一致。

比如你在终端里能执行mise,但GUI应用直接执行可能找不到。

所以我在这里做了一些兜底:

为什么选择Flutter

这类工具其实用很多技术都能做,比如Electron、Tauri、Qt、SwiftUI等。

最后选择Flutter,主要有几个原因:

  • 我对Flutter比较熟悉
  • 桌面端支持macOS/Windows/Linux
  • UI写起来比较直接
  • 状态管理和组件拆分比较适合做这种工具型应用
  • 最终打包出来是一个桌面应用,使用门槛比较低

用Flutter写的时候,也遇到了一些坑,比如:系统文件选择、macOS打包、公证、不同平台的命令执行差异,这些都需要额外处理。

整体写下来,这种小型桌面工具开发体验还是很不错的。

如何使用

目前可以直接去Release页面下载对应系统的版本:

github.com/likaia/mise…

如果电脑里还没有安装mise,软件启动后会提示安装命令。

也可以先手动安装:

1# macOS
2brew install mise
3
4# Windows
5winget install jdx.mise
6
7# Linux
8curl https://mise.run | sh
9

如果你想本地运行源码:

1git clone https://github.com/likaia/mise_gui.git
2cd mise_gui
3
4flutter pub get
5flutter run -d macos
6

其他平台可以把运行目标换成:

1flutter run -d linux
2flutter run -d windows
3

写在最后

这个软件算是我给自己做的一个小工具,也是我第一个用Flutter作为开发语言写的开源项目。一开始只是因为换电脑时嫌重新配置环境太麻烦,后来越写越觉得这种东西挺适合做成可视化工具。

至此,文章就分享完毕了。

我是神奇的程序员,一位前端开发工程师。

如果你对我感兴趣,请移步我的个人网站,进一步了解。

  • 文中如有错误,欢迎在评论区指正,如果这篇文章帮到了你,欢迎点赞和关注😊
  • 本文首发于神奇的程序员公众号,未经许可禁止转载💌

开发了一个管理本地开发环境的软件》 是转载文章,点击查看原文


相关推荐


Hello 算法:“走一步看一步”的智慧
灵感__idea2026/4/26

每个系列一本前端好书,帮你轻松学重点。 本系列来自上海交通大学硕士,华为高级算法工程师 靳宇栋 的 《Hello,算法》 “走一步看一步”,是我们面对不断变化的世界所采取的应对策略。 多数时候,我们无法对未来做出准确预测,只能根据上一件事的结果对下一件事做决策。介绍“分治”的时候,我们已经接触过这种策略。本篇主角依然如此,但又有所不同。 先看个例子。 爬楼梯 给一个 n 阶楼梯,每步可以上 1 阶或者 2 阶,问有多少种方案可以爬到楼顶? 假设 n 是3,那么方案共 3 种。如下图所示。 这


Linux 驱动开发入门:从最简单的 hello 驱动到硬件交互
4. 嵌入式铲屎官2026/4/17

Linux 驱动开发入门:从最简单的 hello 驱动到硬件交互 🎉 写给未来的自己和领导:本文是 Linux 驱动开发的 入门级保姆教程,从零开始搭建驱动框架,逐行解释代码,记录每一个踩过的坑。无论你是刚接触内核编程,还是想快速上手 GPIO 中断,都能在这里找到清晰的思路和可复现的步骤。 📚 目录 引言:驱动是什么?驱动的基本框架 —— 一切皆文件实战:第一个 hello 驱动 3.1 完整的驱动源码(带详细注释)3.2 编译驱动 —— Makefile 解析3.3 上机测试 ——


深入剖析 Redis 经典面试题
Thomas.Sir2026/4/9

1、什么是Redis?它主要用来什么的? Redis,英文全称是Remote Dictionary Server(远程字典服务),是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。 与MySQL数据库不同的是,Redis的数据是存在内存中的。它的读写速度非常快,每秒可以处理超过10万次读写操作。因此redis被广泛应用于缓存,另外,Redis也经常用来做分布式锁。除此之外,Redis支持事务、持久化、


260331-OpenWebUI统计所有Chat的对话字符个数
GuokLiu2026/4/1

1 OWUI启动脚本 # Open-WebUI Settings export DATA_DIR='data0331' export ENABLE_SIGNUP=True export DEFAULT_USER_ROLE='admin' export DEFAULT_GROUP_ID='xai' export OFFLINE_MODE=false export HF_HUB_OFFLINE=1 # OpenAI API 配置 export ENABLE_OLLAMA_API=false ex


[LangChain智能体本质论]中间件是如何参与Agent、Model和Tool三者交互的?
JaydenAI2026/3/23

LangChain的中间件(Middleware)是围绕Agent执行流程构建的“可插拔钩子系统”。它允许开发者在不修改核心逻辑的情况下,在执行的关键节点(如输入处理、模型调用前后、输出解析等)对数据流进行拦截、修改或验证。中间件类型以AgentMiddleware为基类。 1. AgentMiddleware AgentMiddleware是一个泛型类型,两个泛型参数分别代表状态和静态上下文的类型,我们可以利用state_schema字段得到状态类型。它的name属性返回中间件的名称,默认返回


haproxy案例项目(haproxy+dns+nginx+nfs+keepalived)
爱莉希雅&&&2026/3/15

HAProxy+Nginx+NFS+DNS 部署笔记 一、环境规划 主机名IP 地址安装软件角色说明haproxy192.168.72.100/24haproxy负载均衡器nginx1192.168.72.10/24nginx、nfs-utilsWeb 节点 1(挂载 NFS 共享)nginx2192.168.72.20/24nginx、nfs-utilsWeb 节点 2(挂载 NFS 共享)nfs192.168.72.30/24nfs-utilsNFS 文件共享服务器dns192.168.


Spring Cloud+AI :实现分布式智能推荐系统
我不是呆头2026/3/7

欢迎文末添加好友交流,共同进步! “ 俺はモンキー・D・ルフィ。海贼王になる男だ!” 引言 在当今数字化时代,推荐系统已成为电商平台、内容分发平台、社交网络等互联网产品的核心竞争力之一。从淘宝的"猜你喜欢"、抖音的精准内容推送,到 Netflix 的影视推荐,优秀的推荐系统不仅能显著提升用户留存率和转化率,更能为企业带来可观的商业价值。据统计,亚马逊约 35% 的销售额来自推荐系统,Netflix 则通过推荐算法为用户节省了每年约 10 亿美元的搜索成本。 然而,随着业


一文搞懂激活函数!
aicoting2026/2/27

推荐直接网站在线阅读:aicoting.cn 在深度学习中,激活函数(Activation Function)是神经网络的灵魂。它不仅赋予网络非线性能力,还决定了训练的稳定性和模型性能。那么,激活函数到底是什么?为什么我们非用不可?有哪些经典函数?又该如何选择? 所有相关源码示例、流程图、模型配置与知识库构建技巧,我也将持续更新在Github:AIHub,欢迎关注收藏! 1. 什么是激活函数,为什么需要激活函数 激活函数的核心作用就是为神经网络引入非线性。 为什么需要非线性? 想象一下,如果


【Python练习五】Python 正则与网络爬虫实战:专项练习(2道经典练习带你巩固基础——看完包会)
纯.Pure_Jin(g)2026/2/18

第一题 题目: 使用正则完成下列内容的匹配 匹配陕西省区号 029-12345匹配邮政编码 745100匹配邮箱 lijian@xianoupeng.com匹配身份证号 62282519960504337X 代码: import re # 1. 匹配陕西省区号 029-12345 pattern_area = r'^029-\d{5}$' # 精确匹配 029- 开头,后接5位数字 test_area = '029-12345' print("区号匹配:", re.match(pattern_


Claude Code Agent Teams:3个AI同时写代码,底层原理和主流框架对比
易安说AI2026/2/10

大家好,我是易安,AI超级个体,大厂程序员二孩奶爸。 Claude Opus 4.6 带来了 Agent Teams 功能,可以让多个 Claude Code 实例并行工作。我用它做了个小项目,踩了一些坑,也顺便把底层原理和市面上几个主流多 Agent 框架做了个对比。这篇文章干货比较多,建议收藏。 Agent Teams 到底是什么 简单说就是一个 Lead Agent 可以 spawn 出多个 Teammate Agent,每个 Teammate 是一个完全独立的 Claude Code 会

首页编辑器站点地图

本站内容在 CC BY-SA 4.0 协议下发布

Copyright © 2026 XYZ博客