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

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

2024-05-22 05:00:29作者:尤峻淳Whitney

Starter Logo

Starter 是一款开源的命令行工具,它能从你的源代码中自动生成 Dockerfiledocker-compose.yml 文件,将你的应用带入容器化的世界。不仅如此,Starter 还能够生成 Cloud 66 的 service.yml 服务定义文件,用于定义在任何云上或自家服务器上运行 Docker 的生产环境配置。

下载 Starter

关键特性

  • 框架检测:识别如 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.ymlservice.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 都能为你带来更加高效且稳定的软件部署体验。让我们一起探索这个全新的容器世界,让软件开发变得更加简单!

登录后查看全文
热门项目推荐

项目优选

收起
docsdocs
暂无描述
Dockerfile
702
4.51 K
pytorchpytorch
Ascend Extension for PyTorch
Python
566
693
atomcodeatomcode
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get Started
Rust
546
98
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
957
955
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
411
338
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.6 K
940
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.08 K
566
AscendNPU-IRAscendNPU-IR
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
128
210
flutter_flutterflutter_flutter
暂无简介
Dart
948
235
Oohos_react_native
React Native鸿蒙化仓库
C++
340
387