티스토리 뷰

반응형

 

웹 애플리케이션에서 실시간 데이터 통신은 점점 더 중요해지고 있습니다. 사용자들은 새로고침 없이 즉시 업데이트되는 정보를 기대하고 있죠. 이러한 요구를 충족시키기 위해 다양한 기술이 등장했는데, 그 중 하나가 바로 SSE(Server-Sent Events)입니다. 오늘은 SSE에 대해 자세히 알아보고, 이 기술이 어떻게 웹 개발의 판도를 바꾸고 있는지 살펴보겠습니다.

 

SSE란 무엇인가?

SSE는 서버에서 클라이언트로 실시간 이벤트를 푸시하는 웹 기술입니다. 전통적인 HTTP 요청/응답 모델과 달리, SSE는 서버가 클라이언트에게 지속적으로 데이터를 보낼 수 있는 단방향 채널을 제공합니다. 이는 실시간 업데이트, 알림, 라이브 피드 등을 구현하는 데 매우 유용합니다.

 

SSE vs WebSocket

SSE와 자주 비교되는 기술로 WebSocket이 있습니다. WebSocket은 양방향 통신을 지원하지만, SSE는 서버에서 클라이언트로의 단방향 통신만을 지원합니다. 그러나 SSE는 구현이 더 간단하고, 기존 HTTP 프로토콜을 사용하기 때문에 방화벽이나 프록시 서버와의 호환성이 더 좋습니다.

 

SSE의 장점

  1. 간단한 구현: SSE는 기존 HTTP 프로토콜을 사용하므로, 특별한 프로토콜이나 서버 설정이 필요하지 않습니다.
  2. 자동 재연결: 연결이 끊어졌을 때 브라우저가 자동으로 재연결을 시도합니다.
  3. 단순한 API: JavaScript에서 EventSource 객체를 통해 쉽게 구현할 수 있습니다.
  4. 효율적인 리소스 사용: 단방향 통신이므로 WebSocket보다 서버 리소스를 덜 사용합니다.

 

SSE 구현 예제

서버 사이드 (Node.js with Express)

const express = require('express');
const app = express();

app.get('/events', (req, res) => {
  res.writeHead(200, {
    'Content-Type': 'text/event-stream',
    'Cache-Control': 'no-cache',
    'Connection': 'keep-alive'
  });

  const sendEvent = (data) => {
    res.write(`data: ${JSON.stringify(data)}\n\n`);
  };

  // 예시: 5초마다 현재 시간을 클라이언트에 전송
  const intervalId = setInterval(() => {
    sendEvent({ time: new Date().toLocaleTimeString() });
  }, 5000);

  // 클라이언트 연결이 끊어졌을 때 정리
  req.on('close', () => {
    clearInterval(intervalId);
  });
});

app.listen(3000, () => console.log('SSE server running on port 3000'));

 

클라이언트 사이드 (JavaScript)

<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8">
    <title>SSE 예제</title>
</head>
<body>
    <h1>서버 시간</h1>
    <div id="serverTime"></div>

    <script>
        const eventSource = new EventSource('http://localhost:3000/events');
        const serverTimeDiv = document.getElementById('serverTime');

        eventSource.onmessage = (event) => {
            const data = JSON.parse(event.data);
            serverTimeDiv.textContent = `서버 시간: ${data.time}`;
        };

        eventSource.onerror = (error) => {
            console.error('SSE 에러:', error);
            eventSource.close();
        };
    </script>
</body>
</html>

 

이 예제에서 서버는 5초마다 현재 시간을 클라이언트에 전송합니다. 클라이언트는 이 데이터를 받아 화면에 표시합니다.

 

SSE 활용 사례

  1. 실시간 주식 시세: 주식 거래 플랫폼에서 실시간으로 변화하는 주가 정보를 제공할 수 있습니다.
  2. 소셜 미디어 피드: 새로운 포스트, 댓글, 좋아요 등의 업데이트를 실시간으로 표시할 수 있습니다.
  3. 실시간 알림: 이메일 도착, 메시지 수신 등의 알림을 즉시 사용자에게 전달할 수 있습니다.
  4. 라이브 스포츠 중계: 경기 점수, 주요 이벤트 등을 실시간으로 업데이트할 수 있습니다.

 

SSE 사용 시 주의사항

  1. 브라우저 지원: 대부분의 최신 브라우저에서 지원되지만, Internet Explorer에서는 지원되지 않습니다.
  2. 연결 제한: 브라우저당 동시 SSE 연결 수에 제한이 있을 수 있으므로, 필요한 경우에만 연결을 유지해야 합니다.
  3. 서버 부하: 많은 클라이언트가 동시에 연결될 경우 서버 부하가 증가할 수 있으므로, 적절한 서버 스케일링이 필요할 수 있습니다.

 

결론

SSE는 실시간 웹 애플리케이션 개발을 위한 강력하고 효율적인 도구입니다. 구현이 간단하면서도 실시간 데이터 전송을 가능하게 하여, 다양한 웹 서비스에서 활용될 수 있습니다. 단방향 통신이라는 제한이 있지만, 많은 실시간 시나리오에서 이는 오히려 장점이 될 수 있습니다.

웹 개발자라면 SSE를 통해 사용자 경험을 한 단계 높일 수 있는 기회를 놓치지 마세요. 실시간 기능이 필요한 프로젝트에서 SSE를 고려해보는 것은 어떨까요? 웹의 미래는 더욱 더 실시간화되고 있으며, SSE는 그 미래를 앞당기는 핵심 기술 중 하나입니다.

반응형
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함