toss/granite

기존 앱에 React Native를 통합하는 엔터프라이즈급 마이크로서비스 프레임워크

개발 재료맘대로 써도 됨 · Apache-2.0모바일TypeScript난이도
465+0이번 주0
51포크7이슈
데모·홈페이지 열기granite.run

중간맛 분석

TypeScript 기반의 엔터프라이즈 React Native 프레임워크입니다. ESBuild를 활용한 초단위 빌드, 200KB 수준의 마이크로서비스 번들 분할, Pulumi를 통한 AWS 인프라 자동화가 핵심입니다. 기존 네이티브 앱(brownfield)에 React Native 모듈을 통합하는 데 최적화되어 있으며, 모든 기능에 end-to-end 테스트가 포함되어 있어 즉시 프로덕션 환경에 투입 가능합니다.

이런 레포예요

이럴 때 쓰면 좋아요

  • 기존 네이티브 앱에 React Native 기능을 점진적으로 추가할 때
  • 여러 개의 독립적인 React Native 모듈을 동적으로 로드·배포하고 싶을 때
  • 번들 크기 제약이 있는 환경에서 빠른 빌드와 배포가 필요할 때

핵심 기능

기존 iOS·Android 앱과의 seamless 통합200KB 수준의 극경량 마이크로서비스 번들AWS CDN 배포 자동화(Pulumi 기반)

대안 대비 차별점

기존 풀스택 React Native 프레임워크와 달리 brownfield 통합에 특화되어 있으며, 번들 분할과 Pulumi 자동화로 프로덕션급 마이크로서비스 배포를 원클릭으로 지원합니다.

준비물

  • Node.js
  • AWS 계정
  • Pulumi CLI (인프라 배포 시)

바로 시작하기

  1. Granite CLI로 새 프로젝트 생성하기
npx create-granite-app@latest
  1. React Native 컴포넌트 작성 후 앱 빌드하기
npm run granite build
  1. AWS 인프라 설정을 위해 @granite-js/pulumi-aws를 사용하여 Pulumi 코드 작성하기
import * as pulumi from '@pulumi/pulumi';
import * as aws from '@pulumi/aws';
import { ReactNativeBundleCDN } from '@granite-js/pulumi-aws';

const config = new pulumi.Config();

new ReactNativeBundleCDN('myReactNativeBundleCDN', {
  bucketName: config.require('bucketName'),
  region: config.require('region'),
});
  1. 프로덕션에 배포하기
npm run granite-forge deploy --bucket your-s3-bucket-name

자세한 안내는 공식 가이드를 참고하세요.

별 추이 · 7일

465+0 / 7일

활용성 · 따라 만들기 좋은가

샘플 점수 34/100
  • 관대한 라이선스
  • 테스트 있음
  • 예제 디렉토리
  • 최근 활동
  • AGENTS.md
  • llms.txt
  • 템플릿

🟢 최근 활동 있음 · 2025년 생성

이 레포에 깃밥 배지 달기

[![깃밥](https://www.gitbap.com/badge/toss/granite.svg)](https://www.gitbap.com/r/toss/granite)

🔌 클로드에서 바로 써보기

깃밥을 클로드에 연결하면 이런 레포를 클로드·커서·Codex에서 바로 찾고 체험할 수 있어요.

방법 ① 커넥터 URL

클로드 설정 → 커넥터에 이 주소를 붙여넣기.

https://www.gitbap.com/api/mcp
방법 ② 플러그인 (체험까지)

플러그인을 설치하면 /gitbap-trending·/gitbap-try 슬래시 커맨드로 레포를 그 자리에서 체험. Claude Code에서 아래 두 줄을 차례로 실행하세요.

/plugin marketplace add jakeparkcolde/gitbap-cowork
/plugin install gitbap-cowork@gitbap
연결 방법 자세히 →

AI가 README 기반으로 요약했습니다 · 원문 보기