关键词:

1.新建aws ec2实例

2.使用putty连接到aws ec2 实例(SSH协议)

3.使用filezilla连接到aws ec2实例(SFTP协议)

4.在aws ec2上部署apache服务器(lamp)

5.配置安全组使aws ec2实例能被外网访问

6.弹性IP(EIP)

  朋友想搭一个境外网站,找我帮忙,希望服务器、域名都在境外。我没有在境外建站的经历,只能先尝试。于是上网搜索了一下境外服务器,大家比较常用的是Digital Ocean和AWS,我索性打开这两家的官网,打算自己比较一下,后来选择AWS,是因为他的官网打开的比Digital Ocean快,就这一点,我义无反顾地选择了AWS。

  简单介绍一下,AWS即Amazon Web Services,是Amazon提供的建站平台,在上面可以购买空间、数据库、云计算等服务,官网地址https://aws.amazon.com/。要使用它的服务首先要注册一个账号,注册的过程中会需要用到信用卡,还会接到一个电话要求输入网站上提供的PIN码用于验证你填的手机号,跟随指引,基本上很简单就能完成。

第一部分 新建EC2例

  注册完成后登录管理控制台,控制台首页可以看到几个选项卡:

  很好理解,第一个就是构建虚拟机,以我的经验,建站的空间就在这里申请。点一下启动虚拟机,进入如下界面

  这是我首次接触EC2这个概念,搜索了一下,它是指Elastic Compute Cloud,即弹性云计算,和国内的云虚拟主机的概念差不多,一个EC2实例就是一个云虚拟主机。接下来的步骤就是为这个实例命个名:

  然后选择操作系统,点击每个操作系统会有简介,可以根据自己的技术方向选择,由于我一个都不熟,于是我打算选Amazon的亲儿子Amazon Linux AMI,这也是经验之谈,既然是Amazon的主机,用Amazon定制的Linux肯定没毛病。

  然后选择实例类型,这是一个很人性化的界面,直接放了一个免费的类型,绝不会利用你看不懂就讹你钱,如果你是土豪并且有点文化可以选择更多选项,像我这种挣扎在温饱线的直接很HAPPY的选了免费型然后下一步

  然后就是创建秘钥,给这个秘钥命个名,然后下载秘钥文件后保存,这个秘钥文件(*.pem)很重要

  下载之后,点击创建实例,就OK了。

  然后返回控制台首页,可以看到最近访问的服务下面有个EC2,直接点击EC2,就进入到EC2控制面板,然后点击正在运行的实例

  可以看到我们刚才创建的实例MyFirstInstance。

第二部分 使用PuTTY连接到实例(使用SSH协议)

  接下来的工作就是要想办法连接上这台主机,方便我们在上面部署网站。右键点击实例,在菜单中选择连接,会显示连接方式

  这上面介绍了两种方式,一种是使用SSH客户端,一种是直接从浏览器连接,选择直接从浏览器连接时会提示使用Chrome是不行的,请使用Firefox或者IE9+,并且还要安装Java。

  java我已经很熟悉了实在懒得重复这个工作,而且仅仅为了连一下虚拟主机在我电脑上装java我觉得不划算(虽然我还是默默安装了个firefox),而且SSH客户端对我而言还是个新事物我比较有好奇心,我毫不犹豫决定选择SSH客户端,并且选择了上面提到的PuTTY客户端。下面介绍下如何用PuTTY客户端连接到EC2实例。

  首先下载安装PuTTY的过程就不说了,和一般软件安装过程一样并且这个超级简单。然后我们要做一些准备工作,在正在运行的实例列表中,选择刚才新建的实例,页面底部可以看到实例的详细信息,我们要记住的是实例的Public DNS(IPv4)

  然后我们要对刚才创建实例时下载的密钥文件进行格式转换,从PEM格式转成PPK格式才能在PuTTY上使用,PuTTY自带转换工具PuTTYgen,安装PuTTY后在开始菜单很容易找到PuTTYgen工具,启动它

  然后点击Load,加载刚才下载的私钥pem文件,默认情况下选择文件的界面那里文件类型是*。ppk,我们要改成ALL FILES才能看到PEM文件

  然后Type of key to generate那里选择SSH-2 RSA,

  然后点击Save private key,就可保存为PPK文件了,这个PPK文件就是PuTTY可以用的密钥文件,在一会儿的连接过程中会用到。

  准备工作做完了,接下来启动PuTTY,在左边的目录中选择Session,一般情况下启动时默认就是Session界面,在HostName中输入user_name@public_dns_name

  username按之前选的操作系统有几种不同的值:

  • 对于 Amazon Linux AMI,用户名为 ec2-user

  • 对于 RHEL AMI,用户名称是 ec2-user 或 root

  • 对于 Ubuntu AMI,用户名称是 ubuntu 或 root

  • 对于 Centos AMI,用户名称是 centos

  • 对于 Fedora AMI,用户名称是 ec2-user

  • 对于 SUSE,用户名称是 ec2-user 或 root

  public_dns_name就是前面提到的必须要记住的Public DNS

  然后Connection type选择SSH

  然后通过左边的目录切换到Conncetion——SSH——Auth,在右边点击Browse,选择前面生成的PPK文件,然后切换回Session页面,点击Save,可以保存这些配置以供下次直接使用,点击Open可以连接到EC2

  下面是连接成功后的界面,就是Linux系统的命令窗口,在这个窗口通过命令可以执行一切我们希望的操作,部署网站就靠它完成。

第三部分 使用FileZilla连接到实例(使用SFTP协议)

  这是一个题外话,但它介绍的内容也在后面的工作中承担了很重要的作用:从Windows上传文件到EC2实例中的Linux系统。使用PuTTY自带的工具PSCP(基于命令的工具),或者WinSCP(基于windows GUI的工具)也可以从windows上传文件到远程Linux,为什么我选择了FileZilla?理由很简单,一是我恰好装了FileZilla并且用的比较熟练,二是我想试试FileZilla行不行,因为我以前一直用FTP协议连接远程服务器,今天突然接触到SSH协议,然后我就专门查了一下FTP和SSH区别,查的过程中别的没记住,倒是记住了SFTP这样一个由二者结合的协议,然后以前用FileZilla的时候有印象在选择传输协议时有SFTP这个选项,所以想试试可不可以通过SFTP协议连接到EC2。

  我启动FileZilla,下面的一切都凭经验进行

  新建站点AWS,主机栏输入Public DNS,端口输22,协议选择SFTP,登录类型选择密钥文件,用户前面解释过了填ec2-user,密钥文件选择之前转换成的PPK文件,其它的不管,点击连接,由于是境外服务器网络不稳定,经过多次尝试后终于还是连接成功了,然后我还上传了一个httpd-2.2.32.tar.gz文件,用于部署apache服务器的。

第四部分 部署Apache服务器

  在Linux部署Apache服务器的步骤,常见于LAMP环境搭建的教程里面。LAMP,即Linux + Apache + MySQL + PHP,有时候M也指MariaDB。搜索amazon ec2、lamp关键词,很容易就能找到在ec2上部署apache的教程,然而我一开始并不知道lamp这个概念,于是一直搜索在linux上部署apache的教程,查出来的教程相当复杂,而且我还各种没成功。后来总算让我找到了一篇,原来在ec2上部署apache是一件非常轻松的事情,只需要如下几行代码:

sudo yum update
sudo yum install gcc gcc-c++ make
sudo yum install apache mysql php php-mysql mysql-server

  上面第一行是更新系统环境,第2行是安装C++编译环境,第3行是安装apache、mysql、php等组件。上述代码运行完成后apache就成功安装了。

  测试apache是否成功安装的方法:

apachectl -v
httpd -v

  回显版本号表示已经安装成功

  安装完apache后,接下来启动apache web服务:

sudo service httpd start

  加sudo是为了以管理员权限运行该命令,一般情况下这条命令需要有sudo才会运行成功。

  在官方的API文档里面看的更清楚:

第五部分 测试Apache服务器

  在安装apache服务器并启动httpd服务后,接下来需要测试该服务器能否被正常访问。在浏览器中输入前面提到的Public DNS,应该就可以看到Apache测试页面了。但一般情况下,只做到这一步的话,还看不到测试页面,因为还需设置下安全组规则。在EC2控制面板切到安全组页面

  然后在右边选中MyFirstInstance实例后,右键单击它,在菜单中选择“编辑入站规则”:

  在“编辑入站规则”中添加下面这样一条规则:

  它的含义是允许任何地方通过HTTP协议80端口访问本实例,也就是通过网页方式访问本实例。这个时候基本上就大功告成了,在浏览器输入Public DNS或者公有IP就能看到Apache测试页了。

第六部分 关于弹性IP(EIP,Elastic IP)

  通常情况下,我们申请的EC2实例在每次重启之后,Public DNS和公有IP都会改变,如果是要做一个网站,服务器IP经常改变,那域名解析也要跟着变,这是个很麻烦的事情。这时候就需要申请EIP,并将EIP与EC2实例关联,这个EIP就可以作为这个实例的永久IP,除非我们手动取消关联。关联之后,我们可以在浏览器地址栏输入EIP来访问EC2实例。

  申请EIP的方法:在EC2控制面板找到“弹性IP”页面

  然后在右边选择“分配新地址”

  按照指引分配好新地址后,回到弹性IP页面,右键点击我们刚才申请的EIP,选择关联地址,将前面的EC2实例关联上去

然后就大功告成。

以上是这两天的学习成果,很少,但学习过程也是十分繁琐复杂,查了不少资料走了不少弯路浪费了不少时间,所以才想写一篇笔记记下来,让以后少走弯路。后续将继续学习在ec2上运行php的过程,在amazon申请域名并绑定到ec2实例的过程,逐步将网站建起来,学习过程中的经验也会拿出来分享。

AWS EC2笔记的更多相关文章

  1. AWS EC2中部署Apache服务器(LAMP)

    关键词: 1.新建aws ec2实例 2.使用putty连接到aws ec2 实例(SSH协议) 3.使用filezilla连接到aws ec2实例(SFTP协议) 4.在aws ec2上部署apac ...

  2. AWS EC2首次使用VPS

    看到AWS有免费一年的试用期,就申请了一个账号.想搭建一个自己的网站.申请之前,你还需要有一张信用卡. 申请AWS账号,登陆控制台 进入AWS官网即可申请账号,进入控制台后,就可以新建一个AWS EC ...

  3. Amazon AWS EC2开启Web服务器配置

    在Amazon AWS EC2申请了一年的免费使用权,安装了CentOS + Mono + Jexus环境做一个Web Server使用. 在上述系统安装好之后,把TCP 80端口开启(iptable ...

  4. 在NodeJS中配置aws ec2

    获取access key和secret access key           自己账户下有security credentials的选项                      然后点击Acce ...

  5. 在aws ec2上使用root用户登录

    aws ec2默认是使用ec2-user账号登陆的,对很多文件夹是没有权限的.如何使用root账号执行命令就是一个问题了.解决办法如下: 1.根据官网提供的方法登录连接到EC2服务器(官网推荐wind ...

  6. 亚马逊AWS EC2云实例AMI安装LNMP环境(3)——Mysql5.5

    概括:这里选择亚马逊EC2的Linux AMI实例,该Linux服务器是亚马逊预配置的Linux环境,内置多个YUM源,属于亚马逊首推的稳定Linux服务器.默认登录用户名为ec2-user,执行ro ...

  7. 亚马逊AWS EC2云实例AMI安装LNMP环境(2)——PHP5.6

    概括:这里选择亚马逊EC2的Linux AMI实例,该Linux服务器是亚马逊预配置的Linux环境,内置多个YUM源,属于亚马逊首推的稳定Linux服务器.默认登录用户名为ec2-user,执行ro ...

  8. 亚马逊AWS EC2云实例AMI安装LNMP环境(1)——Nginx安装

    概括:这里选择亚马逊EC2的Linux AMI实例,该Linux服务器是亚马逊预配置的Linux环境,内置多个YUM源,属于亚马逊首推的稳定Linux服务器.默认登录用户名为ec2-user,执行ro ...

  9. AWS EC2服务器的HTTPS负载均衡器配置过程

    AWS EC2服务器配置负载均衡器步骤:   1.普通负载均衡器   至少两台EC2实例,这里以Centos6.7系统为例 启动之后先安装个apache的httpd服务器默认80端口,或者使用其他服务 ...

随机推荐

  1. html中的图片、css、js等路径加载问题

    网页文件的存取路径有3种:物理路径.绝对路径和相对路径. 物理路径就是你的文件放在主机上的具体位置,例如:D:\\image\\1.jpg 这种格式,该方法可以很快确定出你的文件,但是在网页显示路径基 ...

  2. STM8S STM8L引脚如何配置最低(转)

    源:STM8S STM8L引脚如何配置功耗最低 STM8S无任何外围电路 单片机CAP接104电容 复位接上拉电阻,其它引脚全部悬空,利用以下程序测试电流如下:(以前也用STM8L做过类似实验,情况也 ...

  3. Java6 WebService学习

    首先,建立一个WebService: package garfield; import javax.jws.WebService; import javax.xml.ws.Endpoint; @Web ...

  4. vuejs 父组件向子组件传递($broadcast()的用法)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. paper资料

    1.Ycbcr  RGB空间转换 :http://www.cnblogs.com/Imageshop/archive/2013/02/14/2911309.html 2.抠图:http://www.c ...

  6. 判断js对象的数据类型,有没有一个最完美的方法?

    先来一个例子: var string1=""; var string2=new String(""); alert(typeof string1); // st ...

  7. Angular - - ngReadonly、ngSelected、ngDisabled

    ngReadonly 该指令将input,textarea等文本输入设置为只读. HTML规范不允许浏览器保存类似readonly的布尔值属性.如果我们将一个Angular的插入值表达式转换为这样的属 ...

  8. 2.5. Integer 16 、Integer 32、Integer 64(Core Data 应用程序实践指南)

    Core Data 使用 “带符号的整数”,通常我们会选择Integer 32,如果不够,可以升级为Integer 64 (第3章),通过升级托管对象模型. 这三种类型对应的特性(Property)类 ...

  9. js原生设计模式——2面向对象编程之继承—new类式继承

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  10. jQuery css,position,offset,scrollTop,scrollLeft用法

    jQuery css,position,offset,scrollTop,scrollLeft用法: <%@ page language="java" import=&quo ...