Amazon RDS-인터페이스

RDS 인터페이스는 우리가 만든 RDS 서비스에 액세스하는 방법입니다. RDS 서비스를 만들고 구성한 후에는 데이터에 액세스하고이 데이터베이스에 데이터를 업로드하고 데이터베이스에 연결할 수있는 다른 프로그램을 실행해야합니다. 데이터베이스를 생성 한 AWS 계정 소유자가 반드시 이러한 인터페이스를 필요로하는 것은 아니라 데이터베이스의 최종 사용자가 데이터에 액세스하고 데이터를 조작하기위한 이러한 요구 사항입니다.

세 가지 주요 인터페이스가 있습니다.

이것은 사용자가 웹 브라우저를 통해 로그인하고 DB 서비스 사용을 시작할 수있는 가장 간단한 인터페이스입니다. 이러한 액세스의 단점은 RDS 서비스와 상호 작용하려면 사람이 필요하며 DB 백업 또는 분석 등과 같은 일반적인 작업을 수행하기 위해 데이터베이스 프로그램을 실행할 수 없다는 것입니다.

사용중인 클라이언트 컴퓨터에 설치되어 있어야하는 AWS 명령 프롬프트 화면을 통해 DB 명령을 실행할 수있는 CLI 액세스라고도합니다. 다음은 AWS 서비스에 액세스 할 로컬 시스템에 CLI를 설치하는 단계입니다.

AWS CLI를 설치하는 단계는 다음과 같습니다.

1 단계

사용자 환경에서 Python 버전을 확인하십시오.

ubuntu@ubuntu:~$ python -V
ubuntu@ubuntu:~$ python3 -V

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

Python 2.7.12 
Python 3.5.2

버전이 2.6 또는 3.3 미만인 경우 시스템에서 python 버전을 업그레이드해야합니다.

2 단계

pip라는 python 패키지의 가용성을 확인하십시오. AWS CLI를 설치하는 데 필요합니다.

Pip -V

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

pip 10.0.1 from /home/ubuntu/.local/lib/python3.5/site-packages/pip (python 3.5)

단계 -3

다음 명령을 실행하여 AWS CLI를 설치합니다.

pip install awscli –upgrade –user
aws --version

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

Aws-cli/1.11.84 Python/3.6.2 Linux/4.4.0

4 단계

다음으로 자격 증명으로 aws CLI를 구성합니다. 이 명령을 실행 한 다음 필요한 값을 하나씩 입력합니다.

aws configure

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

AWS Access Key ID [None]: ****PLE
AWS Secret Access Key [None]: ********8
Default region name [None]: us-west-2
Default output format [None]: json

위의 구성이 준비되었으므로 이제 Amazon RDS를 설정하고 사용하기 위해 AWS 환경과 통신하는 데 CLI를 사용할 준비가되었습니다. 다음 장에서 우리가 어떻게 할 수 있는지 볼 것입니다.

Amazon Relational Database Service (Amazon RDS)는 API (애플리케이션 프로그래밍 인터페이스)도 제공합니다. API는 사람이 명령을 내리고 결과를받는 대신 시스템간에 정보를 교환 할 때 사용됩니다. 예를 들어 트랜잭션 수가 특정 임계 값에 도달 할 때 RDS 서비스에 데이터베이스 인스턴스를 추가하는 것을 자동화하려는 경우 AWS SDK를 사용하여 데이터베이스 트랜잭션 수를 모니터링하고 RDS를 스핀 오프하는 프로그램을 작성합니다. 필요한 조건이 충족되는 경우입니다.

다음은 DB 스냅 샷의 복사본을 생성하는 API 코드의 예입니다. boto3라는 AWS sdk를 사용하는 파이썬 프로그램입니다. boto3의 클라이언트 라이브러리에는 표시된대로 필수 매개 변수를 사용하여 DB 스냅 샷 사본을 생성하기 위해 Python 프로그램에서 호출하는 copy_db_snapshot이라는 메서드가 있습니다.

import boto3

client = boto3.client('rds')

response = client.copy_db_snapshot(
    SourceDBSnapshotIdentifier='mydbsnapshot',
    TargetDBSnapshotIdentifier='mydbsnapshot-copy',
)

print(response)

위의 프로그램이 실행되면 복사 이벤트의 다양한 속성을 설명하는 응답을받습니다. 여기서 문자열이라는 용어는 사용자가 환경에 대해 정의한 다양한 매개 변수 이름을 나타냅니다. 예를 들어 VpcID는 복사 작업이 발생하는 VPC의 ID를 나타냅니다.

{
    'DBSnapshot': {
        'DBSnapshotIdentifier': 'string',
        'DBInstanceIdentifier': 'string',
        'SnapshotCreateTime': datetime(2015, 1, 1),
        'Engine': 'string',
        'AllocatedStorage': 123,
        'Status': 'string',
        'Port': 123,
        'AvailabilityZone': 'string',
        'VpcId': 'string',
        'InstanceCreateTime': datetime(2015, 1, 1),
        'MasterUsername': 'string',
        'EngineVersion': 'string',
        'LicenseModel': 'string',
        'SnapshotType': 'string',
        'Iops': 123,
        'OptionGroupName': 'string',
        'PercentProgress': 123,
        'SourceRegion': 'string',
        'SourceDBSnapshotIdentifier': 'string',
        'StorageType': 'string',
        'TdeCredentialArn': 'string',
        'Encrypted': True|False,
        'KmsKeyId': 'string',
        'DBSnapshotArn': 'string',
        'Timezone': 'string',
        'IAMDatabaseAuthenticationEnabled': True|False,
        'ProcessorFeatures': [
            {
                'Name': 'string',
                'Value': 'string'
            },
        ]
    }
}