首页
/ SST项目中使用sst dev与sst deploy命令的最佳实践

SST项目中使用sst dev与sst deploy命令的最佳实践

2025-05-09 21:27:05作者:俞予舒Fleming

在SST(Serverless Stack)项目中,开发者经常需要处理敏感信息的存储问题。SST提供了secret功能来安全地管理这些敏感数据,但在实际使用过程中,开发者可能会对secret设置后的部署流程产生疑问。

核心概念解析

SST提供了两种主要的部署方式:

  1. sst dev:开发模式,会启动一个本地开发环境并自动部署变更
  2. sst deploy:直接部署模式,将当前状态完整部署到云端

秘密管理的工作机制

当使用sst secret set命令设置秘密值时,SST会将这些值安全地存储在AWS Secrets Manager中。无论后续使用sst dev还是sst deploy,应用都能正确获取这些秘密值。

开发与生产环境的最佳实践

在开发阶段,sst dev是更高效的选择,因为它:

  • 自动检测代码变更并重新部署
  • 启动本地开发服务器
  • 提供实时的日志输出
  • 部署速度显著快于完整部署

而在生产环境或特定场景下,sst deploy更为合适:

  • 部署到非开发环境(如生产环境)
  • 需要确保所有资源完整部署
  • 执行一次性部署操作

性能考量

对于包含前端框架(如Remix)的项目,完整部署可能会较慢,这是因为:

  • 需要创建CloudFront分发
  • 需要处理前端资源的构建和上传
  • 涉及多个AWS服务的协调

环境阶段的注意事项

特别需要注意的是,秘密是与特定环境阶段(stage)绑定的。如果为不常使用sst dev的阶段设置了秘密,那么必须使用sst deploy来确保该阶段的资源能够正确获取秘密值。

总结建议

对于大多数开发场景,使用sst dev是更高效的选择。但在以下情况应考虑使用sst deploy

  1. 部署到非开发环境
  2. 为不常开发的阶段设置秘密
  3. 需要确保所有资源完整部署

理解这两种部署方式的差异和适用场景,可以帮助开发者更高效地使用SST框架进行Serverless应用开发。

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