-
Notifications
You must be signed in to change notification settings - Fork 3
/
aws.otl
923 lines (922 loc) · 36.2 KB
/
aws.otl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
aws id=g13081
points aws
listing all resources
list-resources cli
ref
list-resources <url:/Users/mertnuhoglu/projects/study/code/study_aws_cli.Rmd#tn=list-resources>
https://docs.aws.amazon.com/cli/latest/reference/ram/list-resources.html
https://stackoverflow.com/a/48288505/29246
Tag Manager
https://resources.console.aws.amazon.com/r/tags
.select all regions
.select all resource types
costs / billing reports
https://console.aws.amazon.com/billing/home?#/reports
https://console.aws.amazon.com/billing/home#/reports/usage
process: move a volume to another instance or restore a backup snapshot id=g10744
process: move a volume to another instance or restore a backup snapshot <url:file:///~/gdrive/mynotes/content/code/ccode.md#r=g10744>
ref
~/projects/bizqualify/BQ-data-run/datarun/restore_snapshot_on_aws_ec2_20181220.md
https://www.techrepublic.com/blog/the-enterprise-cloud/backing-up-and-restoring-snapshots-on-amazon-ec2-machines/
problem
current instance: bzq02
new instance: bzq03
need to move all data of bzq02 to bzq03
aws console: new volume. name `bzqdb`
aws ec2 create-volume --size 2000 --region us-west-2 --availability-zone us-west-2c --volume-type gp2
attach `bzqdb` to `bzq02` instance
Get volume id of `bzqdb` and instance id of `bzq02`
aws ec2 describe-volumes --filters Name=tag:Name,Values=bzqdb | jq '.Volumes[].VolumeId'
"vol-01dbb839dedafbee9"
aws ec2 describe-instances --filters Name=tag:Name,Values=bzq02 | jq '.Reservations[].Instances[].InstanceId'
"i-027ae2359c7142343"
attach bzqdb to bzq02
aws ec2 attach-volume --instance-id i-027ae2359c7142343 --volume-id vol-01dbb839dedafbee9 --device /dev/sdf
mount `bzqdb` volume on `bzq02` instance
Check volume name:
sudo lsblk --output NAME,TYPE,SIZE,FSTYPE,MOUNTPOINT,LABEL
> xvdf disk 2T
format the volume
sudo file -s /dev/xvdf
sudo mkfs -t ext4 /dev/xvdf
Mount `xvdf`
sudo mkdir /data
sudo mount /dev/xvdf /data
copy `bzq02` home dir and data dir to `bzqdb`
Copy home directory:
sudo rsync -aP ~/ /data/home/
Check postgres data directory:
sudo -u postgres psql -c "SHOW data_directory;"
> /var/lib/postgresql/9.5/main
Stop postgres
sudo systemctl stop postgresql
sudo systemctl status postgresql
Copy postgres data directory:
sudo rsync -aP /var/lib/postgresql/9.5/main /data/postgresql/
detach volume `bzqdb` from `bzq02`
First unmount it:
sudo umount -d /dev/xvdf
Detach it from `bzq02`
aws ec2 detach-volume --instance-id i-027ae2359c7142343 --volume-id vol-01dbb839dedafbee9
aws console: new instance `bzq03`
aws ec2 request-spot-instances --spot-price "" --type "one-time" --launch-specification file://xxx.json
attach `bzqdb` to `bzq03` instance
Get instance id of `bzq03`
aws ec2 describe-instances --filters Name=tag:Name,Values=bzq03 | jq '.Reservations[].Instances[].InstanceId'
"i-03317e7025b6e7aaf"
attach
aws ec2 attach-volume --volume-id vol-01dbb839dedafbee9 --instance-id i-03317e7025b6e7aaf --device /dev/sdf
mount `bzqdb` volume on `bzq03` instance
ssh awsbzq3
sudo lsblk --output NAME,TYPE,SIZE,FSTYPE,MOUNTPOINT,LABEL
xvdf disk 2T ext4
sudo mkdir /data
sudo mount /dev/xvdf /data
postgres: change data dir to `bzqdb` data dir
Stop postgres before changing data directory:
sudo systemctl stop postgresql
sudo systemctl status postgresql
Assert that data directory in mounted volume exists:
sudo ls /data/postgresql/main/
Edit postgres conf file:
sudo vim /etc/postgresql/9.5/main/postgresql.conf
data_directory = '/data/postgresql/main/'
start postgres
sudo systemctl start postgresql
sudo systemctl status postgresql
symlink `bzq03` home dir to `bzqdb` dirs
ln -s /data/home/bizqualify_data/ /home/ubuntu/bizqualify_data
ln -s /data/home/backup/ /home/ubuntu/backup
ln -s /data/home/bizqualify_log/ /home/ubuntu/bizqualify_log
ln -s /data/home/BQ-data-run/ /home/ubuntu/BQ-data-run
ln -s /data/home/clients/ /home/ubuntu/clients
terminate `bzq02`
terminate instance
aws ec2 terminate-instances --instance-ids i-027ae2359c7142343
Delete volumes of `bzq02`
aws ec2 describe-volumes --filters Name=status,Values=available | jq '.Volumes[].VolumeId'
"vol-011c509651643e1e2"
"vol-03c829218b96efaf8"
aws ec2 delete-volume --volume-id vol-011c509651643e1e2
aws ec2 delete-volume --volume-id vol-03c829218b96efaf8
allocate elastic ip address
aws ec2 describe-addresses | jq '.Addresses[].PublicIp'
"34.215.116.149"
aws ec2 associate-address --instance-id i-03317e7025b6e7aaf --public-ip 34.215.116.149
process: setup ec2 instance from terminal id=g10726
process: setup ec2 instance from terminal <url:file:///~/gdrive/mynotes/content/code/ccode.md#r=g10726>
ref
aws ec2 User Guide <url:file:///~/Dropbox/mynotes/content/code/ccode.md#r=g10165>
creating a new iam user
ref: Creating IAM Admin User and Group <url:file:///~/gdrive/mynotes/content/code/ccode.md#r=g10642>
where are configuration and credentials info?
~/.aws/config
~/.aws/credentials
users groups and root
root is your actual aws account: [email protected]
but you shouldn't use it at all
see: ref: Creating IAM Admin User and Group <url:file:///~/gdrive/mynotes/content/code/ccode.md#r=g10642>
ex: groups
Administrators, Readers, Developers
you will have multiple iam users
when you use aws client, you need to mention which iam user:
aws s3 ls --profile Administrator
this iam user profile is defined inside ~/.aws/credentials
s3 # s3
http://www.hongkiat.com/blog/amazon-s3-the-beginners-guide/
using amazon s3
bucket = root folder
https://paulstamatiou.com/how-i-use-amazon-s3/
https://paulstamatiou.com/2007/07/29/how-to-bulletproof-server-backups-with-amazon-s3
why
automate backup process
AWS S3 User Guide
Objects
Operations on Objects
Uploading Objects
Uploading Objects Using Pre-Signed URLs
http://docs.aws.amazon.com/AmazonS3/latest/dev/PresignedUrlUploadObject.html
All objects and buckets by default are private.
The pre-signed URLs are useful
if you want your user/customer to be able to upload a specific object to your bucket,
but you don't require them to have AWS security credentials or permissions
aws lambda
AWS.Lambda.A.Guide.to.Serverless.Microservices.B016JOMAEE.epub
Amazon Web Services in Action
Part 2: Building virtual infrastructure with servers and networking
ch03: Using virtual servers: EC2
3.1 Exploring a virtual server
physical server: host server
virtual servers running on it: guests
hypervisor: software that isolates guests from each other
3.1.1 Launching a virtual server
ec2 > Launch Instance
selecting an OS:
preinstalled software for virtual server: Amazon Machine Image (AMI)
virtual appliances: imagge containing an OS and preconfigured software
AMI doesn't include kernel of the OS
kernel is loaded from Amazon Kernel Image (AKI)
hypervisor on aws: Xen
Hardware Virtual Machine (HVM): virtual servers that use hardware-assisted virtualization
make sure you use HVM images
Choosing Size
ex: t2.micro
t: instance family
small virtual servers
2: generation
micro: size
Instance Details
options
IAM role
Shutdown behavior
Enable termination protection
Monitoring: Enable CloudWatch
Storage
Tags
Reviewing your Input
3.1.2 Connecting to a virtual server
ssh -i <path_to_key.pem> ubuntu@<public_ip>
3.2 Monitoring and debugging a virtual server
3.2.1 Showing logs
ec2 console > instances > .select server > Actions > Instance Settings > Get System Log
3.2.2 Monitoring the load
ec2 console > instances > .select server > Monitoring > Network In
3.3 Shutting down
actions:
start
stop: not billed. can be started
reboot: no data lost. restarts
terminate: deletes it. deletes dependencies like network-attached storage too
3.4 Changing the size
it is possible to change the size
start a new server
ec2 console > Launch Instance > .select server > .choose instance type > Launch
# get cpu info
cat /proc/cpuinfo
# get memory info
free -m
stop server
ec2 console > instances > .select instance > Instance State > Stop
change instance type
Instance Settings > Actions > .select instance type > Apply
3.5 Starting a virtual server in another data center
3.6 Allocating a public IP address
ec2 console > Elastic IPs > Allocate New Address
3.7 Adding an additional network interface
why:
to assign two different public IP addresses
then you can serve two different websites depending on the public IP address
3.8 Optimizing costs
On-demandn
Reserved
Spot
3.8.1 Reserve virtual servers
3.8.2 Bidding on unused virtual servers: spot instances
ch04: Programming your infrastructure
intro
4.1 Infrastructure as code
4.1.1 Automation and the DevOps movement
4.1.2 Infrastructure language: JIML (JSON Infrastructure Markup Language)
ex:
{
infrastructure: {
loadbalancer: {
server: {...}
}
, cdn: {...}
, database: {...}
}
}
$ indicates a reference to an ID
ex:
{
"region": "us-east-1",
"resources": [
{
"type": "loadbalancer",
"id": "LB",
"config": {
"server": {
"cpu": 2,
"ram": 4,
"os": "ubuntu",
"waitFor": "$DB"
},
"servers": 2
}
}
, {
"type": "cdn",
"id": "CDN",
"config": {
"defaultSource": "$LB",
"sources": [{
"path": "/static/*",
"source": "$BUCKET"
}]
}
}
, {
"type": "database",
"id": "DB",
"config": {
"password": "***",
"engine": "MySQL"
}
}
, {
"type": "dns",
"config": {
"from": "www.mydomain.com",
"to": "$CDN"
}
}
, {
"type": "bucket",
"id": "BUCKET"
}
]
}
how to turn this JSON to API calls?
build dependency graph
from bottom to top
nodes with no children: DB and bucket
they have no dependencies
server nodes depend on DB node
build linear flow of commands
4.2 Using CLI
4.2.1 Installing CLI
sudo pip install awscli
4.2.2 Configuring CLI
don't use aws root account
create a new user in IAM service
get aws access key id and secret access key
cli
aws configure
4.2.3 Using CLI
ex: get a list of ec2 instances of type t2.micro
$ aws ec2 describe-instances --filters "Name=instance-type,Values=t2.micro"
general template:
$ aws <service> <action> [--key value ...]
aws help
aws <service> help
aws <service> <action> help
ex: server.sh
aws ec2 describe-images --filters "Name=description, Values=Amazon Linux AMI 2015.03.? x86_64 HVM GP2" --query "Images[0].ImageId" --output text
note: --query option uses JMESPath
ex
{
"Images": [
{
"ImageId": "ami-146e2a7c",
"State": "available"
}, {
"State": "available"
}
]
}
ex:
Images[0].ImageId
Images[*].State
4.4 Using a blueprint
AWS CloudFormation: better than JIML
based on templates = blueprint
4.4.1 Anatomy of CloudFormation template
5 parts:
1. Format version
2. Description
3. Parameters
4. Resources
5. Outputs
Output
ex: references "Server"
"Outputs": {
"ServerEC2ID": {
"Value": {"Ref": "Server"},
"Description": "EC2 ID of the server"
},
"PublicName": {
"Value": {"Fn::GetAtt": ["Server", "PublicDnsName"]},
"Description": "Public name of the server"
}
}
4.4.2 Creating your first template
ex: case: provide a virtual server
server needs more cpu
CloudFormation: change InstanceType property
code
ref
<url:file:///~/codes/aws/aws_in_action/chapter4/server.json>
...
"InstanceType": {
"Description": "Select one of the possible instance types",
"Type": "String",
"Default": "t2.micro",
"AllowedValues": ["t2.micro", "t2.small", "t2.medium"]
}
stack = instance
template = class
next
Finding a Linux AMI <url:#r=ccd_0008>
ch05: Automating deployment
5.1 Deploying applications in a flexible cloud environment
5.2 Running a script on server startup using CloudFormation
5.3 Deploying with Elastic Beanstalk
intro
to deploy common web apps
based on php, java, py, docker ...
5.3.1 Components of Elastic Beanstalk
application: logical container
version: first upload executables to S3
configuration template: default configuration
environment:
5.3.2 Using Elastic Beanstalk for Etherpad
create an application
aws elasticbeanstalk create-application --aplication-name etherpad
create a version
aws elasticbeanstalk create-application-version --application-name etherpad ---version-label 1.5.2 --source-bundle S3Bucket=awsinaction,S3Key=chapter5/etherpad.zip
create an environment
# create an environment for nodejs basen on AMI
# use a solution stack name
aws elasticbeanstalk ...
5.4 Deploying a multilayer application with OpsWorks
complex applications consisting of different services (layers)
then use OpsWorks not Elastic Beanstalk
OwsWorks controls AWS resources like
virtual servers, load balancers, databases
Chef: deployment controller
community recipes:
https://supermarket.chef.io/
5.4.1 Components of OpsWorks
/Users/mertnuhoglu/Dropbox/public/img/ss-254.png
elements
stack: container for all other components
layer: belongs to a stack
represents an application/service
instance: represents virtual server
multiple instances per layer
app: software to deploy
5.4.2 Using OpsWorks to deploy IRC chat app
steps
1. create a stack
2. create a nodejs layer for kiwiIRC
3. create a custom layer for IRC server
4. create an app to deploy kiwiIRC to nodejs layer
5. add an instance for each layer
5.5 Comparing deployment tools
intro
we deployed in three ways in this chapter:
1. AWS CloudFormation: to run a script on server startup
2. AWS Elastic Beanstalk: to deploy a common web app
3. AWS OpsWorks: to deploy a multilayer application
differences between these solutions
5.5.1 Classifying the deployment tools
more control: CloudFormation
OpsWorks
more conventions: Elastic Beanstalk
5.5.2 Comparing deployment services
ch06: Securing your system
intro
4 critical steps:
1. installing software updates
2. restricting access to your AWS account
3. controlling network traffic to and from ec2 instances
4. creating a private network in AWS
6.1 Who's responsible for security?
6.2 Keeping your software up to date
6.2.1 Checking for security updates
when logging in, linux warns you:
4 package(s) needed for security, out of 28 available
Run "sudo yum update" to apply all updates
which packages require a security update
yum --security check-update
6.2.2 Installing security updates on server startup
when using CloudFormation
opt
install all updates on server start
$ yum -y update
# put in user-data script
install security updates on server start
$ yum -y --security update
# put in user-data script
define package versions explicitly
ex: user-data script
"Server": {
"Type": "AWS::EC*::Instacnce",
"Properties": {
...
"UserData": {"Fn::Base64": {"Fn::Join": ["", [
"#!/bin/bash -ex\n",
"yum -y update\n"
]]}}
}
}
problem with installing all updates:
system becomes unpredictable
6.2.3 Installing security updates on running servers
run on all servers automatically
<url:file:///~/codes/aws/aws_in_action/chapter6/update.sh>
PUBLICNAMES=$(aws ec2 describe-instances --filters "Name=instance-state-name,Values=running" --query "Reservations[].Instances[].PublicDnsName" --output text)
for PUBLICNAME in $PUBLICNAMES; do
ssh -t -o StrictHostKeyChecking=no ec2-user@$PUBLICNAME "sudo yum -y --security update"
6.3 Securing your AWS account
authenticating with your account
3 ways:
1. root user
2. normal user
3. authenticating as an aws resource like an ec2 instance
for users
need password or access keys
6.3.1 Securing root user
console > .click your name > security credentials > install mfa app > expand mfa > activate mfa
6.3.2 Identity and Access Management service (IAM)
every request to aws api goes through IAM
IAM checks who (authentication) can do what (authorization)
authentication: defined by users and roles
authorization: defined by policies
6.3.3 Policies for authorization
defined in json
contains some statements
allow/deny some action on some resource
list of actions
http://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_Operations.html
ex: a statement
{
"Version": "2012-10-17",
"Statement": [{
"Sid": "1",
"Effect": "Allow",
"Action": ["ec2:*"],
"Resource": ["*"]
}]
}
Deny overrides Allow
ex: allows all actions except terminating instances
{
"Version": "2012-10-17",
"Statement": [{
"Sid": "1",
"Effect": "Allow",
"Action": ["ec2:*"],
"Resource": ["*"]
}, {
"Sid": "2",
"Effect": "Deny",
"Action": ["ec2:TerminateInstances"],
"Resource": ["*"]
}]
}
aws ec2 User Guide id=g10165
aws ec2 User Guide <url:file:///~/Dropbox/mynotes/content/code/ccode.md#r=g10165>
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/RootDeviceStorage.html?shortFooter=true
What is EC2
Amazon EC2 Root Device Volume
root device volume: image used to boot the instance
AMIs backed by either
a template ec2 from instance store
a EBS snapshot (recommended)
they use persistent storage
Root Device Storage Concepts
description of AMI includes either:
ebs
instance store
Instance Store-backed Instances
when instance terminated, all data is deleted
no Stop action
EBS-backed Instances
root volume is an EBS volume
can be restarted without affecting data in attached volumes
when stopped, you can do:
modify properties of the instance
change size of instance
update kernel
attach root volume to a different instance
if ebs-backed instance fails:
stop and start agagin
snapshot all volumes to create a new AMI
attach volume to new instance:
1. create snapshot of root volume
register new AMI using snapshot
Setting Up
1. Sign Up AWS
2. Create IAM User
3. Create a Key Pair
check regions
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html?shortFooter=true
us-east-2
US East (Ohio)
dashboard > ec2 > navigation pane > .select region: us-east-2 (Ohio)
navigation pane > network & security > Key Pairs
.Key Pair Name = mertnuhoglu-key-pair-useast2
download and save pem file
chmod 400 mertnuhoglu-key-pair-useast2.pem
4. Create a Virtual Private Cloud (VPC)
check if VPC is supported:
ec2 > Account Attributes > Supported: VPC
5. Create a Security Group
allow ssh access from specific ip addresses
ec2 > navigation pane > Security Groups > Create Security Group
name: mertnuhoglu_sg_useast2
type: http | source: anywhere
type: https | source: anywhere
type: ssh | source: anywhere
Getting Started
1. Launch an Instance
ec2 dashboard > Launch Instance AMI (Amazon Machine Image)
Choose an Instance Type
Best Practices
Storage
ensure volume with data persists after instance termination
Preserving Amazon EBS Volumes on Instance Termination <url:#r=ccd_0005>
Tutorials
Amazon Machine Images
Finding a Linux AMI id=ccd_0008
Finding a Linux AMI <url:#r=ccd_0008>
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/finding-an-ami.html
Using EC2 Console
ec2 console > navigation bar > .region
sidebar > AMIs > .Filter options = Public images
.select image > Launch Instance
Using CLI
ex: public AMIS owned by you or Amazon
$ aws ec2 describe-images --owners self amazon
ex: only AMIs backed by EBS
$ aws ec2 describe-images --owners self amazon --filters "Name=root-device-type,Values=ebs"
Instances
Instance Purchasing Options
Spot Instances
How Spot Fleet Works id=ccd_0007
How Spot Fleet Works <url:#r=ccd_0007>
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-fleet.html?shortFooter=true
intro
Spot Fleet is
a collection of spot instances
tries to meet target capacity you request
Allocation Strategy
strategies
lowestPrice: default strategy
diversified: distributed across pools
Spot Instance Requests
Spot Instance Request States
open active failed closed cancelled
types of requests:
one-time
persistent
one-time request life: open -> active -> closed
persistent request life: open -> active -> open -> active ...
Specifying a duration
amazon doesn't terminade instances with specified durations
price is fixed and remanis in effect until instance terminates
cli
aws ec2 request-spot-instances --spot-price "0.050" --instance-count 5 --block-duration-minutes 120 --type "one-time" --launch-specification file://specification.json
Specifying a Tenancy
ref
Dedicated Instances <url:#r=ccd_0006>
for dedicated instances
Service-Linked Role
Creating request
console
ec2 > Spot Requests > Request Spot Instances
.Request type: Request
cli
# one-time
aws ec2 request-spot-instances --spot-price "0.05" --instance-count 5 --type "one-time" --launch-specification file://specification.json
# persistent
aws ec2 request-spot-instances --spot-price "0.05" --instance-count 5 --type "persistent" --launch-specification file://specification.json
Spot Fleet Requests
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/spot-fleet-requests.html?shortFooter=true#create-spot-fleet
ref
How Spot Fleet Works <url:#r=ccd_0007>
intro
amazon tries to maintain your fleet's target capacity
Dedicated Instances id=ccd_0006
Dedicated Instances <url:#r=ccd_0006>
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/dedicated-instance.html
physically isolated from other aws accounts
Instance Lifecycle
Terminate
https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/terminating-instances.html#preserving-volumes-on-termination
intro
deleting instance = terminating instance
state: shutting-down or terminated
no further charges incur
you can't restart terminated instances
Storage
Amazon EBS (Elastic Block Store)
http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/AmazonEBS.html
intro
storage volumes for use with ec2 instances
ebs volumes persist independently from instance
Preserving Amazon EBS Volumes on Instance Termination id=ccd_0005
Preserving Amazon EBS Volumes on Instance Termination <url:#r=ccd_0005>
ec2 spot prices
awespottr: find cheapest ec2 spot prices
https://github.com/arithmetric/awespottr
npm install -g awespottr
awespottr -h
awespottr c4.xlarge
price history
https://www.reddit.com/r/aws/comments/4ue6il/how_to_bid_for_cheapest_spot_instances_all/
aws ec2 describe-spot-price-history --product-description "Linux/UNIX" --instance-types c4.xlarge --start-time `date -u --date="7 days ago" +'%Y-%m-%dT%H:%M:00'` | jq -r -c '.SpotPriceHistory[] | (.Timestamp),(.SpotPrice)'
aws ec2 describe-spot-price-history --product-description "Linux/UNIX" --instance-types c4.xlarge --start-time `date -u --date="7 days ago" +'%Y-%m-%dT%H:%M:00'` | jq -r -c '.SpotPriceHistory[]'
by region / availability zone
export AWS_DEFAULT_REGION=us-east-2
aws ec2 describe-spot-price-history --availability-zone "${AWS_DEFAULT_REGION}b" --product-description "Linux/UNIX" --instance-types c4.xlarge --start-time `date -u --date="7 days ago" +'%Y-%m-%dT%H:%M:00'` | jq -r -c '.SpotPriceHistory[] | (.Timestamp),(.SpotPrice)'
# note if you don't specify region, then it only list prices for default region
aws cli
ref
http://localhost:8888/notebooks/aws%20study.ipynb
configure
aws configure list
multiple profiles
environment variables
override configuration
used for temporarily
ex
AWS_DEFAULT_REGION
export AWS_DEFAULT_REGION=us-west-2
list ebs volumes
aws ec2 describe-volumes
AWS Security Credentials User Guide
https://docs.aws.amazon.com/general/latest/gr/aws-security-credentials.html
Root User vs IAM User Credentials
Recommended: Delete your root user access keys
create IAM user credentials for interaction with AWS
You can have multiple unique credentials for each user
Define who has access to which resources
Tasks That Require Root User Credentials id=g10641
Tasks That Require Root User Credentials <url:file:///~/Dropbox/mynotes/content/code/ccode.md#r=g10641>
https://docs.aws.amazon.com/general/latest/gr/aws_tasks-that-require-root.html
Modify root user password
Change support plan
Payment options
Close an account
Reverse DNS
Create CloudFront key pair
Find account canonical user ID
Restoring IAM user permissions
IAM (Identity and Access Management) User Guide
https://docs.aws.amazon.com/IAM/latest/UserGuide/introduction.html
ref
http://localhost:8888/notebooks/study_aws.ipynb
what is iam?
https://docs.aws.amazon.com/IAM/latest/UserGuide/intro-structure.html
to control
who can use aws (authentication)
how they can use resources (authorization)
Understanding how IAM Works
Principal: an entity that can make a request for an action/operation on an aws resource
ex: users, roles, federated users, applications
aws account root user: first principal
Request: using aws management console, aws api, aws cli
includes following information:
actions/operations
resources: upon which actions are performed
principal
environment data: ip, user agent, time
resource data: ex: db table name, ec2 instance tag
Authentication
Authorization
policy types:
permissions policies
permissions for the object to which they are attached
ex: identity based policies, resource based policies, ACLs
permissions boundaries
advanced feature
allows you to use policies to limit maximum permissions that a principal can have
identity based policies: to provide users access aws resources in their own account
resource based policies: for granting cross-account access
Actions or Operations
ex: viewing, creating, editing, deeleting a resource
ex: CreateUser, DeleteUser, GetUser
Overview: Users
IAM Users: they are users within your account
an app can be an IAM user
Federating Existing Users
if the users already have a way to be authenticated, you can federate those user identities into aws.
ex: login by google (openid)
Overview: Permissions and Policies
authorization
policies and accounts
Getting Setup
create a user and group
signin page
https://iterative.signin.aws.amazon.com/console
Getting Started
First: set up an admin group for your AWS account
Creating IAM Admin User and Group id=g10642
Creating IAM Admin User and Group <url:file:///~/gdrive/mynotes/content/code/ccode.md#r=g10642>
https://docs.aws.amazon.com/IAM/latest/UserGuide/getting-started_create-admin-group.html
Recommended: Don't use root user for any task if it is not required
create a new IAM user instead
see: Tasks That Require Root User Credentials <url:file:///~/Dropbox/mynotes/content/code/ccode.md#r=g10641>
opt01: Console
Sign in to IAM console using root user
https://console.aws.amazon.com/iam/
Users > Add user
.User Name: Administrator
...
Create Group > Filter policies > AWS managed - job function
.AdministratorAccess
> Create Group
Identities
Users
Multi-Factor Authentication
Using Multi-Factor Authentication (MFA) in AWS
http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_mfa.html
intro
two ways
security token based
you need to enable a device for MFA
sms based (not valid anymore)
not for root user
only for IAM users
Enabling a Virtual Multi-factor Authentication (MFA) Device
http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_mfa_enable_virtual.html?shortFooter=true
note: you save a copy of the QR code or the secret key in a secure place.
if you lose the phone, you can reconfigure the app using same virtual MFA
Enable a Virtual MFA Device for an IAM User
Enable and manage virtual MFA devices (AWS CLI)
http://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_mfa_enable_cliapi.html?shortFooter=true
you must use AWS Console to manage for root user
articles
Backing up and restoring snapshots on Amazon EC2 machines id=ccd_0009
Backing up and restoring snapshots on Amazon EC2 machines <url:#r=ccd_0009>
https://www.techrepublic.com/blog/the-enterprise-cloud/backing-up-and-restoring-snapshots-on-amazon-ec2-machines/
create a snapshot
1. ec2 console > instances > .select instance
2. > root device
3. Elastic Blockstore > Snapshots > Create Snapshot
Tricks to make an AWS spot instance “persistent”?
https://stackoverflow.com/questions/19575348/tricks-to-make-an-aws-spot-instance-persistent
ans
ans2
1. create a new spot request
uncheck "Delete on Termination" for root device
2. ssh into instance
make a file
3. create a snapshot
Backing up and restoring snapshots on Amazon EC2 machines <url:#r=ccd_0009>
4. exit ssh and terminate instance
5. create AMI from snapshot
new spot request using new image
Virtualization: hvm
uncheck "Delete on Termination" for root
expand: "Advanced Options" > set kernel ID
steps
ebs volume
vol-03058883d903bf9ed
next
snapshot nedir
kernel id vs. opsiyonları incele
persistence konularını arat
AWS Tips I Wish I'd Known Before I Started
https://wblinks.com/notes/aws-tips-i-wish-id-known-before-i-started/
intro
paradigm shift: from pheysical servers to cloud
physical: you care about each host
Application Development
Store no application state on your servers
ex: sessions stored in database not on local filesystem
ex: logs handled via syslog and sent to remote store
ex: uploads go directly to S3
tip: use pre-signed URLs to let users upload directly to S3
http://docs.aws.amazon.com/AmazonS3/latest/dev/PresignedUrlUploadObject.html
ex: long running tasks done via an async queue (SQS)
Store extra information in your logs
extra: instance-id, region, availability-zone, environment
get data from: instance metadata service
If you need to interact with AWS, use the SDK for your langauge.
Have tools to view application logs.
minimal tool set: admin tool, syslog viewer, centralised logging
most important: disable ssh
Operations
Disable ssh access to all servers
If you have to SSH into your servers, then your automation has failed
this forces you to paradigm shift
highlihts any areas you need to automate
Servers are ephemeral, you don't care about them. You only care about the service as a whole.
if a server dies
no concern to you
because auto-scaling gives you a fresh new instance soon
ex: netflix: Chaos Monkey
kills random instances in production
Don't give servers static/elastic IPs.
for auto-scaling: use load balancer instead of unique IPs per instance
Automate everything
ex: recovery, deployment, failover etc.
Everyone gets an IAM account. Never login to the master
ex: extreme case
some users who give the MFA token to two people, and the password to two others, so to perform any action on the master account, two of the users need to agree
Get your alerts to become notifications
your health checks should automatically destroy bad instances and spawn new ones
if everything is automated
Billing
Set up granular billing alerts
Security
Use EC2 roles, do not give applications an IAM account
Assign permissions to groups, not users
Set up automated security auditing
Use CloudTrail to keep an audit log
S3
Use "-" instead of "." in bucket names for SSL
Avoid filesystem mounts (FUSE, etc).
You don't have to use CloudFront in front of S3 (but it can help)
S3 can scale to any capacity
for very high bandwidth: use CDN like CloudFront in front of S3
CloudFront can dramatically speed up access for users around the globe, as it copies your content to edge locations
Use random strings at the start of your keys
EC2/VPC
Use tags!
good for organising things, easier to search and group things up
to trigger specific actions:
ex: env=debug
can put your app into debug mode when it deploys
Use termination protection for non-auto-scaling instances. Thank me later
one-off things that aren't under auto-scaling, then you should probably enable termination protection, to stop anyone from accidentally deleting the instance
Use a VPC
easy to set up
uses
control traffic at network level using ACLs
modify instance size, security groups etc. without terminating instance
private subnet where instances are isolated from outside
Use reserved instances to save big $$$
Lock down your security groups
Don't use 0.0.0.0/0
Don't keep unassociated Elastic IPs
ELB
Terminate SSL on the load balancer
Pre-warm your ELBs if you're expecting heavy traffic
ElastiCache
Use the configuration endpoints, instead of individual node endpoints
CloudWatch
Use the CLI tools
Use the free metrics
Use custom metrics
Use detailed monitoring
Auto-Scaling
IAM
Use IAM roles
Users can have multiple API keys
Multi-factor authentication
Route53
Use ALIAS records
free
Misc
Scale horizontally
using lots of smaller machines is more reliable
hn discussion
https://news.ycombinator.com/item?id=7172060
quora
What is the most difficult part of setting up an AWS cloud infrastructure? Do you find cloud formation to be very complicated to use?
www.quora.com/What-is-the-most-difficult-part-of-setting-up-an-AWS-cloud-infrastructure-Do-you-find-cloud-formation-to-be-very-complicated-to-use
ans
cloudformation is complex
recommend using:
editor that understands json
json validators
aws cloudformation validate-template
CloudFormer
create infrastructure through console/cli
run cloudformer
it creates cf template