Files
2nd/10_Wiki/Topics/DevOps_and_Security/Blink.md
T
Antigravity Agent f8b21af4be Wiki cleanup: error-doc removal, dedup merge, link normalization
10_Wiki/Topics 대규모 정리:
- 오류 캡처/미완성 stub 문서 227개 제거
- 교차폴더 중복 43클러스터 병합 (63파일 → redirect)
- 링크명 정규화: 깨진 링크 수정·redirect 직결·개념 매핑 ~2,400건
- 카테고리 MOC 6개 신규 생성
- Graph 섹션 미해결 related-keyword 링크 10,058건 제거

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-20 23:52:15 +09:00

4.4 KiB

id, title, category, status, canonical_id, aliases, duplicate_of, source_trust_level, confidence_score, verification_status, tags, raw_sources, last_reinforced, github_commit, tech_stack
id title category status canonical_id aliases duplicate_of source_trust_level confidence_score verification_status tags raw_sources last_reinforced github_commit tech_stack
wiki-2026-0508-blink Blink 10_Wiki/Topics verified self
P-Reinforce-AUTO-7F733B
Chromium Blink
Blink Renderer
none A 0.9 applied
browser
web
rendering
chromium
2026-05-10 pending
language framework
cpp chromium

Blink

매 한 줄

"매 Chromium 의 rendering engine — 매 Web 의 de facto standard.". Blink 는 Google 이 2013 년 WebKit 에서 fork 한 layout/rendering engine 으로, Chrome/Edge/Brave/Opera 등 Chromium-based browser 의 90%+ market share 를 통해 매 modern web platform (CSS Grid, Houdini, View Transitions) 을 정의한다.

매 핵심

매 Pipeline

  1. Parse — HTML/CSS → DOM/CSSOM.
  2. Style — selector matching, computed style.
  3. Layout (LayoutNG) — box tree, fragment tree.
  4. Paint — display item list.
  5. Composite (CC) — layer tree → GPU draw quads.
  6. Raster + Display — Skia/SkiaGanesh → Viz → Display compositor.

매 vs WebKit / Gecko

  • Blink (Chromium): V8, Skia, multi-process.
  • WebKit (Safari): JavaScriptCore, CoreGraphics/Metal.
  • Gecko (Firefox): SpiderMonkey, WebRender (Rust).

매 응용

  1. Chrome/Edge browsers.
  2. Electron/Tauri (Tauri uses platform webview).
  3. CEF (Chromium Embedded Framework).
  4. Headless Chrome / Puppeteer / Playwright.

💻 패턴

Custom Element via Web Components

class MyButton extends HTMLElement {
  connectedCallback() {
    this.attachShadow({ mode: "open" }).innerHTML = `
      <button><slot></slot></button>
      <style>button { padding: 8px 16px; }</style>`;
  }
}
customElements.define("my-button", MyButton);

CSS Houdini Paint Worklet

// checkerboard.js
class Checkerboard {
  paint(ctx, geom, props) {
    const size = props.get("--check-size").value;
    for (let y = 0; y < geom.height; y += size)
      for (let x = 0; x < geom.width; x += size)
        if (((x/size) + (y/size)) % 2) ctx.fillRect(x, y, size, size);
  }
}
registerPaint("checkerboard", Checkerboard);
div { background: paint(checkerboard); --check-size: 20; }
async function navigate(url) {
  if (!document.startViewTransition) return location.assign(url);
  const t = document.startViewTransition(() => loadInto(url));
  await t.finished;
}

Performance: Containment

.card {
  contain: layout paint style;  /* isolate subtree work */
  content-visibility: auto;     /* skip offscreen rendering */
}

DevTools Trace (Programmatic)

// puppeteer
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.tracing.start({ path: "trace.json", categories: ["devtools.timeline"] });
await page.goto("https://example.com");
await page.tracing.stop();

CDP (Chrome DevTools Protocol)

const client = await page.target().createCDPSession();
await client.send("Performance.enable");
const { metrics } = await client.send("Performance.getMetrics");
console.log(metrics.find(m => m.name === "LayoutCount"));

매 결정 기준

상황 권장
Cross-browser web app Standards-only, test 3 engines
Desktop app (full Chromium) Electron/CEF
Lightweight desktop Tauri (system webview)
Automation/scrape Playwright (multi-engine)
Mobile WebView System WebView (avoid bundling)

기본값: standards + feature detection; Blink-specific API only with fallbacks.

🔗 Graph

🤖 LLM 활용

언제: explain pipeline stage, generate web platform boilerplate. 언제 X: Blink internals C++ patches — need source + CL review.

안티패턴

  • Vendor-prefixed only: -webkit- without standard fallback.
  • Layout thrashing: read-write-read forced sync layouts.
  • Heavy main thread: blocks composite — use Workers + OffscreenCanvas.
  • Assuming Chromium-only: breaks Safari/Firefox parity.

🧪 검증 / 중복

  • Verified (chromium.org docs, web.dev, Blink design docs).
  • 신뢰도 A.

🕓 Changelog

날짜 변경
2026-05-08 Phase 1
2026-05-10 Manual cleanup — pipeline, Houdini, View Transitions