> 웹 프론트엔드 > JS 튜토리얼 > 에피소드 The Guardian of Codex – PWA 및 마이크로 프런트엔드 수용

에피소드 The Guardian of Codex – PWA 및 마이크로 프런트엔드 수용

Patricia Arquette
풀어 주다: 2024-11-17 16:33:01
원래의
684명이 탐색했습니다.

Episode  The Guardian of Codex – Embracing PWAs and Micro-Frontends

에피소드 12: Codex의 수호자 – PWA와 마이크로 프런트엔드 수용

Arin은 빛나는 데이터 필드의 빛이 광활한 우주 공간과 만나는 Codex의 광활한 개척지 가장자리에 서 있었습니다. 그녀의 발 아래에서는 서로 연결된 노드의 윙윙거리는 소리가 생명과 잠재력을 공명하며 울려 퍼졌습니다. 오늘은 달랐다. 행성방위군(PDC)의 또 ​​다른 하루가 아니었습니다. 임무는 적으로부터 방어하는 것 이상이었습니다. Codex의 회복력을 강화하고, 중단을 견딜 수 있도록 보장하는 동시에 이에 의존하는 사용자에게 원활한 경험을 제공하는 것이었습니다.

침묵을 가르는 라이프사이클 선장의 목소리, 차분하지만 단호함. “Cadet Arin, 기억하세요. 탄력성은 단지 힘에 관한 것이 아닙니다. 적응성에 관한 것입니다. 사용자는 Codex의 본질이며 그들의 경험은 어떤 희생을 치르더라도 보호되어야 합니다.”

아린은 깊은 숨을 쉬며 반짝이는 지평선을 눈으로 살펴보았습니다. 임무는 분명했습니다. 방어력을 강화하고 사용자 신뢰를 유지할 수 있는 도구와 기술로 Codex를 강화하는 것입니다.


1. 프로그레시브 웹 앱(PWA)의 힘

Arin은 PWA(프로그레시브 웹 앱)의 고대 청사진이 저장된 Codex 보관소에 접근했습니다. 그녀는 PWA가 단순한 앱이 아니라 Codex와 연결 끊김의 혼란 사이에 서 있는 수호자라는 것을 알고 있었습니다. 이러한 강력한 구조는 오프라인 기능을 활성화하여 데이터 경로가 불안정한 경우에도 사용자가 필수 리소스에 계속 액세스할 수 있도록 보장합니다.

PWA란 무엇인가요?
프로그레시브 웹 앱(PWA)은 서비스 워커와 매니페스트를 활용하여 기본 앱처럼 작동하는 웹 애플리케이션을 제공하여 오프라인 사용, 더 빠른 로드 시간 및 설치 가능성을 지원합니다.

코드 예: 서비스 워커 설정
Arin은 자산을 캐시하고 원활한 오프라인 지원을 제공하는 침묵의 수호자인 서비스 워커를 만들기 시작했습니다.

if ('serviceWorker' in navigator) {
  window.addEventListener('load', () => {
    navigator.serviceWorker.register('/service-worker.js')
      .then(registration => {
        console.log('Service Worker registered with scope:', registration.scope);
      })
      .catch(error => {
        console.error('Service Worker registration failed:', error);
      });
  });
}
로그인 후 복사
로그인 후 복사
로그인 후 복사

Arin이 Codex의 방어에 이를 삽입하면서 서비스 워커의 코드가 빛을 발하여 네트워크 연결이 없더라도 사용자가 공백에 직면하지 않도록 보장했습니다.

장점:

  • 오프라인 기능 네트워크 액세스가 중단된 경우에도 앱 가용성을 유지합니다.
  • 캐시된 리소스로 인해 로드 시간이 빨라졌습니다.
  • 네이티브와 같은 경험을 통해 사용자 참여가 향상됩니다.

단점:

  • 관리의 복잡성: 서비스 직원을 최신 상태로 유지하는 것이 어려울 수 있습니다.
  • 캐싱과 관련된 디버깅 문제는 해결하기 어려울 수 있습니다.

사용 시기:

  • 연결 상태가 좋지 않은 지역에서도 계속 작동해야 하는 앱을 구축하는 경우.
  • 사용자 참여가 최우선인 트래픽이 많은 앱의 경우

피해야 할 경우:

  • 오프라인 기능이 필요하지 않은 간단한 웹 앱의 경우
  • 서비스 작업자 관리의 복잡성이 이점보다 더 큰 경우.

2. 마이크로 프론트엔드의 모듈식 강점

아린의 눈은 코덱스의 광활하고 넓은 인터페이스를 훑어보았는데, 각 부문은 고유한 에너지 시그니처로 윙윙거렸습니다. 행성은 시간이 지남에 따라 복잡해졌고 추가될 때마다 유지 관리가 더 어려워졌습니다. 그녀는 Builders of Scalability의 다음과 같은 가르침을 회상했습니다. “분할하고 정복하세요. 각 부분은 독립적이면서도 조화롭게 기능할 수 있어야 합니다.”

마이크로 프론트엔드란 무엇인가요?
마이크로 프런트엔드는 마이크로서비스 아키텍처의 원리를 프런트엔드로 확장하여 팀이 모놀리식 앱을 하나의 응집력 있는 애플리케이션으로 작동하는 더 작고 독립적으로 배포 가능한 단위로 나눌 수 있도록 합니다.

이 접근 방식은 여러 팀이 앱의 서로 다른 부분을 작업하는 대규모 애플리케이션에 특히 유용합니다. 마이크로 프런트엔드를 통해 각 팀은 전체 앱에 영향을 주지 않고 자율성을 유지하고, 업데이트하고, 배포할 수 있습니다.

마이크로 프런트엔드의 주요 이점:

  • 팀 자율성과 병행 개발.
  • 독립 배포로 다운타임 없이 빠른 업데이트가 보장됩니다.
  • 앱 요구 사항에 따라 성장할 수 있는 확장 가능한 아키텍처

잠재적 과제:

  • 마이크로 프런트엔드 간의 통신 복잡성
  • 공유 상태를 관리하면 코드가 더 복잡해질 수 있습니다.
  • 의존성 중복 관리를 철저히 하지 않으면

테스트 사례: 포켓몬 앱:
아린은 포켓몬스터 앱, 포켓 배틀, 포켓몬스터 등의 다양한 부분을 별도의 마이크로 프론트엔드로 개발하는 상상을 했습니다. 이 분할은 Pokedex 업데이트가 Poke Battle에 영향을 미치지 않도록 하고 그 반대의 경우도 마찬가지입니다.

컨테이너 앱 설정:
컨테이너 앱은 마이크로 프런트엔드를 함께 바인딩하는 오케스트레이터 역할을 합니다. 다음은 마이크로 프론트엔드 통합을 위한 Webpack Module Federation 설정 예시입니다.

container-app/package.json:

if ('serviceWorker' in navigator) {
  window.addEventListener('load', () => {
    navigator.serviceWorker.register('/service-worker.js')
      .then(registration => {
        console.log('Service Worker registered with scope:', registration.scope);
      })
      .catch(error => {
        console.error('Service Worker registration failed:', error);
      });
  });
}
로그인 후 복사
로그인 후 복사
로그인 후 복사

container-app/webpack.config.js:

{
  "name": "container-app",
  "dependencies": {
    "react": "^17.0.2",
    "react-dom": "^17.0.2",
    "react-router-dom": "^5.2.0"
  },
  "scripts": {
    "start": "webpack serve --config webpack.config.js"
  }
}
로그인 후 복사
로그인 후 복사

container-app/src/index.js:

const HtmlWebpackPlugin = require('html-webpack-plugin');
const ModuleFederationPlugin = require('webpack/lib/container/ModuleFederationPlugin');

module.exports = {
  entry: './src/index.js',
  mode: 'development',
  devServer: {
    port: 8080,
  },
  output: {
    publicPath: 'http://localhost:8080/',
  },
  plugins: [
    new ModuleFederationPlugin({
      name: 'container',
      remotes: {
        pokebattle: 'pokebattle@http://localhost:8081/remoteEntry.js',
        pokedex: 'pokedex@http://localhost:8082/remoteEntry.js',
      },
      shared: ['react', 'react-dom']
    }),
    new HtmlWebpackPlugin({
      template: './public/index.html',
    }),
  ],
};
로그인 후 복사
로그인 후 복사

포케 배틀 마이크로 프런트엔드 만들기:
포크 배틀 마이크로 프론트엔드에는 자체 코드베이스와 Webpack 구성이 있습니다.

pokebattle/package.json:

if ('serviceWorker' in navigator) {
  window.addEventListener('load', () => {
    navigator.serviceWorker.register('/service-worker.js')
      .then(registration => {
        console.log('Service Worker registered with scope:', registration.scope);
      })
      .catch(error => {
        console.error('Service Worker registration failed:', error);
      });
  });
}
로그인 후 복사
로그인 후 복사
로그인 후 복사

pokebattle/webpack.config.js:

{
  "name": "container-app",
  "dependencies": {
    "react": "^17.0.2",
    "react-dom": "^17.0.2",
    "react-router-dom": "^5.2.0"
  },
  "scripts": {
    "start": "webpack serve --config webpack.config.js"
  }
}
로그인 후 복사
로그인 후 복사

pokebattle/src/App.js:

const HtmlWebpackPlugin = require('html-webpack-plugin');
const ModuleFederationPlugin = require('webpack/lib/container/ModuleFederationPlugin');

module.exports = {
  entry: './src/index.js',
  mode: 'development',
  devServer: {
    port: 8080,
  },
  output: {
    publicPath: 'http://localhost:8080/',
  },
  plugins: [
    new ModuleFederationPlugin({
      name: 'container',
      remotes: {
        pokebattle: 'pokebattle@http://localhost:8081/remoteEntry.js',
        pokedex: 'pokedex@http://localhost:8082/remoteEntry.js',
      },
      shared: ['react', 'react-dom']
    }),
    new HtmlWebpackPlugin({
      template: './public/index.html',
    }),
  ],
};
로그인 후 복사
로그인 후 복사

Pokedex 마이크로 프런트엔드 설정:
pokedex/package.json:

import React from 'react';
import ReactDOM from 'react-dom';
import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';

const PokeBattle = React.lazy(() => import('pokebattle/App'));
const Pokedex = React.lazy(() => import('pokedex/App'));

function App() {
  return (
    <Router>
      <React.Suspense fallback={<div>Loading...</div>}>
        <Switch>
          <Route path="/pokebattle" component={PokeBattle} />
          <Route path="/pokedex" component={Pokedex} />
        </Switch>
      </React.Suspense>
    </Router>
  );
}

ReactDOM.render(<App />, document.getElementById('root'));
로그인 후 복사

pokedex/webpack.config.js:

{
  "name": "pokebattle",
  "dependencies": {
    "react": "^17.0.2",
    "react-dom": "^17.0.2"
  },
  "scripts": {
    "start": "webpack serve --config webpack.config.js"
  }
}
로그인 후 복사

pokedex/src/App.js:

const HtmlWebpackPlugin = require('html-webpack-plugin');
const ModuleFederationPlugin = require('webpack/lib/container/ModuleFederationPlugin');

module.exports = {
  entry: './src/index.js',
  mode: 'development',
  devServer: {
    port: 8081,
  },
  output: {
    publicPath: 'http://localhost:8081/',
  },
  plugins: [
    new ModuleFederationPlugin({
      name: 'pokebattle',
      filename: 'remoteEntry.js',
      exposes: {
        './App': './src/App',
      },
      shared: ['react', 'react-dom']
    }),
    new HtmlWebpackPlugin({
      template: './public/index.html',
    }),
  ],
};
로그인 후 복사

아린의 폭로:
Arin은 뒤로 서서 Codex의 새로운 마이크로 프론트엔드 아키텍처가 생생하게 빛나는 것을 지켜보았습니다. 각 부분은 더 큰 전체의 독립적이면서도 조화로운 부분이었습니다. “코덱스는 이제 더 강해졌다”고 생각했습니다. “각 부분은 스스로 싸우고, 적응하고, 진화할 수 있습니다.”

장점:

  • 팀 자율성을 통해 여러 팀이 독립적으로 개발할 수 있습니다.
  • 독립 배포는 빠르고 격리된 업데이트를 의미합니다.
  • 모듈형 아키텍처는 확장 가능하고 유지 관리가 가능한 코드베이스를 지원합니다.

단점:

  • 마이크로 프런트엔드 간의 통신은 복잡할 수 있습니다.
  • 공유 종속성을 관리제대로 처리하지 않으면 중복이 발생할 수 있습니다.
  • 초기 설정은 기존 단일 페이지 앱보다 더 복잡합니다.

사용 시기:

  • 다양한 기능을 작업하는 별도의 팀이 필요한 대규모 애플리케이션.
  • 모듈성과 격리된 배포 주기가 유용한 경우.

피해야 할 경우:

  • 복잡성이 정당화되지 않는 소규모 애플리케이션.
  • 팀이 마이크로 프런트엔드 커뮤니케이션의 미묘한 차이를 처리할 준비가 되어 있지 않은 경우

3. 코드 분할 및 지연 로딩으로 UX 향상

아린은 캡틴 라이프사이클을 바라보며 고개를 끄덕였습니다. “사용자들은 Codex가 항상 응답하고 항상 준비되어 있다고 느껴야 합니다.”라고 그는 말했습니다. 코드 분할지연 로딩이 이를 보장하는 열쇠였습니다. 필요한 것만 로드함으로써 Codex는 민첩성을 유지하고 사용자가 경험에 몰입할 수 있도록 했습니다.

코드 분할 예:

import React from 'react';

function App() {
  return (
    <div>
      <h1>Poke Battle Arena</h1>
      <p>Choose your Pokémon and battle your friends!</p>
    </div>
  );
}

export default App;
로그인 후 복사

장점:

  • 초기 로딩 시간이 개선, 필수 코드만 로딩됩니다.
  • 로드 및 렌더링 시간 감소로 향상된 사용자 경험

단점:

  • 로딩 상태 관리가 필요해졌습니다.
  • 지연 로드된 구성요소 디버깅은 더 복잡할 수 있습니다.

사용 시기:

  • 처음에 로드할 필요가 없는 대규모 구성요소가 있는 앱의 경우
  • 성능을 최적화하고 더 빠른 상호 작용이 필수적인 경우.

피해야 할 경우:

  • 분할로 성능이 크게 향상되지 않는 간단한 앱의 경우.
  • 지연 로딩이 불필요한 오버헤드를 추가하는 최소한의 앱 복잡성을 처리하는 경우.

주요 시사점

Concept Definition Pros Cons When to Use When to Avoid
Progressive Web Apps (PWAs) Web apps with offline capabilities and native-like features. Offline access, improved performance, user engagement. Complex service worker management, debugging challenges. For apps needing offline capabilities and quick load. Apps that don’t benefit from offline or native features.
Micro-Frontends Independent, deployable micro-apps forming one application. Team autonomy, independent deployments, modular architecture. Communication complexity, potential dependency duplication. Large apps needing scalable, modular development. Simple apps where the complexity isn’t justified.
Code Splitting Splitting code into smaller chunks that load on demand. Reduces initial load time, improves UX. Requires managing loading states, can complicate debugging. Apps with large, seldom-used components. Lightweight apps with minimal performance concerns.
콘셉트
정의

장점 단점 사용 시기 피해야 할 때 프로그레시브 웹 앱(PWA) 오프라인 기능과 네이티브와 유사한 기능을 갖춘 웹 앱 오프라인 액세스, 향상된 성능, 사용자 참여. 복잡한 서비스 워커 관리, 디버깅 문제 오프라인 기능과 빠른 로드가 필요한 앱의 경우 오프라인 또는 기본 기능의 이점을 누리지 못하는 앱. 마이크로 프론트엔드 하나의 애플리케이션을 구성하는 독립적이고 배포 가능한 마이크로 앱입니다. 팀 자율성, 독립적 배포, 모듈식 아키텍처. 통신 복잡성, 잠재적인 종속성 중복. 확장 가능한 모듈식 개발이 필요한 대규모 앱 복잡성이 정당화되지 않는 단순한 앱. 코드 분할 요청 시 로드되는 더 작은 덩어리로 코드를 분할합니다. 초기 로딩 시간을 줄이고 UX를 개선합니다. 로드 상태 관리가 필요하며 디버깅이 복잡해질 수 있습니다. 대규모, 거의 사용되지 않는 구성요소가 포함된 앱. 성능 문제를 최소화한 경량 앱 아린은 뒤로 물러서 코덱스가 새로운 에너지로 반짝이는 모습을 지켜보았습니다. 더 이상 하나의 단일체가 아니라 일련의 강력하고 상호 연결된 노드로, 탄력적이고 적응력이 뛰어나며 다가올 과제에 대비할 수 있습니다. 강화할 때마다 그녀는 진정한 방어가 단지 무차별 대입에 관한 것이 아니라는 것을 깨달았습니다. 그것은 현명하고 전략적인 적응에 관한 것이었습니다. “사용자들은 언제나 안전할 것입니다.” 그녀는 Codex의 맥박이 그녀의 결심과 일치하는 것을 느끼며 속삭였습니다.

위 내용은 에피소드 The Guardian of Codex – PWA 및 마이크로 프런트엔드 수용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿