+4

Using localstack to test functional(SQS, SNS, S3...) AWS locally

Localstack là gì ?

AWS đã quá nổi tiếng. Những dịch vụ của AWS đều rất tốt, đó đều là những lựa chọn hàng đầu cho việc phát triển phần mềm. Nhưng có một vấn đề là aws không có một bản cài đặt chính thức nào ở local để cho chúng ta có thể dễ dàng test và kiểm tra một kiến trúc nào đó. Nhưng rất may, có một số chọn lựa mà chúng ta có thể dùng để thực hiện được điều này. Trong đó có localstack.

Chúng ta có thể hiểu localstack là AWS cloud stack cục bộ với đầy đủ chức năng. Nó bao gồm các dịch vụ của aws sau:

Cài đặt localstack

yêu cầu trước khi cài đặt:

- make
- python (both Python 2.x and 3.x supported)
- pip (python package manager)
- npm node.js package manager)
- java/javac (Java 8 runtime environment and compiler)
- mvn (Maven, the build system for Java)

chúng ta có thể dễ dàng cài đặt localstack bằng cách thông qua pip:

pip install localstack

hoặc chúng ta có thể cài đặt nó thông qua docker nếu như đã có cài đặt sẵn môi trường docker:

localstack start --docker

Start localstack

trước khi start nó thì hãy chắc chắn là chúng ta đã fake thông tin đăng nhập aws:

~/.aws/credentials

AWS_ACCESS_KEY_ID=foo
AWS_SECRET_ACCESS_KEY=bar

Để chạy localstack chỉ cần:

localstack start

hoặc chúng ta có thể chạy thông qua docker:

localstack start --docker

Sử dụng localstack với aws-cli

SQS

Create Queue:

$ aws --endpoint-url=http://localhost:4576 sqs create-queue --queue-name test_queue
{
    "QueueUrl": "http://localhost:4576/123456789012/test_queue"
}

List Queue:

$ aws --endpoint-url=http://localhost:4576 sqs list-queues
{
    "QueueUrls": [
        "http://localhost:4576/123456789012/test_queue"
    ]
}

Send a message to this queue:

$  aws --endpoint-url=http://localhost:4576 sqs send-message --queue-url http://localhost:4576/123456789012/test_queue --message-body 'Test Message!'
{
    "MD5OfMessageBody": "df69267381a60e476252c989db9ac8ad",
    "MessageId": "a6ed436b-076a-0d8d-73e1-cc3291a19c28"
}

Receive the message from this queue:

$  aws --endpoint-url=http://localhost:4576 sqs receive-message --queue-url http://localhost:4576/123456789012/test_queue
{
    "Messages": [
        {
            "Body": "Test Message!",
            "Attributes": {
                "ApproximateFirstReceiveTimestamp": "1.49138149959e+12",
                "SenderId": "AIDAIT2UOQQY3AUEKVGXU",
                "ApproximateReceiveCount": "1",
                "SentTimestamp": "1.49138142195e+12"
            },
            "ReceiptHandle": "xuazrzyjcgpgzpzlxlyxmujbgzfkswixjkywshturlylrfwzyccutlumitgduyzddwkaoypcmswlkxrrjghdyztfewrpmkxdufptyketrfumwzicmggogdbaucwztvorplibccpfhirmalnixvfbklzrgncpisdsiuiajqwefxueqhuygfibmgqwx",
            "MD5OfBody": "df69267381a60e476252c989db9ac8ad",
            "MessageId": "a6ed436b-076a-0d8d-73e1-cc3291a19c28"
        }
    ]
}

S3

Create a bucket:

$ aws --endpoint-url=http://localhost:4572 s3 mb s3://mytestbucket
make_bucket: mytestbucket

$ aws --endpoint-url=http://localhost:4572 s3 ls
2006-02-03 08:45:09 mytestbucket

Copy a file over:

$ aws --endpoint-url=http://localhost:4572 s3 cp /tmp/mongo.log s3://mytestbucket
upload: ../../../../tmp/mongo.log to s3://mytestbucket/mongo.log

$ aws --endpoint-url=http://localhost:4572 s3 ls s3://mytestbucket
2017-04-05 01:18:39       4789 mongo.log

Delete this file

$ aws --endpoint-url=http://localhost:4572 s3 rm s3://mytestbucket/mongo.log
delete: s3://mytestbucket/mongo.log

$ aws --endpoint-url=http://localhost:4572 s3 ls s3://mytestbucket
$

Kết luận

Ở trên là giới thiệu về local stack và hai ví dụ về 2 dịch vụ của aws. Các bạn có thể xem thêm ở đây. Hi vọng bài viết giúp ích được cho các bạn. Cảm ơn đã đọc bài (bow). Tham khảo: https://github.com/localstack/localstack

https://gugsrs.com/localstack-sqs-sns/

https://lobster1234.github.io/2017/04/05/working-with-localstack-command-line/


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí