[React] ๐ฅ Firebase ๋ฅผ ํ์ฉํ ์น ํธ์คํ ์ถ๊ฐํ๊ธฐ (๋ฐฐํฌ) ๐
๊ฐ์ ๐ฃ
๋ก์ปฌ ์๋ฒ์์ ๊ฐ๋ฐํ ํ๋ก์ ํธ๋ฅผ,
ํธ์คํ
์ ํตํด ๋๋ฉ์ธ์ ์ป์ด ์ธ๋ถ์์์ ์ ๊ทผ์ ํ์ฉํ๋ ๊ฒ์ ๋ฐฐํฌ(Deploy
)๋ผ๊ณ ํ๋ค.
๋ํ์ ์ธ ํธ์คํ
์๋น์ค๋ก๋ Netlify
, Vercel
, AWS
, Github Pages
๋ฑ ์ด ์์ง๋ง,
์ด๋ฒ ํฌ์คํ
์์๋,
Google ์์ ์ ๊ณตํ๋ Firebase
๋ฅผ ํตํ ํธ์คํ
์ฒ๋ฆฌ๋ฅผ ์ ๋ฆฌํ๊ณ ์ ํ๋ค.
ํ๋ก์ ํธ ์์ฑ ๐
Firebase
์น ํธ์คํ
์์ฑ ๋ฐ ๋ฐฐํฌํ๊ธฐ ์์
์์๋ ํฌ๊ฒ ์๋์ ๊ฐ์ด ์งํ๋๋ค.
1๏ธโฃ Firebase
ํ๋ก์ ํธ ์์ฑ
2๏ธโฃ Firebase
ํธ์คํ
์ค์
3๏ธโฃ Firebase
์ด๊ธฐํ
4๏ธโฃ Firebase
๋ฐฐํฌ ๋ฐ ํ์ธ
๋จผ์ ํด๋น URL ์์ ์๋ก์ด Firebase
ํ๋ก์ ํธ๋ฅผ ์์ฑ ํด ์ค๋ค.
install ๐ฎ
์ฐ๋ฆฌ๋ ์น ์ฑ
์ ๋ฐฐํฌํ๋ ค๊ณ ํ๋,
์์ฑํ ํ๋ก์ ํธ์ ํ๋ก์ ํธ ๊ฐ์
ํ๋ฉด์์ ์น
๋ฒํผ์ ํด๋ฆญ ํด ์ค๋ค.
์ฑ ๋๋ค์์ ์ค์ ํด ์ค๋ค ํธ์คํ ์ฒดํฌ๋ฐ์ค๋ ์ฒดํฌ ํด ์ค๋ค.
npm
์ ์ฌ์ฉํ์ฌ ํ๋ก์ ํธ์์ firebase
๋ชจ๋์ ์ค์น ํด ์ค๋ค.
npm install firebase
yarn add firebase
firebase SDK
๋ ์ถํ ๋ชจ๋์ ์ด๊ธฐํ ํ ๋ ์ฌ์ฉ๋๋ฏ๋ก ํด๋ฆฝ๋ณด๋์ ์ ์ฅ ํด ๋์
๋ค์์ผ๋ก ์๋ ๋ช
๋ น์ด๋ฅผ ํตํด
Firebase
๋ก ์์ฑํ ํ๋ก์ ํธ ๊ด๋ฆฌ, ๋ฐฐํฌ, DB ๊ด๋ฆฌ ๋ฑ ์ ํ ๋ ์ฌ์ฉ๋๋ ๋ชจ๋์ ์ ์ญ์ผ๋ก ์ค์น ํด ์ค๋ค.
npm install -g firebase-tools
yarn global add firebase-tools
init ๐พ
ํ๋ก์ ํธ ํฐ๋ฏธ๋์ firebase login
์ ์คํํ์ฌ,
ํ๋ก์ ํธ์ ์์ฑํ ํ๋ก์ ํธ๋ฅผ ์ฐ๊ฒฐํ ์ค๋น๋ฅผ ํ๋ค.
ํด๋น ๋ช ๋ น์ด๋ฅผ ์คํํ๋ฉด, ์ ์ฐฝ์ผ๋ก google ๋ก๊ทธ์ธ ํ๋ฉด์ด ์คํ๋๋ค.
- ์ด๋ฏธ ๋ช ๋ น์ด๋ฅผ ์คํํ์ฌ ๋ก๊ทธ์ธ ๋ ์ํ
๋ง์ฝ Local ์ ์ฐ๊ฒฐ๋ ๊ตฌ๊ธ ๊ณ์ ์ ๋ณ๊ฒฝํ๊ณ ์ถ๋ค๋ฉด
firebase logout
๋ช ๋ น์ผ๋ก ์ฐ๊ฒฐ์ ๋์ด์ค์ผ ํ๋ค.
firebase init
ํด๋น ๋ช ๋ น์ด๋ฅผ ์คํํ๋ฉด ์๋์ ๊ฐ์ ํ๋ฉด์ ๋ณผ ์ ์๋ค.
Hosting: Configue files for Firebase Hosting โฆ
์์คํ์ด์ค ๋ฐ
๋ฅผ ๋๋ฌ ์ ํ ํ Enter
์์ ์์ฑํ ํ๋ก์ ํธ๋ฅผ ์ ํ ํด ์ค๋ค.
Select a default Firebase project for this directory:
Vite
๋ก ์์ฑํ ์ฑ์ผ ๊ฒฝ์ฐnpm run build
ํน์yarn run build
๋ช ๋ น์ ์คํ ์dist
ํด๋๊ฐ ์์ฑ๋๋ค.
(React ์ ๊ฒฝ์ฐbuild
ํด๋ ์์ฑ)
Are you ready to proceed? (Y/N)
๐ ์งํ์ฌ๋ถ Y
What do you want to use as your public directory?
๐ dist ๋ผ๊ณ ์ ์ด์ค๋ค
(npm run build ๋ก ๋์จ ํ์ผ์ ์ฌ์ฉํ๊ธฐ ๋๋ฌธ์)
Configure as a single-page app (rewrite all urls to /index.html)? (Y/N)
๐ SPA ์ผ๊ฒฝ์ฐ index.html ์ ๊ธฐ๋ณธ์ผ๋ก ๋ณด์ฌ์ฃผ๊ฒ ๋ค๋ ์ฌ๋ถ Y
(๋ฆฌ์กํธ์ด๊ธฐ ๋๋ฌธ์ SPA)
Set up automatic builds and deploys with GitHub? (Y/N)
๐ GitHub๋ก ์๋ ๋น๋ ๋ฐ ๋ฐฐํฌ ์ค์ N
File build/index.html already exists. Overwrite? (Y/N)
๐ ์ด๋ฏธ ์์ฑ๋ index.html์ ๋ฎ์ด์ฐ๋์ฌ๋ถ N
(๋ฎ์ด์ฐ๋ฉด ๋ฆฌ์กํธ๋ก build ๋ ํ์ผ์ด ์ด๊ธฐํ๋๊ธฐ ๋๋ฌธ์ N)
init
์ค์ ์ด ์๋ฃ๋๋ฉด Hosting ์ ํ๊ธฐ ์ํ ํ์ผ๊ณผ ํด๋๊ฐ ์์ฑ๋๋ค.
build
๋ช
๋ น์ด๋ฅผ ์คํํ์ง ์๊ณ firebase deploy
๋ช
๋ น์ด๋ง์ ์คํํ๋ฉด,
๋ฐฐํฌ๊ฐ ์งํ๋๋ฉฐ ์์ฑ๋ Hosting URL
์ฃผ์๋ก ์ ์ํ ์ ์๋ค.
์์ฑ๋ ํธ์คํ
์ฃผ์๋ก ์ ์ ์ ์๋์ ๊ฐ์ ํ๋ฉด์ด ์ถ๋ ฅ๋๋ค๋ฉด,
ํธ์คํ
(๋ฐฐํฌ) ์ ์ฑ๊ณต ํ ๊ฒ์ด๋ค.
์์ฑ๋ ์ฝ๋๋ฅผ ๋ฐ์์ํค๋ ค๋ฉด,
build
๋ช ๋ น์ด๋ฅผ ์คํํ๊ณ ๋ค์firebase deploy
๋ช ๋ น์ผ๋ก ์ ์ฉ์ํค๋ฉด ๋๋ค.
Error โ
๋ง์ฝ 404
์๋ฌ Page Not Fount
๊ฐ ๋ฌ๋ค๋ฉด,
firebase.json
ํ์ผ์ ์์ ํด ์ค๋ค.
{
"hosting": {
"public": "build",
"ignore": ["firebase.json", "**/.*", "**/node_modules/**"],
"rewrites": [
{
"source": "**",
"destination": "/index.html"
}
]
}
}
๋ฐฐํฌ ํ์ธ โ๏ธ
๋๋ฉ์ธ๊ณผ ํจ๊ป ์ฑ๊ณต์ ์ผ๋ก Deploy ๋ ์ํ๋ฅผ ํ์ธํ ์ ์๋ค.
Reference ๐
https://wavescats.github.io/react/2022/10/21/react18.html
https://firebase.google.com/docs/hosting?hl=ko
https://firebase.google.com/docs/hosting/quickstart?hl=ko
https://lxxyeon.tistory.com/38
https://velog.io/@hippohami/Firebase-%EC%9B%B9-%ED%98%B8%EC%8A%A4%ED%8C%85-%EC%84%A4%EC%A0%95-%EB%B0%B0%ED%8F%AC-%ED%95%98%EB%8A%94-%EB%B0%A9%EB%B2%95