AWS的一些命令操作

1, 配置AWS CLI,AWS Access Key ID可以从AWS控制台得到

[root@bjsconsole ~]# aws configure
AWS Access Key ID []: ****************
AWS Secret Access Key []: ***************
Default region name []: cn-north-1
Default output format [None]:

2,启动EC2虚拟机器,先准备一个需要在启动过程中执行的脚本

[bjs@bjsconsole ~]$ cat my_script.txt

yum install telnet -y

3,通过如下的命令启动EC2. 你可能需要先创建相关的资源,比如安全组,子网和placement  group。

[bjs@bjsconsole ~]$ aws ec2 run-instances –image-id ami-3fe13752 –count 2 –instance-type c4.8xlarge –key-name mykey-zhenyong-private –region cn-north-1 –security-group-ids sg-efcac28d  –subnet-id subnet-b2e6f2c6 –user-data file://my_script.txt –placement   “{ \”GroupName\”: \”test\” }”

4, 可以通过AWS CLI命令或者API得到虚拟机的列表

[bjs@bjsconsole ~]$ aws ec2 describe-instances –filters “Name=instance-type,Values=c4.8xlarge” “Name=instance-state-code,Values=16” | grep InstanceId

5,创建磁盘EBS,设置磁盘的IOPS为20000,并把磁盘挂在到AWS的EC2上

[bjs@bjsconsole ~]$ aws ec2 create-volume –region cn-north-1 –availability-zone cn-north-1b –size 400 –volume-type io1 –iops 20000

[bjs@bjsconsole ~]$ aws ec2 create-volume –region cn-north-1 –availability-zone cn-north-1b –size 400 –volume-type io1 –iops 20000

[bjs@bjsconsole ~]$ aws ec2 attach-volume –volume-id vol-0a6cfa07828f05ddf –instance-id i-04ec9cae4f402c8ed –device /dev/sdb

[bjs@bjsconsole ~]$ aws ec2 attach-volume –volume-id vol-001a4156071f183a6  –instance-id i-0d75e9a4071ffbfc0  –device /dev/sdb

6,把互联网IP地址连接到虚拟机上。

[bjs@bjsconsole ~]$ aws ec2 associate-address –instance-id i-04ec9cae4f402c8ed  –allocation-id eipalloc-dfe281e5

[bjs@bjsconsole ~]$ aws ec2 associate-address –instance-id i-0d75e9a4071ffbfc0 –allocation-id eipalloc-743b584e

7,登陆到虚拟机上,安装一些必要的软件,准备执行后续的操作。

[root@ip-10-128-2-224 ~]# yum install fio iperf -y –enablerepo=epel

8,在一台虚拟机上执行iperf –s,

[root@ip-10-128-2-224 ~]# iperf -s

9,另一台虚拟机上执行iperf –c, 检查网络带宽。这是两台c4.8xlarge的虚拟机,网络性能为10Gbps,可以看到网络带宽实测数据非常接近。

[root@ip-10-128-2-92 ~]# iperf -c 10.128.2.224

10,接下来在虚拟机上执行对磁盘的测试,先进行分区,然后创建文件系统

[root@ip-10-128-2-224 ~]# fdisk /dev/sdb

[root@ip-10-128-2-224 ~]# mkfs.ext4 /dev/sdb1

 

11,挂载设备到/mnt目录,通过ioping检查磁盘的延迟。可以看到延迟大约在300us(0.3ms)左右。

[root@ip-10-128-2-224 ~]# mount /dev/sdb1 /mnt/

[root@ip-10-128-2-224 ~]# ioping -c 10 /mnt/

12,使用fio进行磁盘压力测试,可以看到磁盘的IO性能非常稳定的在20000IOPS附近,带宽在340MB/s左右,注意,这是单盘的性能,通过增加EBS的数量,还可能增加并发的性能。

[root@ip-10-128-2-224 mnt]# fio -direct=1 -iodepth=128 -rw=randwrite -ioengine=libaio -bs=16k -size=10G -numjobs=1 -runtime=1000 -group_reporting -filename=iotest -name=Rand_Write_Testing

12,使用cloudwatch取到EC2的监控数据。

[bjs@bjsconsole ~]$ aws cloudwatch get-metric-statistics –metric-name CPUUtilization –start-time 2017-05-24T04:00:0 –end-time 2017-05-24T04:35:0 –period 300 –namespace AWS/EC2 –statistics Average –dimensions Name=InstanceId,Value=i-04ec9cae4f402c8ed

 

== 其他参考==

启动EC2,指定使用EIP。

[bjs@bjsconsole ~]$ aws ec2 run-instances –image-id ami-3fe13752 –count 2 –instance-type c4.8xlarge –key-name mykey-zhenyong-private –region cn-north-1 –security-group-ids sg-efcac28d  –subnet-id subnet-b2e6f2c6 –user-data file://my_script.txt –placement   “{ \”GroupName\”: \”test\” }” –associate-public-ip-address

 

查看你的服务限制是否已经到上限:

[ec2-user@bjsconsole tools]$ aws support describe-trusted-advisor-check-result –language en –region us-east-1 –check-id eW7HH0l7J9

 

提交case给AWS

[ec2-user@bjsconsole tools]$ aws support create-case –subject “Test” –service-code “amazon-cloudwatch” –communication-body “Test” –region us-east-1 –category-code “apis”  –severity-code “low”
{
“caseId”: “case-936200357723-muen-2017-5e8e46d0d8557d0e”
}

你可能感兴趣的:(AWS的一些命令操作)