OPEN HYPER STEP
← 목록으로 (Supabase)
SUPABASE · 27 / 34
supabase
CHAPTER 27 / 34
읽기 약 2
FUNCTION

실시간 채팅 구현


핵심 개념

Supabase Realtime으로 실시간 채팅을 구현합니다. 채널, 메시지 저장, 실시간 수신을 포함합니다.

코드 분석
SUPABASE📋 코드 (19줄)
'use client'
export function ChatRoom({ roomId }: { roomId: string }) {
  const supabase = createClient()
  const [messages, setMessages] = useState<Message[]>([])

  useEffect(() => {
    // 기존 메시지 로드
    supabase.from('messages').select('*, profiles(username)')
      .eq('room_id', roomId).then(({ data }) => setMessages(data || []))

    // 실시간 구독
    const ch = supabase.channel(`room:${roomId}`)
      .on('postgres_changes',
        { event: 'INSERT', table: 'messages', filter: `room_id=eq.${roomId}` },
        payload => setMessages(p => [...p, payload.new ])
      ).subscribe()
    return () => supabase.removeChannel(ch)
  }, [roomId])
}

AI 프롬프트
🤖 AI에게 잘 물어보는 법 — 모델·전략별 프롬프트
Claude

무료: Sonnet 4.6 / Pro $20/mo: Opus 4.6

이 Supabase '실시간 채팅' RLS 정책에서
보안 구멍·우회 가능한 케이스·과도한 권한을 찾고
안전한 정책 코드를 작성해줘.
ChatGPT

무료: GPT-5.5 / Plus $20/mo: GPT-5.5 Pro

'실시간 채팅'를 Next.js + Supabase로 구현한
실전 풀스택 코드(Auth/RLS/Realtime 포함)를 만들어줘.
Gemini

무료: 2.5 Flash / Pro $19.99/mo: 3.1 Pro

이 Supabase '실시간 채팅' 관련 테이블·RLS 정책 전체를 분석해서
보안 취약점·N+1 쿼리·인덱스 누락을
우선순위 리포트로 만들어줘.
Grok

무료: Grok 4.1 / SuperGrok $30/mo

Supabase '실시간 채팅' vs Firebase의
동일 기능 구현을 2026년 기준
비용·성능·DX로 솔직히 비교해줘.

⭐ 이것만 기억하세요
실시간 채팅 구현 이 3가지만 확실히 잡으세요
1.HTTP 요청으로 채팅을 구현하면 메시지 지연이 생기고, 상대방의 메시지를 받으려면 폴링해야 합니다
2.messages 테이블에 INSERT → Realtime 구독으로 자동 수신 → 화면에 즉시 렌더링하는 실시간 채팅 흐름입니다
3.다음 챕터에서 좋아요·북마크 시스템을 구현합니다


공유하기
진행도 27 / 34