Logo
hhlee
2024-10-29 14:33:12

비하인드
글로벌버전 웹사이트 개발 with GPT & Copilot

웹사이트를 개발하다보면 자국어만을 기준으로 할 수도 있지만, 특히나 글로벌로 판매가 가능한 SaaS 서비스라면 무언가 아쉬운 느낌이 듭니다. 그렇다고 거창하게 글로벌을 노리고 제작하기에는 생각보다 품이 많이 들어 부담스럽습니다. 저희팀은 아래와 같은 우리만의 방법으로 부담없이 모국어로 개발하면서도 글로벌 지원을 하고 있습니다.

에디터상에서 번역 완성

변수처리 방식의 단점

일반적인 i18n 라이브러리 등은 아래와 같은 방식으로 다국어를 처리합니다. 여러가지 방법이 있겠지만 기본적인 구조는 아래와 같습니다. 각 메시지의 키를 만들고, 해당 키에 상응하는 사용자의 언어별 표시를 하는 것입니다. 언뜻보면 가장 합리적인 방법처럼 보입니다.

const helloMessage = {
  ko: "안녕하세요",
  en: "Hello",
  ja: "こんにちは",
};
alert(helloMessage[userLang]);

이 방식은 가장 간단한 형태의 다국어버전 구동방식을 표현합니다. 비즈니스가 성장함에 따라 다양한 다국어를 유연하게 추가할 수 있다는 장점이 있습니다. 하지만 비즈니스가 적절하게 성장한 상태가 아닐 때에, 소수의 개발팀에서 작업할 때에는 아래와 같은 과도기적인 문제가 있습니다.

  • UI를 구현하며 수많은 에러 및 사용자 메시지를 작성함에 있어서, 언어 키를 네이밍하고 확보해야하는 문제가 생깁니다.
  • 각 언어별 번역하는 문제가 생깁니다(이는 외부 서비스 및 GPT로 어느정도 보완 가능)
  • 이미 기존에 활용한 키가 있는지 검토하고 없는 경우에 추가하도록 검색을 하게 됩니다.
  • 코드 수정을 유발하는 어떤 메시지가 유저로부터 발견되었을 때, 관련 언어키를 먼저 검색 후 오류위치를 찾게 됩니다.

사소한 잡일들이지만 사용자 메시지와 맞닿은 프론트쪽 개발을 하다보면, 이러한 과정으로 인해서 안그래도 부족한 개발 리소스가 낭비되게 됩니다.

코드에 녹이는 언어별 메시지

이러한 불편을 최소화하고자 비디오스튜팀은 자국어 단일 버전을 개발하는 속도로 다국어 버전을 개발하고 있습니다. 대신 다국어버전을 "영어" 하나로만 국한하고 있습니다. 추후에 시장이 넓어짐에 따라 이 방식은 유지될 수 없겠지만, 적어도 "영어" 사용가능한 유저층에게 어필하는 글로벌 초기단계에서는 아주 유용하게 사용하고 있습니다.

비디오스튜팀은 백엔드와 프론트에 directTrans라는 global 헬퍼를 등록하고 씁니다. 이 코드의 구현은 아주 심플합니다. 첫번째 파라미터로 모국어인 한글 메시지를 받고, 두번째 파라미터로는 글로벌인 영어 메시지를 받습니다.

function directTrans(ko = '', en = ''){
  return userLang === 'ko' || en ==='' ? ko : en;
}

아래와 같이 유저에게 노출되는 메시지가 나타나는 부분은 단순히 아래와 같이 만들면 됩니다.

...(중략)
if (block === undefined){
  return alert(
    directTrans(
      '블록이 존재하지 않습니다',
      'No block exists'
    )
  );
}

이렇게 보면 어차피 코드짜면서 영어 번역해야하는거 아니냐 할 수 있지만, 코파일럿과 함께 사용하면 절대 그렇지 않습니다. 코파일럿은 혹은 Cursor AI 도구를 사용하면, 내가 자주사용하는 헬퍼 혹은 열려있는 탭의 함수정의, 입력된 패턴을 참고하기 때문에 위와 같이 자주 쓰는 헬퍼의 용법은 아주 잘 이해합니다.

아래와 같이 dtrans('.. 하고 한글을 입력하면, 바로 두번째 파라미터가 번역된 영어 메시지가 들어가는 것을 유추하므로, 에디터상에서 코드를 짜면서 글로벌 버전을 바로 만들어낼 수 있습니다.

copilot.gif

< 모국어인 한글만 타이핑하면, 자동번역된 영어가 추가됨 >

이 방식으로 진행하면 위에서 언급한 정석적인 글로벌 버전의 개발 단점을 모두 극복할 수 있습니다.

  • 코드를 짜면서 유저메시지를 모국어로 적으므로 별도의 번역 시스템을 사용할 필요가 없게되어 코드를 짜는데 지체되는 시간이 없습니다.
  • 기존 키랑 무관하게 필요한 메시지를 바로바로 작성하면 됩니다(물론 중복메시지로 인한 코드가 길어지는 단점은 있지만, 생각보다 중복메시지는 별로 없습니다)
  • 노출된 사용자 메시지를 기반으로 코드 부분을 찾을 때 빠르게 찾을 수 있습니다(메시지 자체가 코드에 있으므로)

앞서 언급한대로 이 방식은 힘을 들이지 않고 글로벌 버전을 빠르게 구현하는데에 목적이 있습니다. 보다 정교한 번역 품질이나 여러 언어버전을 만들기에는 적합하지 않은 방식입니다. 서비스가 성장함에 따라 언어 시스템은 변경을 해야합니다.

블로그의 비동기 번역

코드에 들어가는 사용자 메시지 외에 서비스에는 수많은 메시지와 글이 동원됩니다. 랜딩페이지나 약관 등의 고정된 페이지는 1회성으로 번역을 해서 넣으면 그만이지만, 가이드나 블로그 같이 유동적으로 생성되고 수정되는 글에 대해서는 수작업으로 팔로우하기가 힘든 단점이 있습니다.

이에 비디오스튜에서는 가이드를 모국어인 한글로 등록하고, 일정한 시간후에 자동으로 수정된 부분을 추정하여 백엔드에서 GPT 모델을 이용하여 영어로 번역합니다. 번역에 관한 여러 API 서비스가 있을 수 있지만, LLM을 통한 번역시 아래와 같은 장점이 있습니다.

  • 문체를 우리가 원하는대로 자연스럽게 설정할 수 있습니다.
  • 시스템 메시지를 통해서 우리 서비스의 분야와 특성을 감안한 번역이 가능합니다.
  • 전문 용어/사이트에서만 쓰는 특수한 용어들에 대한 오번역을 막을 수 있습니다.

실제 적용함에 있어서 텍스트가 큰 가이드의 경우(거의 책 한권 분량)은 수정시마다 전체를 번역하는 것이 불가능합니다. 따라서 아래와 같이 문단별로 내용을 기반으로 해시키를 만들고, 변경되는 문단만 추적해서 자동 번역을 돌리고 있습니다.

< 변화되는 문단만을 수정하기 위한 해시값 >

이러한 호출 타입은 (저희는 사용하고 있지 않지만) GPT의 대량 호출 할인을 사용하면 더 저렴하게 대량 번역이 가능할 듯합니다.

아래는 한국어와 영어로 제공하고 있는 이 블로그글의 주소입니다. 영어로 된 버전은 저희의 서비스 특성을 감안해서 GPT가 자동으로 번역해서 만들어낸 결과입니다.

고객센터 대응

저희는 완벽한 일관된 고객 경험 및 실시간 사용자정보 연동을 위해, 자체적인 챗봇을 만들어서 사용합니다. 여기서 사용자의 정보가 모국어가 아닌 사용자의 경우에는, 자동으로 모국어를 첨부해서 원본과 보여줍니다. 우리가 모국어로 답변하면 이는 다시 사용자의 언어로 번역해서 전달됩니다.

cs.gif

< 모국어가 아닌 질문은 상호 자동번역 >

이를통해 번역으로 인한 지체를 줄이고 원활하게 글로벌 서비스를 제공하고 있습니다.

마무리

이미 많은 서비스들이 개발 및 운영에 GPT를 도입하고 있는 것으로 알고 있습니다. 비디오스튜팀과 같이 소규모 팀이면 GPT 등의 AI 도구를 이용하여 효율적으로 글로벌 서비스도 가능합니다.

게시물로 이동
🎓 소규모 커머스 기업들이 당장 시도해볼 수 있는 5가지 인스타그램 릴스 유형 인스타그램 릴스는 커머스 마케터들에게 이제 선택이 아닌 필수 마케팅 채널로 자리잡았습니다. 실제로 2023년 2분기 메타의 발표에 따르면 전 세계 인스타그램 릴스의 일일 시청 횟수는 2,000억 회에 달한다고 하죠.릴스는 짧고 중독성 있는 음악과 매력적인 영상으로 시청자의 눈과 귀를 사...
소규모 커머스 기업들이 당장 시도해볼 수 있는 5가지 인스타그램 릴스 유형
Junwoo 2025-03-26
🗞️ [Update] 더 똑똑해진 위자드 모드 (Text-to-Video) 최근 위자드 모드 사용 흐름 개선을 하면서 지속적으로 위자드 모드에 대한 개발 고도화를 진행 중에 있는데요.이제 템플릿을 고르고 영상 편집을 시작 할 때, 타이틀 슬라이드부터 인트로, 아웃트로 슬라이드까지 한번에 모든 내용이 완성되도록 개선되었습니다.여러분이 입력하거나 생성한 스크립트에...
[Update] 더 똑똑해진 위자드 모드 (Text-to-Video)
Junwoo 2025-03-21
🤔 비디오스튜로 광고 영상 만들기 (비하인드) 비디오스튜 글로벌 채널에 게시하기 위한 영어 버전 광고 영상을 직접 만든 후기를 공유하고자 합니다.튜토리얼이라고 하기 보다는 작업 과정에서의 팁들을 공유하기 위한 글인만큼 비하인드 섹션에 게시합니다.완성된 광고 동영상사용한 솔루션들메인 영상 편집: 비디오스튜화면 녹화: ScreenFlo...
비디오스튜로 광고 영상 만들기 (비하인드)
Junwoo 2025-03-12
🎓 AI 동영상 편집기 선택 시 고려해야 할 요소 (2025) 최근 영상 편집 업계에서는 AI 동영상 편집기가 큰 화제를 모으고 있습니다. 클릭 몇 번으로 자동으로 멋진 영상을 완성해준다는 자동 영상 편집 소프트웨어들도 쏟아져 나오고 있죠.&lt; 구글 트렌드의 'AI video editor 검색 추이 &gt;구글 트렌드에서 'AI 동영상 편집기’...
AI 동영상 편집기 선택 시 고려해야 할 요소 (2025)
Junwoo 2025-03-05
📣 텍스트의 한계를 뛰어넘다: 한국언론진흥재단의 영상 콘텐츠 혁신 도전기 한국언론진흥재단(이하 KPF)은 다양한 미디어 채널을 통해 국민의 정보복지 향상을 위한 다양한 사업을 펼치고 있는 기관입니다.KPF 사무실을 방문했다가 우연히 복도 벽면에 설치된 디스플레이에서 플레이되던 영상을 보고, 비디오스튜의 향기를 물씬 느끼게 되었는데요.&lt; KPF 사무실에서...
텍스트의 한계를 뛰어넘다: 한국언론진흥재단의 영상 콘텐츠 혁신 도전기
Junwoo 2025-02-26
🗞️ [Update] 위자드 모드 사용 흐름 개선 위자드 모드를 통해 새로운 프로젝트를 생성할 때, 레시피를 선택하는 과정에서 업데이트가 있어 안내드립니다.생성할 프로젝트의 화면 비율을 우선 선택프로젝트의 제목을 입력하고나면 생성할 동영상 프로젝트의 화면비율을 우선 선택하게 됩니다. 세로형, 가로형, 그리고 위자드 모드를 닫고 직접 편...
[Update] 위자드 모드 사용 흐름 개선
Junwoo 2025-02-20
🗞️ [Update] AI 이미지 생성 기능에 Flux 모델 도입 AI Photo 생성 기능에 고퀄리티의 실사 이미지 생성 모델 중 가장 높은 성능을 보이고 있는 Flux 모델이 적용되었습니다.스크립트를 기반으로 자동 생성편집화면 상에서 사용자가 입력한 내용에 가장 적합한 생성 프롬프트를 자동으로 생성하기 때문에, 별도로 프롬프트에 대한 지식이 없어도...
[Update] AI 이미지 생성 기능에 Flux 모델 도입
Junwoo 2025-02-11
🗞️ [Update] 더 스마트해진 이미지/영상 매칭 많은 분들이 요청해주셨던 '스톡 이미지/영상 매칭' 기능이 새롭게 개선되었습니다. 이제 영상 뿐만이 아니라 이미지 라이브러리까지 함께 검색을 하여 가장 어울리는 미디어를 추천할 수 있게 되었는데요.✨ 무엇이 달라졌나요?더 정확해진 이미지/영상 매칭위자드 모드를 통해 프로젝트 초안을 생성...
[Update] 더 스마트해진 이미지/영상 매칭
Junwoo 2025-02-07
[중단]