使用AWS的Elastic Beanstalk快速发布网站

本贴最后更新于 3097 天前,其中的信息可能已经时异事殊

最近AWS在中国区上架了一款新产品,Elastic Beanstalk, 是中国区第一个类似工具,并且首次和其他区域同步发布。其他区域目前已经有了Container,Lambda,Beanstalk这三款产品,都可以用来实现快速的网站发布,我认为最为容易使用,并且便于从传统部署方式转变的,还是Beanstalk。Beanstalk目前的发布速度在20秒左右,已经和Docker的秒级发布不相上下,是非常优秀的。

 

在AWS控制台,打开Elastic Beanstalk界面,如果你没有创建过application的话,会有引导界面来引导创建一个,不过这个创建的都是默认设置,如果你的网站直接发布,可以使用,但是如果你原本就有一个VPC存在,或者你需要使用数据库连接这些功能,就需要跳过自动生成,自己进行详细设置,但是也很简单,不会花费超过1分钟。

 

  • Create New Application

需要输入一个Application name, 这是你的应用的名称,如果你的网站叫做fullmoon,可以直接填full moon,但是这个名字像S3一样是所有用户唯一的,所以越早可以越好。

Description无所谓,随便填。

 

  • Create Environment

创建好Application之后,Beanstalk的界面就成了application list,在fullmoon这个application下,还什么都没有,No environments currently exist for this application,environment指的是运行网站的具体服务名字,如果你有三个微服务,那么你需要创建三个environment,如果只是一个简单的博客站,只需要一个envrionment即可。点击Create One Now。

点击之后,选择web server 还是worker,分别代表前端web服务还是后端服务,我们一般选择web服务,按照现在流行的微服务架构,一切都是web服务。

 

  • Environment Type

这里可以选择发布平台,目前支持Ruby,PHP,Tomcat,Python,Node.js,IIS,JAVA,GO,我要发布一个JAVA的博客系统,选择Tomcat,如果你用spring-boot这类JAVA工具把jar打包成了可执行文件,你可以选择JAVA平台,直接运行jar包。

Environment type是AWS云的一大重要特性,指的是你的程序跑single instance还是auto scanning。Single instance不用解释,就是在一个实例上跑你的网站,Load balance, auto scanning是发布你的网站之后,如果访问量过大,会再启动一个一摸一样的服务来缓解压力,并且自动负载均衡,如果访问量减少,又回还原到1个实例。AWS的服务都是按秒收费的,所以选择auto scanning并不会多花钱。

 

  • Application version

这一步是进行网站版本设置,可以从console界面上传文件,也可以直接填写s3地址,Sample application是不上传,先启动一个白板网站。

 

  • Environment information

填写这个微服务的名称, 并生成url,通过url开放的80或其他端口访问服务。

url也是全用户唯一,所以,早用早享受。

 

  • Additional Resources

选择是否创建RDS数据库和使用VPC,这里是创建数据库和VPC的选项,比较复杂,如果有已经有RDS和VPC了,就钩上,没有就算了,我会换一篇blog单独讲VPC和RDS的最佳实践。

 

  • Configuration Details

选择服务器的配置信息,Instance type是服务器大小配置,如果是简单个人使用的话,选择最便宜的t2.micro足够了,商业用途可以选择t2.small,搭建网站或者微服务的话,一般足够!不要选择大的类型,本来就很贵,还和我们auto scanning的思想不符合。

 

  • EC2 key pair

这个是ssh服务登录的key,如果你不准备登录这台服务器,没有key也无所谓。

下面的选项是选择磁盘类型,SSD大小,一般不会用到。

 

  • Environment Tag

tag在AWS中是非常重要的功能,这里设置的tag可以作为配置信息加载到服务器上,可以用来实现服务的环境变量配置,这里不展开讲。如果设置Name=full moon,那么beanstalk启动的服务在ec2console上显示的名字就是full moon,不设置也没关系。

 

  • Permissions

这里是AWS IAM的设置,IAM是非常复杂的系统,我会在另外的blog详细讲IAM的最佳实践。一般用户用不到,就默认选项即可。

 

  • Review Information

确认你的选项。

 

 

所有的配置都配置完之后,点击luanch,网站就启动了,只需要20秒!

在Beanstalk的application list界面,有了你的environment,点击进去,是网站运行的console。

  • DeshBoad

显示服务器监控,版本,recent log 信息

  • Configuration

可以view modify我们之前做的配置。AWS的配置可以提供非常强大功能。

  • Log

可以下载所有的服务器日志,包括系统日志。

  • Health
  • Monitoring
  • Alarms

是服务监控,比目前市面上所有的云计算厂商做的都好。

 

 

在Dashboad界面,抬头看到信息application  Environment ID: e-4mcdvvzi33, URL: application.cn-north-1.eb.amazonaws.com.cn ,其中URL即是部署为网站对外的url,如果有域名,在DNS解析配置CNAME等于URL,就可以把网址指向服务器了。

本博客就是用beanstalk的技术部署,但是在IAM,RDS,VPC的设置上是最佳实践,解决了安全问题。

 

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 101 关注
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    75 引用 • 258 回帖 • 631 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖 • 1 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 731 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    77 引用 • 389 回帖
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    117 引用 • 99 回帖 • 215 关注
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 30 关注
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    85 引用 • 165 回帖 • 1 关注
  • 音乐

    你听到信仰的声音了么?

    61 引用 • 512 回帖
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    223 引用 • 474 回帖 • 1 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    289 引用 • 4492 回帖 • 657 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 457 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 28 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    26 引用 • 196 回帖 • 25 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 240 关注
  • Follow
    4 引用 • 12 回帖
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 213 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 68 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 1 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 1 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 635 关注
  • RemNote
    2 引用 • 16 回帖 • 10 关注
  • Visio
    1 引用 • 2 回帖 • 1 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 379 关注
  • 电影

    这是一个不能说的秘密。

    121 引用 • 606 回帖