이 페이지에서는 Pub/Sub를 사용하여 Chat 앱을 만드는 방법을 설명합니다. Chat 앱의 이러한 유형의 아키텍처는 Chat이 Chat 앱에 메시지를 전송하지 못하도록 차단할 수 있는 방화벽이 조직에 있거나 Chat 앱이 Google Workspace Events API를 사용하는 경우에 유용합니다. 그러나 이러한 채팅 앱은 비동기 메시지만 주고받을 수 있으므로 이 아키텍처에는 다음과 같은 제한사항이 있습니다.
- 메시지에서 대화상자를 사용할 수 없습니다. 대신 카드 메시지를 사용하세요.
- 동기식 응답으로 개별 카드를 업데이트할 수 없습니다. 대신
patch
메서드를 호출하여 전체 메시지를 업데이트합니다.
다음 다이어그램은 Pub/Sub으로 빌드된 채팅 앱의 아키텍처를 보여줍니다.
위의 다이어그램에서 Pub/Sub 채팅 앱과 상호작용하는 사용자는 다음과 같은 정보 흐름을 갖습니다.
사용자가 Chat에서 채팅 메시지 또는 Chat 스페이스를 통해 Chat 앱에 메시지를 보내거나, Chat 앱에 활성 구독이 있는 Chat 스페이스에서 이벤트가 발생합니다.
채팅에서 메시지를 Pub/Sub 주제에 전송합니다.
Chat 앱 로직이 포함된 클라우드 또는 온프레미스 시스템인 애플리케이션 서버는 방화벽을 통해 메시지를 수신하기 위해 Pub/Sub 주제를 구독합니다.
원하는 경우 Chat 앱에서 Chat API를 호출하여 메시지를 비동기식으로 게시하거나 다른 작업을 실행할 수 있습니다.
기본 요건
자바
- Google Chat에 액세스할 수 있는 비즈니스 또는 엔터프라이즈 Google Workspace 계정
- 결제가 사용 설정된 Google Cloud 프로젝트. 기존 프로젝트에 결제가 사용 설정되어 있는지 확인하려면 프로젝트의 결제 상태 확인을 참고하세요. 프로젝트를 만들고 결제를 설정하려면 Google Cloud 프로젝트 만들기를 참고하세요.
- Java 11 이상
- Maven 패키지 관리 도구
Python
- Google Chat에 액세스할 수 있는 비즈니스 또는 엔터프라이즈 Google Workspace 계정
- 결제가 사용 설정된 Google Cloud 프로젝트. 기존 프로젝트에 결제가 사용 설정되어 있는지 확인하려면 프로젝트의 결제 상태 확인을 참고하세요. 프로젝트를 만들고 결제를 설정하려면 Google Cloud 프로젝트 만들기를 참고하세요.
- Python 3.6 이상
- pip 패키지 관리 도구
Node.js
- Google Chat에 액세스할 수 있는 비즈니스 또는 엔터프라이즈 Google Workspace 계정
- 결제가 사용 설정된 Google Cloud 프로젝트. 기존 프로젝트에 결제가 사용 설정되어 있는지 확인하려면 프로젝트의 결제 상태 확인을 참고하세요. 프로젝트를 만들고 결제를 설정하려면 Google Cloud 프로젝트 만들기를 참고하세요.
- Node.js 14 이상
- npm 패키지 관리 도구
-
초기화된 Node.js 프로젝트 새 프로젝트를 초기화하려면 새 폴더를 만들고 이 폴더로 전환한 다음 명령줄 인터페이스에서 다음 명령어를 실행합니다.
npm init
환경 설정
Google API를 사용하려면 먼저 Google Cloud 프로젝트에서 사용 설정해야 합니다. 단일 Google Cloud 프로젝트에서 하나 이상의 API를 사용 설정할 수 있습니다.Google Cloud 콘솔에서 Google Chat API 및 Pub/Sub API를 사용 설정합니다.
Pub/Sub 설정
Chat API에서 메시지를 보낼 수 있는 Pub/Sub 주제를 만듭니다. Chat 앱당 하나의 주제를 사용하는 것이 좋습니다.
다음 서비스 계정에 Pub/Sub 게시자 역할을 할당하여 주제에 Chat 게시 권한을 부여합니다.
chat-api-push@system.gserviceaccount.com
Chat 앱이 Pub/Sub 및 Chat으로 승인할 수 있는 서비스 계정을 만들고 비공개 키 파일을 작업 디렉터리에 저장합니다.
주제에 대한 pull 구독을 만듭니다.
이전에 만든 서비스 계정의 구독에 Pub/Sub 구독자 역할을 할당합니다.
스크립트 작성
자바
CLI에서 서비스 계정 사용자 인증 정보를 제공합니다.
export GOOGLE_APPLICATION_CREDENTIALS=SERVICE_ACCOUNT_FILE_PATH
CLI에서 Google Cloud 프로젝트 ID를 제공합니다.
export PROJECT_ID=PROJECT_ID
CLI에서 이전에 만든 Pub/Sub 구독의 구독 ID를 제공합니다.
export SUBSCRIPTION_ID=SUBSCRIPTION_ID
작업 디렉터리에
pom.xml
라는 파일을 만듭니다.pom.xml
파일에 다음 코드를 붙여넣습니다.작업 디렉터리에서 디렉터리 구조
src/main/java
를 만듭니다.src/main/java
디렉터리에Main.java
이라는 파일을 만듭니다.Main.java
에 다음 코드를 붙여넣습니다.
Python
CLI에서 서비스 계정 사용자 인증 정보를 제공합니다.
export GOOGLE_APPLICATION_CREDENTIALS=SERVICE_ACCOUNT_FILE_PATH
CLI에서 Google Cloud 프로젝트 ID를 제공합니다.
export PROJECT_ID=PROJECT_ID
CLI에서 이전에 만든 Pub/Sub 구독의 구독 ID를 제공합니다.
export SUBSCRIPTION_ID=SUBSCRIPTION_ID
작업 디렉터리에
requirements.txt
라는 파일을 만듭니다.requirements.txt
파일에 다음 코드를 붙여넣습니다.작업 디렉터리에
app.py
라는 파일을 만듭니다.app.py
에 다음 코드를 붙여넣습니다.
Node.js
CLI에서 서비스 계정 사용자 인증 정보를 제공합니다.
export GOOGLE_APPLICATION_CREDENTIALS=SERVICE_ACCOUNT_FILE_PATH
CLI에서 Google Cloud 프로젝트 ID를 제공합니다.
export PROJECT_ID=PROJECT_ID
CLI에서 이전에 만든 Pub/Sub 구독의 구독 ID를 제공합니다.
export SUBSCRIPTION_ID=SUBSCRIPTION_ID
작업 디렉터리에
package.json
라는 파일을 만듭니다.package.json
파일에 다음 코드를 붙여넣습니다.작업 디렉터리에
index.js
라는 파일을 만듭니다.index.js
에 다음 코드를 붙여넣습니다.
Chat에 앱 게시
Google Cloud 콘솔에서 메뉴 > API 및 서비스 > 사용 설정된 API 및 서비스 > Google Chat API > 구성으로 이동합니다.
Pub/Sub용 Chat 앱을 구성합니다.
- 앱 이름에
Quickstart App
을 입력합니다. - 아바타 URL에
https://developers.google.com/chat/images/quickstart-app-avatar.png
를 입력합니다. - 설명에
Quickstart app
을 입력합니다. - 기능에서 1:1 메시지 수신 및 스페이스 및 그룹 대화 참여를 선택합니다.
- 연결 설정에서 Cloud Pub/Sub를 선택하고 이전에 만든 Pub/Sub 주제의 이름을 붙여넣습니다.
- 공개 상태에서 도메인의 특정 사용자 및 그룹에서 이 Google Chat 앱을 사용할 수 있도록 설정을 선택하고 이메일 주소를 입력합니다.
- 로그에서 Logging에 오류 로깅을 선택합니다.
- 앱 이름에
저장을 클릭합니다.
앱이 Chat에서 메시지를 수신하고 응답할 준비가 되었습니다.
스크립트 실행
CLI에서 작업 디렉터리로 전환하고 스크립트를 실행합니다.
자바
mvn compile exec:java -Dexec.mainClass=Main
Python
python -m venv env
source env/bin/activate
pip install -r requirements.txt -U
python app.py
Node.js
npm install
npm start
코드를 실행하면 애플리케이션이 Pub/Sub 주제에 게시된 메시지를 수신 대기하기 시작합니다.
Chat 앱 테스트
Chat 앱을 테스트하려면 Chat 앱으로 채팅 메시지 공간을 열고 메시지를 보냅니다.
신뢰할 수 있는 테스터로 추가할 때 제공한 Google Workspace 계정을 사용하여 Google Chat을 엽니다.
- 새 채팅을 클릭합니다.
- 사용자 1명 이상 추가 입력란에 Chat 앱의 이름을 입력합니다.
검색 결과에서 채팅 앱을 선택합니다. 채팅 메시지가 열립니다.
- 앱의 새 직접 메시지에
Hello
를 입력하고enter
를 누릅니다.
신뢰할 수 있는 테스터를 추가하고 대화형 기능 테스트에 관해 자세히 알아보려면 Google Chat 앱의 대화형 기능 테스트를 참고하세요.
문제 해결
Google Chat 앱 또는 카드가 오류를 반환하면 Chat 인터페이스에 '문제가 발생했습니다'라는 메시지가 표시됩니다. 또는 '요청을 처리할 수 없습니다.' Chat UI에 오류 메시지가 표시되지 않지만 Chat 앱 또는 카드에서 예기치 않은 결과가 발생하는 경우가 있습니다. 예를 들어 카드 메시지가 표시되지 않을 수 있습니다.
Chat UI에 오류 메시지가 표시되지 않을 수 있지만 Chat 앱의 오류 로깅이 사용 설정된 경우 오류를 해결하는 데 도움이 되는 설명 오류 메시지와 로그 데이터를 사용할 수 있습니다. 오류를 보고, 디버그하고, 수정하는 데 도움이 필요한 경우 Google Chat 오류 문제 해결하기를 참고하세요.
삭제
이 튜토리얼에서 사용한 리소스 비용이 Google Cloud 계정에 청구되지 않도록 하려면 Cloud 프로젝트를 삭제하는 것이 좋습니다.
- Google Cloud 콘솔에서 리소스 관리 페이지로 이동합니다. 메뉴 > IAM 및 관리자 > 리소스 관리를 클릭합니다.
- 프로젝트 목록에서 삭제할 프로젝트를 선택하고 삭제 를 클릭합니다.
- 대화상자에서 프로젝트 ID를 입력한 다음 종료를 클릭하여 프로젝트를 삭제합니다.
관련 주제
Chat 앱에 더 많은 기능을 추가하려면 다음을 참고하세요.