首页
/ 探索未来软件部署的新纪元: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 都能为你带来更加高效且稳定的软件部署体验。让我们一起探索这个全新的容器世界,让软件开发变得更加简单!

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

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
52
461
kernelkernel
deepin linux kernel
C
22
5
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
349
381
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
131
185
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
873
517
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.09 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
264
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
607
59
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4