开源开发环境管理器
文档 · 报告bug · 请求功能 · 加入我们的Slack · Twitter
特性
- 单一命令:使用单一命令激活完全配置的开发环境。
- 到处运行:在任何机器上启动你的开发环境 — 无论是本地、远程、基于云、物理服务器,还是虚拟机,以及任何架构x86或ARM。
- 配置文件支持:最初支持dev container,可扩展到DevFile、Nix和Flox(欢迎在这里贡献!)。
- 预构建系统:大幅改善环境设置时间(欢迎在这里贡献!)。
- IDE支持:无缝支持本地VS Code和JetBrains,无需配置即可使用。包含内置的Web IDE以增加便利性。
- Git提供商集成:可以连接GitHub、GitLab、Bitbucket、Bitbucket Server、Gitea、Gitness、Azure DevOps和AWS CodeCommit,允许从工作空间轻松拉取和提交仓库分支或PR。
- 多项目工作空间:支持在同一工作空间中使用多个项目仓库,便于使用微服务架构进行开发。
- 反向代理集成:利用反向代理功能实现协作并简化反馈循环。即使在防火墙后也可以无缝访问预览端口和Web IDE。
- 可扩展性:通过插件或提供商开发实现可扩展性。此外,可以使用任何动态语言,而不仅仅是Go(欢迎在这里贡献!)。
- 安全性:自动在客户端机器和开发环境之间创建VPN连接,确保完全安全的连接。
- 所有端口:VPN连接使得可以访问开发环境上的所有端口,无需通过SSH连接设置端口转发。
- "在我的机器上可以运行":再也不会遇到这种情况。
快速开始
Mac / Linux
curl -sfL https://download.daytona.io/daytona/install.sh | sudo bash && daytona server -y && daytona
Windows
Windows PowerShell
此命令下载并安装Daytona,并运行Daytona服务器:$architecture = if ($env:PROCESSOR_ARCHITECTURE -eq "AMD64") { "amd64" } else { "arm64" }
md -Force "$Env:APPDATA\bin\daytona"; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.SecurityProtocolType]'Tls,Tls11,Tls12';
Invoke-WebRequest -URI "https://download.daytona.io/daytona/latest/daytona-windows-$architecture.exe" -OutFile "$Env:APPDATA\bin\daytona\daytona.exe";
$env:Path += ";" + $Env:APPDATA + "\bin\daytona"; [Environment]::SetEnvironmentVariable("Path", $env:Path, [System.EnvironmentVariableTarget]::User);
daytona serve;
通过打开新终端并运行以下命令创建你的第一个开发环境:
daytona create --code
开始编码。
为什么选择Daytona?
Daytona是一个极其简单的开源开发环境管理器。
随着时间的推移,设置开发环境变得越来越具有挑战性,特别是在远程设置时,复杂性会增加一个数量级。这个过程如此复杂,以至于我们编写了一份全面指南,详细说明了设置所需的所有步骤——包含__5,000字__,7个步骤,需要15到__45分钟__的时间。
这种复杂性是不必要的。
使用Daytona,你只需要执行一个命令:daytona create --code
。
Daytona自动化了整个过程;配置实例、解释和应用配置、设置预构建、建立安全的VPN连接、安全地连接你的本地或Web IDE,并为开发环境分配一个完全限定的域名,以便于共享和协作。
作为开发者,你可以立即开始专注于最重要的事情——你的代码。
背景故事
我们在职业生涯的大部分时间里都在构建云开发环境。2009年,我们启动了可能是第一个商业云IDE项目。那时,技术还不成熟,迫使我们从头开发一切——IDE、环境编排器以及几乎所有其他东西。很多人对此感兴趣,超过250万开发者注册了!但我们太早了,我们要求用户改变他们的工作方式,这要求太高了。
现在,自项目inception以来已经过去了15年,我们注意到了一些事情。首先,我们当时希望拥有的技术现在已经存在。其次,大约50%的开发者在远程开发环境中工作,第三,也是最重要的,设置开发环境变得比以往任何时候都更加复杂,无论是本地还是远程,后者的复杂性更高。 因此,我们汲取了所有经验教训,决定将这些问题作为一个完全开源的项目一劳永逸地解决。我们的目标是创建一个单一的二进制文件,让你能够在任何地方设置开发环境,完全免费,最终实现许多人尝试过的承诺。
入门指南
要求
在开始安装脚本之前,请检查所有必要的要求:
- 硬件资源:根据项目需求,确保你的机器有足够的资源。最低硬件规格为1个CPU、2GB内存和10GB磁盘空间。
- Docker:确保已安装并运行Docker。
安装Daytona
Daytona允许你使用Daytona CLI管理开发环境。要安装它,请执行以下命令:
# 将Daytona安装到/usr/local/bin
curl -sf -L https://download.daytona.io/daytona/install.sh | sudo bash
# 或者如果你想将Daytona安装到不需要sudo的其他路径
# curl -sf -L https://download.daytona.io/daytona/install.sh | DAYTONA_PATH=/home/user/bin bash
手动安装
如果你不想使用提供的脚本,可以直接从特定操作系统的URL下载二进制文件:curl -sf -L https://download.daytona.io/daytona/latest/daytona-darwin-amd64 -o daytona
curl -sf -L https://download.daytona.io/daytona/latest/daytona-darwin-arm64 -o daytona
curl -sf -L https://download.daytona.io/daytona/latest/daytona-linux-amd64 -o daytona
curl -sf -L https://download.daytona.io/daytona/latest/daytona-linux-arm64 -o daytona
curl -sf -L https://download.daytona.io/daytona/latest/daytona-windows-amd64.exe -o daytona
curl -sf -L https://download.daytona.io/daytona/latest/daytona-windows-arm64.exe -o daytona
确保下载daytona
二进制文件的路径在你的系统PATH中。
初始化Daytona
要初始化Daytona,请按以下步骤操作:
1. 启动Daytona服务器: 这将以守护进程模式启动Daytona服务器。使用以下命令:
daytona server
2. 添加你选择的Git提供商: Daytona支持GitHub、GitLab、Bitbucket、Bitbucket Server、Gitea、Gitness、AWS CodeCommit和Azure DevOps。要将它们添加到你的配置文件,使用以下命令:
daytona git-providers add
按照提供的步骤操作。
3. 添加你的提供商目标: 这一步是为了选择部署开发环境的位置。默认情况下,Daytona包含一个Docker提供商,可以在本地机器上启动环境。对于远程开发环境,使用以下命令:
daytona target set
按照此命令的步骤将SSH机器添加到你的目标中。
4. 选择你的默认IDE: Daytona的默认设置是本地VS Code。如果你喜欢,可以切换到VS Code - 浏览器版或JetBrains产品组合中的任何IDE,使用以下命令:
daytona ide
现在你已经安装并初始化了Daytona,可以继续设置开发环境并立即开始编码。
创建开发环境
使用Daytona创建开发环境是一个简单的过程,只需一个命令即可完成:
daytona create --code
如果你不希望在创建环境后立即打开IDE,可以跳过--code
标志。
执行此命令后,你将被提示回答两个问题:
- 选择提供商以决定在哪里创建开发环境。
- 选择或输入你希望用来创建开发环境的Git仓库。
做出选择后,按回车键,Daytona将处理剩下的事情。你只需执行以下命令来打开默认IDE:
daytona code
此命令在你首选的IDE中打开开发环境,让你可以立即开始编码。
停止Daytona服务器:
daytona server stop
重启Daytona服务器:
daytona server restart
如何扩展Daytona
Daytona通过创建插件和提供商提供了扩展的灵活性。
提供商
Daytona设计为与基础设施无关,能够在各种平台上创建和管理开发环境。提供商是封装了在特定目标平台上配置计算资源逻辑的组件。它们允许在单个提供商内配置不同的目标,例如,在AWS提供商内配置多个AWS配置文件。
它是如何工作的?当执行daytona create --code
命令时,Daytona将环境详细信息传达给所选的提供商,然后提供商配置必要的计算资源。一旦配置完成,Daytona在这些资源上设置环境,允许用户无缝地与环境交互。
提供商是遵循Daytona提供商接口的独立项目。它们几乎可以用任何主要编程语言开发。更多详情即将公布。
插件
插件通过添加新的CLI命令、API方法或开发环境中的服务来增强Daytona的核心功能。它们提供可配置的设置,以根据用户需求定制插件的行为。
与提供商类似,插件是符合Daytona插件接口的独立项目,可以用多种编程语言开发。更多详情即将公布。
贡献
Daytona是在Apache许可证2.0下的开源软件,并且是其贡献者的版权。如果你想为该软件做出贡献,你必须:
- 阅读开发者原创证书1.1版(https://developercertificate.org/)
- 对Daytona项目的所有提交进行签名。
这确保用户、分发者和其他贡献者可以依赖所有与Daytona相关的软件都是在许可证条款下贡献的。没有遵循这个过程的贡献将不被接受。
之后,请查看贡献指南以开始。
许可证
本仓库包含Daytona,受Apache许可证2.0保护,除非另有说明(任何Daytona徽标或商标不在Apache许可证范围内,应由LICENSE文件明确说明。)
Daytona是由Daytona Platforms, Inc.从这个开源软件生产的产品。它根据我们的商业条款分发。
其他人可以自行分发该软件,但他们不能使用任何Daytona商标、云服务等。
我们明确授予你在开发Daytona本身时包含我们商标的构建权限。你不得发布或分享该构建,也不得将该构建用于运行Daytona的任何其他目的。
行为准则
本项目采用了贡献者契约中的行为准则。更多信息请参见行为准则或联系codeofconduct@daytona.io以获取任何其他问题或评论。
问题
有关如何使用和开发Daytona的更多信息,请在Slack上与我们交流。