Infograb logo
데이터베이스 접근 감사 이벤트 참조

감사 로그에서 데이터베이스 세션 활동을 볼 수 있습니다. 세션이 업로드된 후에는 tsh play 명령어를 사용하여 감사 데이터를 재생할 수 있습니다.

데이터베이스 세션 ID는 UUID 형식으로 제공됩니다 (예: 307b49d6-56c7-4d20-8cf0-5bc5348a7101). sid 키를 사용하여 감사 로그에서 데이터베이스 세션 ID를 확인하세요.

예시:

tsh play --format json database.session
    {
        "cluster_name": "teleport.example.com",
        "code": "TDB02I",
        "db_name": "example",
        "db_origin": "dynamic",
        "db_protocol": "postgres",
        "db_query": "select * from sample;",
        "db_roles": [
            "access"
        ],
        "db_service": "example",
        "db_type": "rds",
        "db_uri": "databases-1.us-east-1.rds.amazonaws.com:5432",
        "db_user": "alice",
        "ei": 2,
        "event": "db.session.query",
        "sid": "307b49d6-56c7-4d20-8cf0-5bc5348a7101",
        "success": true,
        "time": "2023-10-06T10:58:32.88Z",
        "uid": "a649d925-9dac-44cc-bd04-4387c295580f",
        "user": "alice"
    }

웹 UI에서 Management 아래의 Activity에서 event 리소스에 대한 권한이 있는 사용자는 감사 로그를 볼 수 있습니다. 데이터베이스 세션은 세션 녹화 페이지에 나타나지 않습니다.

db.session.start (TDB00I/W)

클라이언트가 데이터베이스에 성공적으로 연결되거나, 접근이 거부되어 연결 시도가 실패할 때 발생합니다.

성공적인 연결 이벤트:

{
  "cluster_name": "root", // Teleport 클러스터 이름.
  "code": "TDB00I", // 이벤트 코드.
  "db_name": "test", // 데이터베이스/스키마 이름.
  "db_protocol": "postgres", // 데이터베이스 프로토콜.
  "db_service": "local", // 데이터베이스 서비스 이름.
  "db_uri": "localhost:5432", // 데이터베이스 서버 끝점.
  "db_user": "postgres", // 데이터베이스 계정 이름.
  "ei": 0, // 세션 내의 이벤트 인덱스.
  "event": "db.session.start", // 이벤트 이름.
  "namespace": "default", // 이벤트 네임스페이스, 항상 "default".
  "server_id": "05ff66c9-a948-42f4-af0e-a1b6ba62561e", // 데이터베이스 서비스 호스트 ID.
  "sid": "63b6fa11-cd44-477b-911a-602b75ab13b5", // 고유한 데이터베이스 세션 ID.
  "success": true, // 성공적인 연결 여부.
  "time": "2021-04-27T23:00:26.014Z", // 이벤트 타임스탬프.
  "uid": "eac5b6c8-384a-4471-9559-e135834b1ab0", // 고유 이벤트 ID.
  "user": "alice" // Teleport 사용자 이름.
}

접근 거부 이벤트:

{
  "cluster_name": "root", // Teleport 클러스터 이름.
  "code": "TDB00W", // 이벤트 코드.
  "db_name": "test", // 사용자가 연결을 시도한 데이터베이스/스키마 이름.
  "db_protocol": "postgres", // 데이터베이스 프로토콜.
  "db_service": "local", // 데이터베이스 서비스 이름.
  "db_uri": "localhost:5432", // 데이터베이스 서버 끝점.
  "db_user": "superuser", // 사용자가 로그인하려고 시도한 데이터베이스 계정 이름.
  "ei": 0, // 세션 내의 이벤트 인덱스.
  "error": "접근이 거부되었습니다", // 연결 오류.
  "event": "db.session.start", // 이벤트 이름.
  "message": "접근이 거부되었습니다", // 세부 오류 메시지.
  "namespace": "default", // 이벤트 네임스페이스, 항상 "default".
  "server_id": "05ff66c9-a948-42f4-af0e-a1b6ba62561e", // 데이터베이스 서비스 호스트 ID.
  "sid": "d18388e5-cc7c-4624-b22b-d36db60d0c50", // 고유한 데이터베이스 세션 ID.
  "success": false, // 실패한 연결 여부.
  "time": "2021-04-27T23:03:05.226Z", // 이벤트 타임스탬프.
  "uid": "507fe008-99a4-4247-8603-6ba03408d047", // 고유 이벤트 ID.
  "user": "alice" // Teleport 사용자 이름.
}

db.session.end (TDB01I)

클라이언트가 데이터베이스에서 연결을 끊을 때 발생합니다.

{
  "cluster_name": "root", // Teleport 클러스터 이름.
  "code": "TDB01I", // 이벤트 코드.
  "db_name": "test", // 데이터베이스/스키마 이름.
  "db_protocol": "postgres", // 데이터베이스 프로토콜.
  "db_service": "local", // 데이터베이스 서비스 이름.
  "db_uri": "localhost:5432", // 데이터베이스 서버 끝점.
  "db_user": "postgres", // 데이터베이스 계정 이름.
  "ei": 3, // 세션 내의 이벤트 인덱스.
  "event": "db.session.end", // 이벤트 이름.
  "sid": "63b6fa11-cd44-477b-911a-602b75ab13b5", // 고유한 데이터베이스 세션 ID.
  "time": "2021-04-27T23:00:30.046Z", // 이벤트 타임스탬프.
  "uid": "a626b22d-bbd0-40ef-9896-b7ff365664b0", // 고유 이벤트 ID.
  "user": "alice" // Teleport 사용자 이름.
}

db.session.query (TDB02I)

클라이언트가 SQL 쿼리를 실행할 때 발생합니다.

{
  "cluster_name": "root", // Teleport 클러스터 이름.
  "code": "TDB02I", // 이벤트 코드.
  "db_name": "test", // 데이터베이스/스키마 이름.
  "db_protocol": "postgres", // 데이터베이스 프로토콜.
  "db_query": "INSERT INTO public.test (id,\"timestamp\",json)\n\tVALUES ($1,$2,$3)", // 쿼리 텍스트.
  "db_query_parameters": [ // 준비된 문에 대한 쿼리 매개변수.
    "test-id",
    "2022-04-02 17:50:20-07",
    "{\"k\": \"v\"}"
  ],
  "db_service": "local", // 데이터베이스 서비스 이름.
  "db_uri": "localhost:5432", // 데이터베이스 서버 끝점.
  "db_user": "postgres", // 데이터베이스 계정 이름.
  "ei": 29, // 세션 내의 이벤트 인덱스.
  "event": "db.session.query", // 이벤트 이름.
  "sid": "691e6f70-3c31-4412-90aa-fe0558abb212", // 고유한 데이터베이스 세션 ID.
  "time": "2021-04-27T23:04:57.395Z", // 이벤트 타임스탬프.
  "uid": "9f7b4179-b9cf-4302-bb7c-1408e404823f", // 고유 이벤트 ID.
  "user": "alice" // Teleport 사용자 이름.
}

db.session.spanner.rpc (TSPN001I/W)

클라이언트가 원격 프로시저 호출(RPC)을 실행할 때 또는 RPC 실행 시도가 접근 거부로 실패할 때 발생합니다.

{
  "args": { // "프로시저"에 따라 특정한 RPC 인수.
    "query_options": {},
    "request_options": {},
    "seqno": 1,
    "session": "projects/project-id/instances/instance-id/databases/dev-db/sessions/ABCDEF1234567890",
    "sql": "select * from TestTable",
    "transaction": {
      "Selector": {
        "SingleUse": {
          "Mode": {
            "ReadOnly": {
              "TimestampBound": {
                "Strong": true
              },
              "return_read_timestamp": true
            }
          }
        }
      }
    }
  },
  "cluster_name": "root", // Teleport 클러스터 이름.
  "code": "TSPN001I", // 이벤트 코드.
  "db_name": "dev-db", // 데이터베이스 이름.
  "db_origin": "dynamic", // Teleport 데이터베이스 서비스 구성 출처.
  "db_protocol": "spanner", // 데이터베이스 프로토콜.
  "db_service": "teleport-spanner", // 데이터베이스 서비스 이름.
  "db_type": "spanner", // 데이터베이스 유형.
  "db_uri": "spanner.googleapis.com:443", // 데이터베이스 서비스 끝점.
  "db_user": "some-user", // 데이터베이스 계정 이름, (GCP IAM 서비스 계정 이름의 @<project>.iam.gserviceaccount.com 접미사 제외).
  "ei": 29, // 세션 내의 이벤트 인덱스.
  "event": "db.session.spanner.rpc", // 이벤트 이름.
  "procedure": "ExecuteStreamingSql", // 원격 프로시저 호출(RPC)의 이름.
  "sid": "406b9883-0e16-42f2-9d0b-b3bd956f9cd4", // 고유한 데이터베이스 세션 ID.
  "success": true, // RPC가 Teleport RBAC에 의해 허용됨.
  "time": "2024-03-13T00:02:44.739Z", // 이벤트 타임스탬프.
  "uid": "e0625e79-9399-4ea3-aa8b-dba1eb98658d", // 고유 이벤트 ID.
  "user": "alice@example.com" // Teleport 사용자 이름.
}
Teleport 원문 보기