أقسام قاعدة المعرفة ▾
للمبتدئين
للمستثمرين
- من أين تأتي قيمة رمز GNK
- Gonka مقابل المنافسين: Render، Akash، io.net
- الليبرمانز: من الفيزياء الحيوية إلى الذكاء الاصطناعي اللامركزي
- اقتصاديات توكن GNK
- مخاطر وآفاق Gonka: تحليل موضوعي
- Gonka ضد Render Network: مقارنة تفصيلية
- Gonka ضد Akash: استدلال الذكاء الاصطناعي مقابل الحاويات
- Gonka ضد io.net: استدلال مقابل سوق GPU
- Gonka مقابل Bittensor: مقارنة مفصلة بين نهجين للذكاء الاصطناعي
- Gonka مقابل Flux: نهجان للتعدين المفيد
- الحوكمة في Gonka: كيف تدار شبكة لامركزية
تقني
تحليل
- Gonka — لينكس لعصر الذكاء الاصطناعي
- مفتاح القتل: لماذا اللامركزية في الذكاء الاصطناعي ضرورية
- وقود، لا ذهب - من الذهب الرقمي إلى وقود الذكاء الاصطناعي
- إثبات العمل المفيد: دليل كامل للتعدين المفيد
- فجوة 112 مليار دولار - الإفلاس الخفي لشركات التكنولوجيا الكبرى
- مشاريع DePIN لعام 2026: مراجعة ومقارنة كاملة
أدوات
- Cursor + Gonka AI - LLM رخيص للبرمجة
- Claude Code + Gonka AI - LLM للطرفية
- OpenClaw + Gonka AI - وكلاء AI متاحون
- OpenCode + Gonka AI - AI مجاني للكود
- Continue.dev + Gonka AI - AI لـ VS Code/JetBrains
- Cline + Gonka AI - وكيل AI في VS Code
- Aider + Gonka AI - برمجة زوجية مع AI
- LangChain + Gonka AI - تطبيقات AI بتكلفة زهيدة
- n8n + Gonka AI - أتمتة مع AI رخيص
- Open WebUI + Gonka AI - ChatGPT الخاص بك
- LibreChat + Gonka AI — ChatGPT مفتوح المصدر
- وكيل هيرميس + جونكا AI - وكيل مستقل بسعر زهيد
- Kilo Code + Gonka AI - وكيل ذكاء اصطناعي في VS Code
- Roo Code + Gonka AI - وكيل ذكاء اصطناعي مستقل في VS Code
- LlamaIndex + Gonka AI - تطبيقات RAG بتكلفة زهيدة
- PydanticAI + Gonka - وكلاء AI محددون النوع بتكلفة زهيدة
- Vercel AI SDK + Gonka AI - تطبيقات AI على TypeScript بتكلفة زهيدة
- TanStack AI + Gonka - تطبيقات AI على TypeScript بتكلفة زهيدة
- بدء سريع لواجهة برمجة التطبيقات - curl، Python، TypeScript
- JoinGonka Gateway - مراجعة كاملة
- مفاتيح الإدارة — SaaS على Gonka
- أرخص واجهة برمجة تطبيقات AI: مقارنة المزودين 2026
- تم الوصول إلى حد طلبات Cursor Pro - تحليل حقيقي وبديل رخيص
- بديل أرخص لـ Claude Code - تحليل الفاتورة والتبديل
- Cline يحرق الدولارات - لماذا يستهلك الوكيل الكثير من المال
- OpenClaw باهظة الثمن - لماذا يحرق الوكيل الرموز المميزة وكيفية التوفير
- بديل OpenRouter الأرخص - مقارنة مقابل JoinGonka Gateway
أدوات
TanStack AI + Gonka - تطبيقات AI على TypeScript بتكلفة زهيدة
TanStack AI (@tanstack/ai) - SDK آمن للأنواع لـ TypeScript من فريق TanStack (مؤلفو Query, Router, Table). بنية agnostic للمزود: دردشة متدفقة، استدعاء أدوات أصلي، وكلاء، إخراج مهيكل، وتعدد الوسائط من خلال مجموعة موحدة من المحولات. ربط جاهز لـ React, Vue, Svelte, Solid و Preact (useChat وخطافات أخرى) بالإضافة إلى عميل بدون واجهة مستخدم للخادم.
المشكلة هي نفسها كما في أي إطار عمل AI - سعر الاستدلال. يدعم TanStack AI OpenAI و Anthropic و Gemini مباشرة، ولكن أسعار هؤلاء المزودين المباشرة (2.50-15 دولارًا لكل مليون رمز) تجعل دردشة الإنتاج والوكلاء مكلفة: تستهلك حوارات البث ودورات الأدوات ملايين الرموز بسرعة.
الميزة الرئيسية لـ TanStack AI هي دالة openaiCompatible(): طريقة من الدرجة الأولى لتوصيل أي نقطة نهاية متوافقة مع OpenAI. هذا يعني أن JoinGonka Gateway يتكامل بدون محولات مخصصة - تحدد baseURL، المفتاح، وقائمة النماذج. النتيجة: نفس الدردشة والوكلاء الآمنين للأنواع، ولكن مقابل 0.0005 دولار لكل مليون رمز عبر شبكة Gonka اللامركزية بدلاً من 2.50-15 دولارًا مع OpenAI.
الخطوة 1: تثبيت TanStack AI والحصول على المفتاح
تثبيت الحزم (الأساسي + محول OpenAI الذي يحتوي على openaiCompatible):
# pnpm
pnpm add @tanstack/ai @tanstack/ai-openai
# npm
npm install @tanstack/ai @tanstack/ai-openaiلواجهة الدردشة في React، أضف العميل والربط:
pnpm add @tanstack/ai-client @tanstack/ai-reactمفتاح API الخاص بـ JoinGonka: إذا لم يكن لديك بعد - سجل على gate.joingonka.ai/register، احصل على 10 ملايين رمز مجاني وأنشئ مفتاح jg-xxx في لوحة التحكم -> مفاتيح API. يعمل مفتاح واحد ورصيد واحد لكلا تنسيقَي OpenAI و Anthropic.
الخطوة 2: توصيل Gonka عبر openaiCompatible
في TanStack AI، يتم تكوين مزود OpenAI المتوافق المخصص بواسطة الدالة openaiCompatible(): تحدد baseURL، apiKey، وقائمة النماذج مرة واحدة، ثم تختار النموذج لكل استدعاء. بوابة Gateway الخاصة بنا تتحدث بتنسيق Chat Completions، لذلك نترك api: 'chat-completions' (هذه هي القيمة الافتراضية).
import { openaiCompatible } from '@tanstack/ai-openai'
// مزود Gonka - يتم تكوينه مرة واحدة
export const gonka = openaiCompatible({
name: 'gonka',
baseURL: 'https://gate.joingonka.ai/v1',
apiKey: process.env.GONKA_API_KEY!, // jg-مفتاحك
api: 'chat-completions',
models: [
'Qwen/Qwen3-235B-A22B-Instruct-2507-FP8', // الافتراضي
'moonshotai/Kimi-K2.6',
'MiniMaxAI/MiniMax-M2.7',
],
})دردشة متدفقة على الخادم (على سبيل المثال، مُعالج مسار في أي إطار عمل كامل المكدس أو TanStack Start). نحدد طول الاستجابة عبر modelOptions - هذه هي النقطة الوحيدة لمعلمات السلك الأصلي (max_tokens، temperature):
import { chat, toServerSentEventsResponse } from '@tanstack/ai'
import { gonka } from './gonka'
export async function POST(request: Request) {
const { messages } = await request.json()
const stream = chat({
adapter: gonka('Qwen/Qwen3-235B-A22B-Instruct-2507-FP8'),
messages,
modelOptions: { max_tokens: 8192 }, // حد Qwen عبر Gateway
})
return toServerSentEventsResponse(stream)
}عميل React عبر خطاف useChat - يبث الاستجابات من الخادم إلى واجهة المستخدم:
import { useChat } from '@tanstack/ai-react'
function Chat() {
const { messages, sendMessage, status } = useChat({ api: '/api/chat' })
return (
<div>
{messages.map((m) => (
<p key={m.id}><b>{m.role}:</b> {m.content}</p>
))}
<button onClick={() => sendMessage('ما هي Gonka؟')}>
اسأل
</button>
</div>
)
}بدون خادم: يعمل نفس المزود في برنامج نصي أو الواجهة الخلفية مباشرةً - استدعِ chat() واقرأ التدفق. الاتصال بـ Gonka هو نفسه لجميع الخيارات.
معلمات النماذج عبر بوابة Gateway: السياق لجميع النماذج الثلاثة - 128 ألف رمز. الحد الأقصى لـ max_tokens: Qwen3-235B - 8192، Kimi K2.6 - 3072، MiniMax-M2.7 - 4096. إذا لم يتم تحديد max_tokens، فإن الافتراضي لغير البث هو 1500، لذا حدده صراحةً للإجابات الطويلة.
مقارنة التكلفة
يعمل TanStack AI بشكل جيد مع أسعار OpenAI/Anthropic المباشرة وعبر Gonka - يتغير baseURL فقط. لكن السعر يختلف بأضعاف. دعنا نقارن أحمال تطبيق الإنتاج النموذجية على TanStack AI:
| السيناريو | الرموز | OpenAI / Anthropic | JoinGonka Gonka |
|---|---|---|---|
| استجابة دردشة بث واحدة | ~3K | $0.008 — $0.045 | $0.000004 |
| دورة وكيل مع استدعاء أداة | ~15K | $0.04 — $0.22 | $0.00002 |
| 1000 حوار في اليوم | ~3M | $7.50 — $45 | $0.003 |
| شهر من الإنتاج (~100M) | ~100M | $250 — $1,500 | $0.10 |
يعني نهج TanStack AI المستقل عن المزود أن التحول إلى Gonka هو تغيير سطر واحد (baseURL)، وليس إعادة كتابة للتعليمات البرمجية. تظل أدواتك الآمنة من النوع، والإخراج المنظم، وخطافات React دون تغيير. بالنسبة لتطبيق يضم آلاف المستخدمين، يبلغ الفرق عشرات الآلاف من الدولارات شهريًا.
سعر Gonka: المدخل ~$0.0005 لكل مليون رمز، المخرجات ×3. هذا أرخص بمئات إلى آلاف المرات من أسعار OpenAI وAnthropic المباشرة.
أدوات آمنة من النوع واختيار النموذج
الميزة الرئيسية لـ TanStack AI هي عقد toolDefinition() الموحد: يتم وصف الأداة مرة واحدة (المدخل/المخرج عبر Zod أو ArkType أو Valibot أو JSON Schema)، ويتم ربط التنفيذ بالخادم أو العميل. يدعم Qwen3-235B و Kimi K2.6 و MiniMax-M2.7 استدعاء الأدوات الأصلية عبر Gonka، لذا تعمل الوكلاء بشكل موثوق - دون تحليل استجابات النص.
import { chat, toolDefinition } from '@tanstack/ai'
import { gonka } from './gonka'
import { z } from 'zod'
const getWeather = toolDefinition({
name: 'getWeather',
description: 'معرفة الطقس في مدينة',
inputSchema: z.object({ city: z.string() }),
outputSchema: z.object({ tempC: z.number() }),
}).server(async ({ city }) => {
return { tempC: 21 } // استدعاء API الفعلي الخاص بك
})
const stream = chat({
adapter: gonka('Qwen/Qwen3-235B-A22B-Instruct-2507-FP8'),
messages: [{ role: 'user', content: 'ما هو الطقس في موسكو؟' }],
tools: [getWeather],
modelOptions: { max_tokens: 8192 },
})أي نموذج تختار:
- Qwen/Qwen3-235B-A22B-Instruct-2507-FP8 — الافتراضي. أكبر سقف للاستجابة (8192) واستدعاء أدوات قوي. مناسب للوكلاء والإخراج المنظم.
- moonshotai/Kimi-K2.6 — ممتاز للحوارات الطويلة والتفكير. سقف الاستجابة 3072.
- MiniMaxAI/MiniMax-M2.7 — توازن بين السرعة والجودة، سقف 4096.
بفضل تبديل المحول في وقت التشغيل في TanStack AI، يمكنك الاحتفاظ بجميع النماذج الثلاثة في مزود واحد والتبديل بينها على الفور - على سبيل المثال، مهام الوكيل الثقيلة على Qwen، والاستجابات السريعة على MiniMax.