PostgreSQL - Amazon Kendra

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

PostgreSQL

PostgreSQL는 오픈 소스 데이터베이스 관리 시스템입니다. PostgreSQL사용자인 경우 PostgreSQL 데이터 원본을 Amazon Kendra 인덱싱하는 데 사용할 수 있습니다. Amazon Kendra PostgreSQL데이터 소스 커넥터는 PostgreSQL 9.6을 지원합니다.

Amazon Kendra 콘솔과 API를 사용하여 PostgreSQL 데이터 소스에 연결할 Amazon Kendra 수 있습니다. TemplateConfiguration

Amazon Kendra PostgreSQL데이터 소스 커넥터 문제 해결은 을 참조하십시오데이터 소스 문제 해결.

지원되는 기능

  • 필드 매핑

  • 사용자 컨텍스트 필터링

  • 포함/제외 필터

  • 전체 및 증분 콘텐츠 동기화

  • Virtual Private Cloud(VPC)

필수 조건

PostgreSQL데이터 원본을 Amazon Kendra 인덱싱하는 데 사용하기 전에 먼저 PostgreSQL 및 AWS 계정에서 다음과 같이 변경하십시오.

PostgreSQL에서 다음 사항을 갖추었는지 확인하세요.

  • 데이터베이스 사용자 이름 및 암호를 기록했습니다.

    중요

    읽기 전용 데이터베이스 자격 증명을 Amazon Kendra 제공하는 것이 가장 좋습니다.

  • 데이터베이스 호스트 URL, 포트, 인스턴스를 복사했습니다.

  • PostgreSQL 및 동일한 인덱스에 사용할 다른 여러 데이터 소스에서 각 문서가 고유한지 확인했습니다. 인덱스에 사용하려는 각 데이터 소스에는 데이터 소스 전체에서 동일한 문서가 포함되어서는 안 됩니다. 문서 ID는 인덱스 전체에 적용되며 인덱스별로 고유해야 합니다.

에 다음이 있는지 확인하십시오. AWS 계정

  • Amazon Kendra 색인을 만들고 API를 사용하는 경우 색인 ID를 기록해 두었습니다.

  • 데이터 소스에 대한 IAM 역할을 만들고 API를 사용하는 경우 역할의 IAM ARN을 기록했습니다.

    참고

    인증 유형과 자격 증명을 변경하는 경우 올바른 AWS Secrets Manager 비밀 ID에 액세스하려면 IAM 역할을 업데이트해야 합니다.

  • PostgreSQL 보안 인증 정보를 AWS Secrets Manager 보안 암호에 저장했고 API를 사용하는 경우 보안 암호의 ARN을 기록했습니다.

    참고

    보안 인증 정보와 보안 암호를 정기적으로 새로 고치거나 교체하는 것이 좋습니다. 보안을 위해 필요한 액세스 수준만 제공하세요. 데이터 소스, 커넥터 버전 1.0 및 2.0(해당하는 경우) 간에 보안 인증 정보와 보안 암호를 재사용하지 않는 것이 좋습니다.

기존 IAM 역할이나 암호가 없는 경우 PostgreSQL 데이터 원본을 연결할 때 콘솔을 사용하여 새 IAM 역할과 Secrets Manager 암호를 만들 수 Amazon Kendra있습니다. API를 사용하는 경우 기존 IAM 역할 및 Secrets Manager 암호의 ARN과 인덱스 ID를 제공해야 합니다.

연결 지침

PostgreSQL데이터 소스에 Amazon Kendra 연결하려면 데이터에 액세스할 Amazon Kendra 수 있도록 PostgreSQL 자격 증명의 세부 정보를 제공해야 합니다. 아직 구성하지 않은 경우 PostgreSQL 을 Amazon Kendra 참조하십시오필수 조건.

Console

Amazon Kendra 연결하려면 PostgreSQL

  1. 에 AWS Management Console 로그인하고 Amazon Kendra 콘솔을 엽니다.

  2. 왼쪽 탐색 창에서 인덱스를 선택한 다음 인덱스 목록에서 사용할 인덱스를 선택합니다.

    참고

    인덱스 설정에서 사용자 액세스 제어 설정을 구성하거나 편집할 수 있습니다.

  3. 시작하기 페이지에서 데이터 소스 추가를 선택합니다.

  4. 데이터 원본 추가 페이지에서 커넥터를 선택한 다음 PostgreSQL커넥터 추가를 선택합니다. 버전 2 (해당하는 경우) 를 사용하는 경우 “V2.0" 태그가 있는 PostgreSQL커넥터를 선택하십시오.

  5. 데이터 소스 세부 정보 지정 페이지에서 다음 정보를 입력합니다.

    1. 이름 및 설명에서 데이터 소스 이름에 데이터 소스의 이름을 입력합니다. 하이픈은 포함할 수 있지만 공백은 포함할 수 없습니다.

    2. (선택 사항) 설명 - 데이터 소스에 대한 선택적 설명을 입력합니다.

    3. 기본 언어 - 문서를 필터링하여 색인에 사용할 언어를 선택합니다. 달리 지정하지 않는 한, 언어는 영어로 기본 설정됩니다. 문서 메타데이터에 지정된 언어가 선택한 언어보다 우선합니다.

    4. 태그의 새 태그 추가 - 리소스를 검색 및 필터링하거나 비용을 추적할 수 있는 선택적 태그를 포함합니다. AWS

    5. 다음을 선택합니다.

  6. 액세스 및 보안 정의 페이지에서 다음 정보를 입력합니다.

    1. 소스에서 다음 정보를 입력합니다.

    2. 호스트 - 데이터베이스 호스트 이름을 입력합니다.

    3. 포트 - 데이터베이스 포트를 입력합니다.

    4. 인스턴스 - 데이터베이스 인스턴스를 입력합니다.

    5. SSL 인증서 위치 활성화 - SSL 인증서 파일의 Amazon S3 경로를 입력하도록 선택합니다.

    6. 인증에서 - 다음 정보를 입력합니다.

      1. AWS Secrets Manager 비밀 - 기존 암호를 선택하거나 새 암호를 생성하여 PostgreSQL 인증 Secrets Manager 자격 증명을 저장합니다. 새 암호를 만들기로 선택하면 AWS Secrets Manager 보안 암호 창이 열립니다.

        1. AWS Secrets Manager 보안 암호 생성 창에 다음 정보를 입력합니다.

          1. 보안 암호 이름 - 보안 암호의 이름. 암호 이름에 접두사 AmazonKendra '- PostgreSQL -'가 자동으로 추가됩니다.

          2. 데이터베이스 사용자 이름암호의 경우 - 데이터베이스에서 복사한 보안 인증 값을 입력합니다.

        2. 저장을 선택합니다.

    7. Virtual Private Cloud(VPC) - VPC를 사용하기로 선택할 수 있습니다. 그렇다면 서브넷VPC 보안 그룹을 추가해야 합니다.

    8. IAM 역할 - 기존 역할을 선택하거나 새 IAM IAM 역할을 생성하여 리포지토리 자격 증명에 액세스하고 콘텐츠를 인덱싱합니다.

      참고

      IAM 색인에 사용되는 역할은 데이터 원본에 사용할 수 없습니다. 기존 역할을 인덱스나 FAQ에 사용하는지 확실하지 않은 경우 새 역할 생성을 선택하여 오류를 방지하세요.

    9. 다음을 선택합니다.

  7. 동기화 설정 구성 페이지에 다음 정보를 입력합니다.

    1. 동기화 범위에서 다음 옵션을 선택합니다.

      • SQL 쿼리 - SELECT 및 JOIN 연산과 같은 SQL 쿼리 문을 입력합니다. SQL 쿼리는 32KB 미만이어야 합니다. Amazon Kendra 는 쿼리와 일치하는 모든 데이터베이스 콘텐츠를 크롤링합니다.

      • 프라이머리 키 열 - 데이터베이스 테이블의 프라이머리 키를 입력합니다. 이는 데이터베이스 내의 테이블을 식별합니다.

      • 제목 열 - 데이터베이스 테이블에 있는 문서 제목 열의 이름을 입력합니다.

      • 본문 열 - 데이터베이스 테이블에 있는 문서 본문 열의 이름을 입력합니다.

    2. 추가 구성 - 선택 사항에서 모든 파일을 동기화하는 대신 다음 옵션 중 하나를 선택하여 특정 콘텐츠를 동기화합니다.

      • 변경 감지 열 - 콘텐츠 변경을 감지하는 Amazon Kendra 데 사용할 열 이름을 입력합니다. Amazon Kendra 이러한 열에 변경 사항이 있을 경우 콘텐츠를 다시 인덱싱합니다.

      • 사용자 ID 열 - 콘텐츠에 대한 액세스를 허용할 사용자 ID가 포함된 열의 이름을 입력합니다.

      • 그룹 열 - 콘텐츠에 대한 액세스를 허용할 그룹이 포함된 열의 이름을 입력합니다.

      • 소스 URL 열 - 인덱싱할 소스 URL이 포함된 열의 이름을 입력합니다.

      • 타임스탬프 열 —타임스탬프가 포함된 열의 이름을 입력합니다. Amazon Kendra 타임스탬프 정보를 사용하여 콘텐츠의 변경 사항을 감지하고 변경된 콘텐츠만 동기화합니다.

      • 시간대 열 - 콘텐츠를 크롤링할 시간대가 포함된 열의 이름을 입력합니다.

      • 타임스탬프 형식 - 콘텐츠 변경 사항을 감지하고 콘텐츠를 다시 동기화하는 데 사용할 타임스탬프 형식이 포함된 열의 이름을 입력합니다.

    3. 동기화 모드 - 데이터 소스 콘텐츠가 변경될 때 인덱스를 업데이트하는 방법을 선택합니다. 데이터 원본을 처음으로 동기화하는 경우 기본적으로 모든 콘텐츠가 크롤링되고 색인됩니다. Amazon Kendra 동기화 모드 옵션으로 전체 동기화를 선택하지 않더라도 초기 동기화에 실패한 경우 데이터의 전체 동기화를 실행해야 합니다.

      • 전체 동기화: 모든 콘텐츠를 새로 인덱싱하여 데이터 소스가 색인과 동기화될 때마다 기존 콘텐츠를 대체합니다.

      • 신규, 수정된 동기화: 데이터 소스가 색인과 동기화될 때마다 새 콘텐츠와 수정된 콘텐츠만 인덱싱합니다. Amazon Kendra 데이터 원본의 메커니즘을 사용하여 콘텐츠 변경 사항을 추적하고 마지막 동기화 이후 변경된 콘텐츠를 인덱싱할 수 있습니다.

      • 새 콘텐츠, 수정된 콘텐츠, 삭제된 동기화: 데이터 원본이 색인과 동기화될 때마다 새 콘텐츠, 수정된 콘텐츠, 삭제된 콘텐츠만 색인화합니다. Amazon Kendra 데이터 원본의 메커니즘을 사용하여 콘텐츠 변경 사항을 추적하고 마지막 동기화 이후 변경된 콘텐츠를 인덱싱할 수 있습니다.

    4. 동기화 실행 일정빈도 - Amazon Kendra 가 데이터 소스와 동기화할 빈도를 선택합니다.

    5. 다음을 선택합니다.

  8. 필드 매핑 설정 페이지에 다음 정보를 입력합니다.

    1. 생성된 기본 데이터 소스 필드 (문서 ID, 문서 제목, 소스 URL) 중에서 색인에 매핑하려는 Amazon Kendra 필드를 선택합니다.

    2. 필드 추가 - 사용자 지정 데이터 소스 필드를 추가하려면 매핑할 인덱스 필드 이름과 필드 데이터 유형을 만듭니다.

    3. 다음을 선택합니다.

  9. 검토 및 생성 페이지에서 입력한 정보가 정확한지 확인한 다음 데이터 소스 추가를 선택합니다. 이 페이지에서 정보를 편집하도록 선택할 수도 있습니다. 데이터 소스가 성공적으로 추가된 후 데이터 소스 페이지에 데이터 소스가 표시됩니다.

API

연결하려면 Amazon Kendra PostgreSQL

TemplateConfigurationAPI를 사용하여 다음을 지정해야 합니다.

  • 데이터 원본 - TemplateConfigurationJSON 스키마를 사용할 JDBC 때와 같이 데이터 원본 유형을 지정합니다. 또한 API를 TEMPLATE 호출할 때와 같이 데이터 소스를 지정하십시오. CreateDataSource

  • 데이터베이스 유형 - 데이터베이스 유형을 postgresql로 지정해야 합니다.

  • SQL 쿼리 - SELECT 및 JOIN 작업과 같은 SQL 쿼리 문을 지정합니다. SQL 쿼리는 32KB 미만이어야 합니다. Amazon Kendra 는 쿼리와 일치하는 모든 데이터베이스 콘텐츠를 크롤링합니다.

  • 동기화 모드 - 데이터 원본 콘텐츠가 변경될 때 색인을 업데이트하는 방법을 Amazon Kendra 지정합니다. 데이터 원본을 처음으로 동기화하는 경우 기본적으로 모든 콘텐츠가 크롤링되고 색인됩니다. Amazon Kendra 동기화 모드 옵션으로 전체 동기화를 선택하지 않더라도 초기 동기화에 실패한 경우 데이터의 전체 동기화를 실행해야 합니다. 다음 중에서 선택할 수 있습니다.

    • FORCED_FULL_CRAWL모든 콘텐츠를 새로 인덱싱하려면 데이터 원본이 색인과 동기화될 때마다 기존 콘텐츠를 교체해야 합니다.

    • FULL_CRAWL데이터 원본이 색인과 동기화될 때마다 새 콘텐츠, 수정된 콘텐츠, 삭제된 콘텐츠만 색인화하도록 합니다. Amazon Kendra 데이터 원본의 메커니즘을 사용하여 콘텐츠 변경 사항을 추적하고 마지막 동기화 이후 변경된 콘텐츠를 인덱싱할 수 있습니다.

    • CHANGE_LOG데이터 소스가 색인과 동기화될 때마다 새 콘텐츠와 수정된 콘텐츠만 인덱싱합니다. Amazon Kendra 데이터 원본의 메커니즘을 사용하여 콘텐츠 변경 사항을 추적하고 마지막 동기화 이후 변경된 콘텐츠를 인덱싱할 수 있습니다.

  • 비밀 Amazon 리소스 이름 (ARN) - 계정에서 생성한 인증 자격 증명이 포함된 Secrets Manager 암호의 Amazon 리소스 이름 (ARN) 을 제공합니다. PostgreSQL 보안 암호는 다음 키가 있는 JSON 구조로 저장됩니다.

    { "user name": "database user name", "password": "password" }
    참고

    보안 인증 정보와 보안 암호를 정기적으로 새로 고치거나 교체하는 것이 좋습니다. 보안을 위해 필요한 액세스 수준만 제공하세요. 데이터 소스, 커넥터 버전 1.0 및 2.0(해당하는 경우) 간에 보안 인증 정보와 보안 암호를 재사용하지 않는 것이 좋습니다.

  • IAM 역할 CreateDataSource Secrets Manager —비밀에 액세스할 수 있는 권한을 IAM 역할을 제공하고 커넥터 및 에 필요한 퍼블릭 API를 호출하기 위해 호출할 RoleArn 시기를 지정합니다. PostgreSQL Amazon Kendra자세한 내용은 PostgreSQL 데이터 소스에 대한IAM 역할을 참조하세요.

다음 선택적 기능도 추가할 수 있습니다.

  • Virtual Private Cloud(VPC) - CreateDataSource를 호출할 때 VpcConfiguration을 지정합니다. 자세한 정보는 Amazon Kendra 를 사용하도록 구성 Amazon VPC을 참조하세요.

  • 포함 및 제외 필터 - 사용자 ID, 그룹, 소스 URL, 타임스탬프, 시간대를 사용하여 특정 콘텐츠를 포함할지 여부를 지정할 수 있습니다.

  • 사용자 컨텍스트 필터링 및 액세스 제어 — 문서에 대한Amazon Kendra ACL이 있는 경우 문서에 대한 액세스 제어 목록 (ACL) 을 크롤링합니다. ACL 정보는 검색 결과를 문서에 대한 사용자 또는 그룹의 액세스 권한을 기준으로 필터링하는 데 사용됩니다. 자세한 내용은 사용자 컨텍스트 필터링을 참조하세요.

  • 필드 매핑 - PostgreSQL 데이터 소스 필드를 Amazon Kendra 인덱스 필드에 매핑하기로 선택합니다. 자세한 내용을 알아보려면 데이터 소스 필드 매핑을 참조하세요.

    참고

    문서를 Amazon Kendra 검색하려면 문서에 해당하는 문서 본문 필드 또는 문서 본문 필드가 필요합니다. 데이터 원본의 문서 본문 필드 이름을 색인 필드 이름에 매핑해야 _document_body 합니다. 다른 모든 필드는 선택 사항입니다.

구성해야 할 기타 중요한 JSON 키 목록은 PostgreSQL 템플릿 스키마를 참조하세요.

참고

  • 업데이트된 내용을 Amazon Kendra 확인할 때 삭제된 데이터베이스 행은 추적되지 않습니다.

  • 데이터베이스 행의 필드 이름 및 값 크기는 400KB를 초과할 수 없습니다.

  • 데이터베이스 데이터 원본에 많은 양의 데이터가 있고 첫 번째 동기화 후 모든 데이터베이스 콘텐츠를 인덱싱하고 싶지 Amazon Kendra 않은 경우 새 문서, 수정된 문서 또는 삭제된 문서만 동기화하도록 선택할 수 있습니다.

  • 읽기 전용 데이터베이스 자격 증명을 Amazon Kendra 제공하는 것이 가장 좋습니다.

  • 가장 좋은 방법은 민감한 데이터나 개인 식별 정보(PII)가 포함된 테이블을 추가하지 않는 것입니다.