探索未来软件部署的新纪元:Starter

Starter 是一款开源的命令行工具,它能从你的源代码中自动生成 Dockerfile 和 docker-compose.yml 文件,将你的应用带入容器化的世界。不仅如此,Starter 还能够生成 Cloud 66 的 service.yml 服务定义文件,用于定义在任何云上或自家服务器上运行 Docker 的生产环境配置。
关键特性
- 框架检测:识别如 Rails v5.0, PHP Laravel, Node.JS Express 等多种框架及其版本。
- 端口识别:确定需要设置的端口。
- 数据库检测:检测并配置你在
docker-compose中使用的数据库。 - Procfile 兼容性:自动生成基于 Procfile 的服务。
- 智能分析:分析你的应用以生成适当的
Dockerfile,docker-compose.yml,service.yml文件。 - API 集成:允许将 Starter 整合到你的产品中。
为什么选择 Starter?
-
你是 Docker 新手: Starter 是帮助你迈入 Docker 大门的理想工具。通过自动化流程,你可以专注于核心业务,而无需纠结于 Docker 学习曲线的基础部分。
-
你需要对现有应用进行容器化: Starter 可以分析你的现有应用,识别其运行的框架和版本,以及所使用的数据库和端口。然后,它会生成可直接运行的 Dockerfile, DockerCompose 或 service.yml 文件,加速构建过程,助你准备在生产环境中运行 Docker。
为何要容器化你的应用?
-
实现多租户架构:如果你的应用需要共享资源,或者单个应用的流量不足以支撑独立运行,那么 Starter 可以帮你把多个应用部署在同一栈中。
-
创建安全的沙箱环境:利用 Docker 提供的安全隔离功能,你可以将应用的部分组件放入容器,确保它们在一个安全的沙箱环境中运行。
快速启动
前往 Starter 最新发布页,下载适合你的平台的最新版本。将文件复制到 /usr/local/bin 并重命名为 starter,然后运行(chmod a+x /usr/local/bin/starter)。之后只需运行 starter update 即可自动更新。
$ cd /my/project
$ starter -g dockerfile,service,docker-compose
这段命令将在当前目录下分析项目,并生成 Dockerfile, docker-compose.yml 和 service.yml 文件。在必要时,系统会提示你输入信息。
Starter 支持 Procfile,为 Procfile 中的每一项生成 service.yml 中的服务。强烈建议使用 Procfile 来定义自己的服务命令,否则 Starter 只会检测到 web 服务。
若需针对不同目录执行 Starter,请使用 -p 选项:
$ starter -p /my/project
更多选项,请查看:
$ starter help
使用 Habitus 构建 Starter
如果你想贡献给 Starter 开发,你可以使用 Habitus 这款开源的 Docker 构建流工具。在仓库根目录下运行 Habitus,最新的编译版本将会在 ./artifacts/compiled 目录下生成。
habitus --keep-artifacts=true
为了提供一个隔离的开发环境,你可以使用 docker-compose 进行开发、测试和编译。
$ docker-compose run starter
在 Docker 容器内构建 Starter:
root@xx:/usr/local/go/src/github.com/cloud66/starter# go build
运行测试:
root@xx:/usr/local/go/src/github.com/cloud66/starter# go test
现在,你已经准备好开始为 Starter 贡献力量了!
结语
Starter 凭借其智能化的分析能力和便捷的集成方式,是提升开发者效率的得力助手。无论你是 Docker 新手,还是有经验的开发者,Starter 都能为你带来更加高效且稳定的软件部署体验。让我们一起探索这个全新的容器世界,让软件开发变得更加简单!
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00