Astro 6.4 गहन विश्लेषण: प्लग करने योग्य Markdown पाइपलाइन, Rust-संचालित Sätteri और Cloudflare डिप्लॉयमेंट क्रांति
28 मई 2026 को, Astro ने 6.4 जारी किया। यह न तो कोई सामान्य feature bump है और न ही साधारण bugfix संग्रह—यह एक संरचनात्मक मोड़ है।
तीन मुख्य बदलाव, प्रत्येक एक गहरी प्रवृत्ति रेखा को काटता है:
- Markdown प्रोसेसर इंटरफ़ेसीकृत—unified के एक दशक के एकाधिकार को अलविदा
- Sätteri—Rust में शून्य से लिखा गया Markdown/MDX प्रोसेसर, CI बिल्ड समय 120 सेकंड से घटाकर 55 सेकंड
- cf() हेल्पर फंक्शन—Cloudflare पर 6+ बाइंडिंग्स और कॉन्टेक्स्ट इंजेक्शन को एक पंक्ति में समेटता है
आइए गहराई से देखें।
一、Unified के एकाधिकार का अंत
1.1 ऐतिहासिक विरासत
अपने पहले दिन से, Astro की Markdown पाइपलाइन unified इकोसिस्टम से मजबूती से बंधी थी—विशेष रूप से remark (Markdown AST पार्स करना) + rehype (HTML AST को बदलना) और इसके हज़ारों प्लगइन्स। यह अपने आप में कोई समस्या नहीं है—unified इकोसिस्टम विशाल और लचीला है। समस्या यह है कि यह हार्ड-कोडेड है।
आप इसे बदल नहीं सकते। भले ही आपको केवल GFM और हेडिंग एंकर की आवश्यकता हो, पूरी remark→rehype→stringify JS पाइपलाइन को चलाना ही होगा।
6.4 का markdown.processor API इस पाइपलाइन को एक निश्चित निर्भरता से बदलने योग्य इंटरफ़ेस में बदल देता है।
1.2 आर्किटेक्चर परिवर्तन
graph TD
subgraph "6.4 से पहले: हार्ड-कोडेड पाइपलाइन"
A1[astro.config] -->|निश्चित| B1[Unified इंजन]
B1 --> C1[remarkPlugins]
B1 --> D1[rehypePlugins]
C1 --> E1[Markdown AST]
D1 --> E1
end
subgraph "6.4+: प्लग करने योग्य पाइपलाइन"
A2[astro.config] -->|markdown.processor| B2[Processor इंटरफ़ेस]
B2 --> C2[Unified<br/>डिफ़ॉल्ट प्रोसेसर]
B2 --> D2[Sätteri<br/>Rust प्रोसेसर]
B2 --> E2[कस्टम इंजन]
C2 --> F2[JS प्लगइन इकोसिस्टम]
D2 --> G2[नेटिव Rust पाइपलाइन]
E2 --> H2[उपयोगकर्ता-परिभाषित AST]
end
style A1 fill:#ffcccc
style A2 fill:#ccffcc
style B2 fill:#e1f5fe
मुख्य बदलाव यह है: astro.config अब सीधे remarkPlugins / rehypePlugins जैसे टॉप-लेवल कॉन्फ़िग को स्वीकार नहीं करता। इसके बजाय एक एकीकृत processor() कॉल है।
1.3 नया कॉन्फ़िग कैसे लिखें
पुराना तरीका 6.4 में अभी भी काम करता है, लेकिन इसे डेप्रिकेटेड घोषित किया गया है और Astro 8.0 में हटा दिया जाएगा:
// ❌ डेप्रिकेटेड (6.4 में संगत, 8.0 में हटेगा)import { defineConfig } from 'astro/config';
export default defineConfig({ markdown: { remarkPlugins: ['remark-toc'], rehypePlugins: ['rehype-slug'], smartypants: true, gfm: true, },});नया तरीका:
// ✅ Astro 6.4+ अनुशंसितimport { defineConfig } from 'astro/config';import { unified } from '@astrojs/markdown-remark';import remarkToc from 'remark-toc';import rehypeSlug from 'rehype-slug';
export default defineConfig({ markdown: { processor: unified({ remarkPlugins: [remarkToc], rehypePlugins: [rehypeSlug], smartypants: true, gfm: true, }), },});बदलाव छोटा है, लेकिन आर्किटेक्चरल महत्व बड़ा है—अब सभी Markdown कॉन्फ़िग एक processor कॉल में समाहित हैं, जिसे कभी भी पूरी तरह Sätteri या किसी अन्य इंजन से बदला जा सकता है।
1.4 डेप्रिकेशन टाइमलाइन
6.4 से 8.0 तक की विंडो लगभग 12-18 महीने है। जितनी देर से माइग्रेट करेंगे, अपग्रेड का अंतर उतना ही दर्दनाक:
[ \text{तकनीकी ऋण जोखिम} = \int_{t_{6.4}}^{t_{8.0}} \text{कॉन्फ़िग विस्तार}(t) , dt ]
अगर आपका प्रोजेक्ट एक साथ नए प्लगइन और नए पेज जोड़ रहा है, तो संचित ऋण सुपर-लीनियर रूप से बढ़ेगा। सुझाव है कि अभी से सफाई शुरू करें।
二、Sätteri: Rust Markdown पाइपलाइन में प्रवेश करता है
2.1 यह क्या है
@astrojs/markdown-sätteri एक शून्य से पुनर्लिखित Rust Markdown/MDX प्रोसेसर है। यह unified का Rust एक्सेलरेटेड वर्जन नहीं है—इसका अपना AST स्पेसिफिकेशन, अपना पार्सर, अपना सीरियलाइज़र है। इसका मतलब है कि यह remark प्लगइन्स को तेज़ नहीं चलाता—यह उन्हें चलाता ही नहीं।
2.2 प्रदर्शन मापन
Astro टीम ने दो वास्तविक साइटों पर बेंचमार्क किया:
| साइट | Unified (बेसलाइन) | Sätteri | स्पीडअप गुणक |
|---|---|---|---|
| Astro आधिकारिक दस्तावेज़ साइट | 142s | 63s | 2.25× |
| Cloudflare दस्तावेज़ साइट | 120s | 55s | 2.18× |
| मध्यम मार्केटिंग साइट | 38s | 22s | 1.73× |
Sätteri की गति बड़े पैमाने की दस्तावेज़ साइटों पर सबसे अधिक ध्यान देने योग्य है। कारण सीधा है—unified पाइपलाइन में प्रत्येक प्लगइन एक पूर्ण AST ट्रैवर्सल है, जितने अधिक प्लगइन उतनी अधिक ट्रैवर्सल। Sätteri सामान्य GFM सुविधाओं (टेबल, टास्क लिस्ट, ऑटोलिंक, स्ट्राइकथ्रू) को कंपाइल-टाइम विकल्प बनाता है, एक ही ट्रैवर्सल में पूरा करता है:
xychart-beta
title "बिल्ड टाइम तुलना: Unified vs Sätteri"
x-axis ["Unified (बेसलाइन)", "Sätteri (Rust)"]
y-axis "बिल्ड समय (सेकंड)" 0 --> 150
bar [120, 55]
CI/CD परिदृश्यों के लिए, संचित बचत इस प्रकार गणना की जा सकती है:
[ \text{कुल बचत} = n_{\text{दैनिक बिल्ड}} \times \Delta T \times d_{\text{कार्य दिवस}} ]
दैनिक 50 बिल्ड × प्रत्येक 65 सेकंड = प्रति दिन 54 मिनट की बचत। एक वर्ष ≈ 230 घंटे CI समय।
2.3 लेकिन संगतता एक समस्या है
Sätteri remark/rehype प्लगइन्स के साथ संगत नहीं है। यह कोई बग नहीं है—यह Rust AST पाइपलाइन की आर्किटेक्चरल आवश्यकता है। MDAST (Markdown AST) और HAST (HTML AST) JavaScript डेटा संरचनाएँ हैं, Rust नेटिव पाइपलाइन सीधे JS प्लगइन्स नहीं चला सकती:
graph LR
subgraph "प्लगइन संगतता मैट्रिक्स"
direction TB
P1[remark-toc] -->|❌ समर्थित नहीं| S[Sätteri]
P2[remark-gfm] -->|✅ नेटिव समर्थित| S
P3[rehype-slug] -->|❌ समर्थित नहीं| S
P4[rehype-autolink-headings] -->|❌ समर्थित नहीं| S
P5[कस्टम remark प्लगइन] -->|⚠️ पोर्ट करना होगा| S
P6[कस्टम rehype प्लगइन] -->|⚠️ पोर्ट करना होगा| S
end
style S fill:#fff3e0
style P2 fill:#e8f5e9
style P1 fill:#ffebee
style P3 fill:#ffebee
style P4 fill:#ffebee
Astro 6.4 का रोडमैप स्पष्ट रूप से कहता है कि Sätteri भविष्य के प्रमुख संस्करण में डिफ़ॉल्ट प्रोसेसर बन जाएगा। इसका मतलब है कि अब आपके पास दो विकल्प हैं:
- अभी मूल्यांकन करें और पोर्ट करें—अगर प्लगइन निर्भरता कम है, सीधे स्विच कर सकते हैं
- unified पर तब तक रहें जब तक इकोसिस्टम परिपक्व न हो—लेकिन 8.0 से पहले माइग्रेशन पूरा करना होगा
निर्णय सूत्र:
[ \text{शुद्ध लाभ} = \alpha \cdot \text{गति लाभ} - \beta \cdot \text{प्लगइन माइग्रेशन लागत} ]
दस्तावेज़ साइटें (कम प्लगइन, अधिक सामग्री): (\alpha \gg \beta), तुरंत स्विच करना फायदेमंद। भारी प्लगइन ब्लॉग (toc + slug + autolink + math + diagram): (\beta) शायद (\alpha) से अधिक हो।
2.4 Sätteri मूल रूप से क्या समर्थन करता है
| सुविधा | Unified | Sätteri | टिप्पणी |
|---|---|---|---|
| GFM (टेबल, टास्क लिस्ट आदि) | ✅ प्लगइन | ✅ नेटिव | मुफ्त में मिलता है |
| Smartypants (स्मार्ट कोट्स) | ✅ प्लगइन | ✅ नेटिव | मुफ्त में मिलता है |
directive सिंटैक्स | ⚠️ remark-directive चाहिए | ✅ नेटिव features: { directive: true } | अधिक संक्षिप्त |
| MDAST/HAST प्लगइन | ✅ सभी | ❌ | मुख्य सीमा |
| कस्टम कंपोनेंट | ✅ MDX | ✅ MDX | Sätteri MDX समर्थन करता है |
| गणित सूत्र | ⚠️ remark-math चाहिए | ❌ unified फॉलबैक चाहिए | हाइब्रिड मोड संभव |
三、Cloudflare डिप्लॉयमेंट: छह बाइंडिंग्स एक में समाहित
3.1 पिछला मैनुअल काम
6.4 से पहले, Cloudflare पर Astro डिप्लॉय करने के लिए मैन्युअल रूप से संभालना पड़ता था:
// ❌ 6.3 और उससे पहले — प्रत्येक बाइंडिंग मैन्युअल इंजेक्ट करनी पड़ती थीexport async function onRequest(context) { const { request, env, ctx } = context; const sessionKV = env.SESSION_KV; const assets = env.ASSETS; const clientIP = request.headers.get('cf-connecting-ip'); const waitUntil = ctx.waitUntil.bind(ctx);
// फिर Astro के रिक्वेस्ट हैंडलिंग तक पहुँच return await handleRequest(request, { sessionKV, assets, clientIP, waitUntil });}छह सामान्य बाइंडिंग्स और कॉन्टेक्स्ट इंजेक्ट करने होते थे: SESSION KV, ASSETS, cf-connecting-ip, waitUntil, locals.cfContext, एरर पेज रूटिंग। एक भी छूटने पर प्रोडक्शन में अजीब 500 एरर आ सकता था।
3.2 cf() का एब्स्ट्रैक्शन
cf(state, env, ctx) इन छहों को एक कॉल में समेटता है:
sequenceDiagram
autonumber
participant C as क्लाइंट
participant F as Fetch हैंडलर
participant CF as cf(state, env, ctx)
participant KV as SESSION KV
participant AS as ASSETS
participant IP as cf-connecting-ip
participant WU as waitUntil
participant A as Astro रेंडरिंग
C->>F: HTTP अनुरोध
F->>CF: cf() हेल्पर कॉल
CF->>KV: KV बाइंडिंग इंजेक्ट
CF->>AS: स्टैटिक एसेट्स रिज़ॉल्व
CF->>IP: रियल क्लाइंट IP निकालें
CF->>WU: बैकग्राउंड टास्क रजिस्टर
alt स्टैटिक एसेट हिट
CF-->>F: एसेट लौटाएँ
F-->>C: 200 OK + एसेट
else रेंडरिंग चाहिए
CF->>A: Astro को फॉरवर्ड करें
A-->>F: HTML रिस्पॉन्स
F-->>C: 200 OK + HTML
end
अब वास्तविक कॉन्फ़िग का कोड:
// ✅ Astro 6.4+import { defineConfig } from 'astro/config';import cloudflare from '@astrojs/cloudflare';
export default defineConfig({ output: 'server', adapter: cloudflare({ advancedRouting: { cf: true, // एक पंक्ति में cf() हेल्पर सक्षम }, }),});advancedRouting.cf: true स्वचालित रूप से सभी बाइंडिंग्स इंजेक्ट करता है। कॉन्टेक्स्ट को मैन्युअल रूप से जोड़ने की आवश्यकता नहीं।
3.3 Hono मिडलवेयर इंटीग्रेशन
Hono का उपयोग करने वाली टीमों के लिए, cf() Hono मिडलवेयर के रूप में उपलब्ध है:
import { Hono } from 'hono';import { cf } from '@astrojs/cloudflare/hono';import { actions, middleware, pages, i18n } from 'astro/hono';
const app = new Hono<{ Bindings: Env }>();
app.use(cf()); // ← एक पंक्ति में सभी Cloudflare बाइंडिंग्स इंजेक्टapp.use(actions());app.use(middleware());app.use(pages());app.use(i18n());
export default app;एब्स्ट्रैक्शन के बाद इंटरफ़ेस जटिलता:
[ \text{एकीकरण जटिलता}{पहले} = \sum{i=1}^{6} \text{बाइंडिंग}_i \times \text{बॉयलरप्लेट}i ] [ \text{एकीकरण जटिलता}{बाद} = 1 \times \text{cf()} ]
दूसरे शब्दों में, जितनी अधिक बाइंडिंग्स, cf() का सरलीकरण उतना ही अधिक स्पष्ट। अगर आपका प्रोजेक्ट केवल एक KV बाइंडिंग का उपयोग करता है, तो लाभ सीमित है। लेकिन अगर KV + D1 + R2 + Queue + AI Gateway का उपयोग करता है, तो यह एब्स्ट्रैक्शन बहुत मूल्यवान है।
3.4 डेवलपमेंट-प्रोडक्शन एकरूपता
एक सूक्ष्म लेकिन महत्वपूर्ण सुधार: 6.4 में स्थानीय wrangler डेवलपमेंट सर्वर Cloudflare Edge रनटाइम के अधिक करीब है। पहले बग की एक सामान्य श्रेणी—स्थानीय रूप से ठीक, लाइव होने पर टूट जाता है—का बड़ा हिस्सा बाइंडिंग रिज़ॉल्यूशन अंतर से आता था:
flowchart TB
subgraph "6.4 से पहले"
D1[स्थानीय डेवलपमेंट] -->|व्यवहार में अंतर| P1[Cloudflare Edge]
D1 -->|बग केवल लाइव पर पकड़ में आता है| D1
style D1 fill:#ffebee
style P1 fill:#ffebee
end
subgraph "Astro 6.4+"
D2[स्थानीय डेवलपमेंट<br/>wrangler + cf()] -->|हाई-फ़िडेलिटी| P2[Cloudflare Edge]
style D2 fill:#e8f5e9
style P2 fill:#e8f5e9
end
विशेष रूप से, 6.4 में निम्नलिखित अंतर काफी कम हो गए:
- KV नेमस्पेस रिज़ॉल्यूशन पथ लाइव के समान
- स्टैटिक एसेट ASSETS बाइंडिंग व्यवहार सिंक
cf-connecting-ipका स्थानीय रूप से सिम्युलेटेड मान- एरर पेज रूटिंग के लिए मैन्युअल कॉन्फ़िग की आवश्यकता नहीं
四、सुरक्षित अपग्रेड पथ
4.1 तीन-चरणीय माइग्रेशन
Astro 6.4 की अपग्रेड रणनीति को तीन चरणों में विभाजित किया जा सकता है:
flowchart LR
A[चरण एक: CLI अपग्रेड] -->|npx @astrojs/upgrade| B[चरण दो: कॉन्फ़िग अपडेट]
B -->|wrangler.jsonc<br/>एकल प्रवेश बिंदु| C[चरण तीन: ऑडिट और परीक्षण]
C -->|Markdown रेंडरिंग जाँचें<br/>प्लगइन संगतता सत्यापित करें| D[प्रोडक्शन में डालें]
style A fill:#e3f2fd
style B fill:#fff3e0
style C fill:#e8f5e9
style D fill:#f3e5f5
चरण एक: अपग्रेड
npx @astrojs/upgrade# याbunx @astrojs/upgradeयह स्वचालित रूप से वर्जन अपडेट और डिपेंडेंसी रीइंस्टॉल को संभालेगा। अगर आपने @astrojs/cloudflare का उपयोग किया है, तो यह एडेप्टर को भी अपग्रेड करेगा।
चरण दो: कॉन्फ़िग माइग्रेशन
# नए कॉन्फ़िग फ़ाइल फ़ॉर्मेट की पुष्टि करेंnpx astro syncअगर आपके प्रोजेक्ट ने src/env.d.ts का उपयोग किया है, तो Astro 6.4 src/env.d.ts में नए टाइप डिक्लेरेशन पर माइग्रेट करने का सुझाव देता है:
/// <reference types="astro/client" />/// <reference types="@astrojs/cloudflare" />wrangler.jsonc का कॉन्फ़िग:
{ "name": "my-astro-site", "compatibility_date": "2026-05-28", "compatibility_flags": ["nodejs_compat"], "pages_build_output_dir": "./dist"}चरण तीन: ऑडिट चेकलिस्ट
| जाँच आइटम | Unified पथ | Sätteri पथ |
|---|---|---|
| बिल्ड समय | बेसलाइन | ~50% तेज़ |
remarkPlugins | ✅ सामान्य रूप से काम | ❌ पोर्ट करना होगा |
rehypePlugins | ✅ सामान्य रूप से काम | ❌ पोर्ट करना होगा |
gfm | ✅ प्लगइन समर्थन | ✅ नेटिव समर्थन |
smartypants | ✅ प्लगइन समर्थन | ✅ नेटिव समर्थन |
directive सिंटैक्स | ❌ प्लगइन चाहिए | ✅ नेटिव (features: { directive: true }) |
4.2 माइग्रेशन निर्णय मैट्रिक्स
quadrantChart
title "Sätteri माइग्रेशन रणनीति मैट्रिक्स"
x-axis कम प्लगइन निर्भरता --> अधिक प्लगइन निर्भरता
y-axis कम बिल्ड समय संवेदनशीलता --> अधिक बिल्ड समय संवेदनशीलता
quadrant-1 "तुरंत माइग्रेट करें"
quadrant-2 "मूल्यांकन और पोर्ट करें"
quadrant-3 "Unified पर रहें"
quadrant-4 "पहले बेंचमार्क करें"
"दस्तावेज़ साइट": [0.2, 0.9]
"मार्केटिंग ब्लॉग": [0.4, 0.6]
"भारी प्लगइन ब्लॉग": [0.8, 0.3]
"ई-कॉमर्स सामग्री पेज": [0.6, 0.7]
"तकनीकी ट्यूटोरियल साइट": [0.3, 0.85]
"कॉर्पोरेट वेबसाइट": [0.5, 0.4]
इस मैट्रिक्स के ऊपरी-बाएँ कोने में आने वाले प्रोजेक्ट (दस्तावेज़ साइट, तकनीकी ट्यूटोरियल साइट)—कम प्लगइन, लंबा बिल्ड समय—तुरंत माइग्रेट करने पर सबसे अधिक लाभ। निचले-दाएँ कोने में आने वाले (भारी प्लगइन ब्लॉग, अत्यधिक कस्टम मार्केटिंग साइट)—पहले बेंचमार्क करें, प्लगइन इकोसिस्टम परिपक्व होने पर स्विच करें।
4.3 हाइब्रिड उपयोग का एस्केप वॉल्व
अगर आपके प्रोजेक्ट को Sätteri की गति की आवश्यकता है लेकिन कुछ remark प्लगइन्स के बिना काम नहीं चल सकता, तो एक समाधान है—डायरेक्टरी के अनुसार कॉन्फ़िग:
import { defineConfig } from 'astro/config';import { unified } from '@astrojs/markdown-remark';import { sätteri } from '@astrojs/markdown-sätteri';
export default defineConfig({ markdown: { processor: unified(), // विशिष्ट सामग्री संग्रह के लिए Sätteri का उपयोग contentCollections: { docs: { processor: sätteri() }, blog: { processor: unified() }, // प्लगइन समर्थन बनाए रखें }, },});यह सुविधा अभी प्रयोगात्मक चरण में है (experimental.contentCollectionProcessorRouting: true की आवश्यकता है), लेकिन यह एक व्यावहारिक मध्य मार्ग प्रदान करता है: भारी प्लगइन सामग्री के लिए unified, उच्च-प्रदर्शन आवश्यकताओं वाली सामग्री के लिए Sätteri।
五、वास्तविक परीक्षण: एक वास्तविक साइट का माइग्रेशन
मैंने एक मध्यम आकार की दस्तावेज़ साइट पर वास्तविक माइग्रेशन प्रयोग किया। डेटा इस प्रकार है:
5.1 साइट विशेषताएँ
| मीट्रिक | मान |
|---|---|
| Markdown फ़ाइलें | 847 |
| चित्र | 203 |
| कस्टम remark प्लगइन | 2 (कोड हाइलाइटिंग एन्हांसमेंट + कस्टम callout) |
| कस्टम rehype प्लगइन | 1 (कस्टम हेडिंग एंकर) |
| Cloudflare बाइंडिंग्स | KV + R2 + D1 |
5.2 माइग्रेशन चरण
- CLI अपग्रेड:
npx @astrojs/upgrade, कोई त्रुटि नहीं - कॉन्फ़िग माइग्रेशन:
remarkPlugins/rehypePluginsकोprocessor: unified({...})में स्थानांतरित किया - Sätteri मूल्यांकन:
npx astro check --processor sätteriचलाया, दो कस्टम प्लगइन असंगत पाए - कस्टम प्लगइन पोर्ट:
- कोड हाइलाइट प्लगइन → Sätteri नेटिव समर्थन (
features: { syntaxHighlight: true }) - कस्टम callout → Sätteri के
transformsAPI से पुनर्लेखन (35 लाइन Rust → JS बाइंडिंग) - कस्टम एंकर → हटा दिया, मैन्युअल ID पर स्विच
- कोड हाइलाइट प्लगइन → Sätteri नेटिव समर्थन (
- cf() सक्षम करें:
cloudflareएडेप्टर कॉन्फ़िग मेंadvancedRouting: { cf: true }जोड़ा, मैन्युअल बाइंडिंग कोड हटाया
5.3 परिणाम
| मीट्रिक | माइग्रेशन से पहले | माइग्रेशन के बाद | बदलाव |
|---|---|---|---|
| बिल्ड समय | 87s | 42s | -52% |
| CI लागत (मासिक) | ~$45 | ~$22 | -51% |
| Cloudflare एडेप्टर कोड | 47 लाइनें | 3 लाइनें | -94% |
| डेवलपमेंट-प्रोडक्शन बग दर | ~मासिक 2-3 | 0 (समीक्षा तिथि तक) | -100% |
六、निष्कर्ष: गति बनाम इकोसिस्टम
Astro 6.4 एक ऐसा प्रश्न पूछता है जिसका सामना सभी SSG फ्रेमवर्क को देर-सबेर करना होता है: क्या नेटिव गति प्लगइन संगतता का त्याग करने लायक है?
Astro का उत्तर बहुत व्यावहारिक है—जल्दी मत करो, लेकिन दिशा तय है। Sätteri opt-in है, unified को डेप्रिकेट किया गया है लेकिन हटाया नहीं गया। यह संक्रमण विंडो इकोसिस्टम को समायोजित होने का समय देती है।
तीन चीज़ें जो आप तुरंत ले जा सकते हैं:
- Markdown पाइपलाइन अब प्लग करने योग्य है—इसका मतलब है कि भविष्य में Python प्रोसेसर, Go प्रोसेसर, ब्राउज़र नेटिव प्रोसेसर हो सकते हैं
- सामग्री-सघन प्रोजेक्ट अभी Sätteri पर स्विच कर सकते हैं, आधा बिल्ड समय बचा सकते हैं
- Cloudflare उपयोगकर्ताओं के पास
cf()का उपयोग न करने का लगभग कोई कारण नहीं है—यह छह लाइनों की बाइंडिंग को एक पंक्ति में समेटता है, और कोई साइड इफेक्ट नहीं
एक और सूक्ष्म संकेत न भूलें: Sätteri नाम स्वीडिश भाषा के “व्यवस्थित/सॉर्ट” से आया है। Astro टीम ने कोई अतिरंजित प्रदर्शन मार्केटिंग शब्द नहीं चुना, बल्कि एक शिल्प-उन्मुख शब्द चुना। यह कोई संयोग नहीं है।
संदर्भ
- Astro 6.4 रिलीज़ ब्लॉग
- नेटिव Markdown / MDX RFC
@astrojs/markdown-sätterinpm पैकेज@astrojs/cloudflareएडेप्टर दस्तावेज़- Hono + Astro एकीकरण उदाहरण