Back to Blog

AI FinOps वेक-अप कॉल: Uber ने चार महीने में ही अपना AI बजट खत्म किया

June 4, 2026by Ichiban Team
aifinopsengineeringubertech-news

Hero

पिछले कुछ सालों से, software engineering में generative AI के इर्द-गिर्द की बातचीत मुख्य रूप से productivity बढ़ाने, developer velocity, और features को तेजी से ship करने पर केंद्रित रही है। लेकिन इस हफ्ते, एक नई कहानी सामने आई है—और यह पूरी तरह से balance sheet (खर्च और बजट) पर केंद्रित है।

हालिया रिपोर्ट्स के अनुसार, Uber को अपने कर्मचारियों के AI खर्च पर सख्त पाबंदियां (caps) लगानी पड़ी हैं क्योंकि कंपनी ने सिर्फ चार महीनों में ही अपना पूरा सालाना AI बजट खत्म कर दिया है। यह चौंकाने वाली घटना दुनिया भर की engineering organizations के लिए एक बहुत बड़ा वेक-अप कॉल है: generative AI को बड़े पैमाने (scale) पर लागू करने से ऐसे variable costs जुड़ जाते हैं जो अगर unmonitored छोड़ दिए जाएं, तो बहुत जल्दी आउट ऑफ कंट्रोल हो सकते हैं।

#क्या हुआ

कई forward-thinking टेक दिग्गजों की तरह, Uber ने भी अपने daily workflows में AI को integrate करने के लिए आक्रामक रूप से (aggressively) काम किया। इस initiative में शायद developer copilots के लिए enterprise licenses, कंपनी-वाइड प्रीमियम चैट इंटरफेस का एक्सेस, और सबसे महत्वपूर्ण—कस्टम internal tooling बनाने के लिए इंटरनल टीमों को बांटी गई API keys शामिल थीं।

लक्ष्य यह था कि काम में आने वाली रुकावटों (friction) को खत्म किया जाए और कर्मचारियों को रोजमर्रा की समस्याओं को सुलझाने के लिए large language models (LLMs) का लाभ उठाने के लिए empower किया जाए। हालाँकि, इस rollout का frictionless नेचर ही इसकी सबसे बड़ी कमजोरी साबित हुआ। बिना सख्त guardrails या token consumption की granular visibility के, इंटरनल यूसेज आसमान छूने लगा। CI/CD pipelines में LLM endpoints को हिट करने वाली automated scripts, डेटा प्रोसेसिंग के लिए autonomous agents स्पिन अप करने वाले इंजीनियर्स, और गैर-जरूरी boilerplate से भरे जाने वाले भारी-भरकम context windows—इन सभी ने मिलकर फंड्स को तेज़ी से खत्म कर दिया।

अप्रैल के अंत तक, वो बजट जो दिसंबर तक चलना चाहिए था, पूरी तरह खत्म हो चुका था। इसके जवाब में, Uber को तेज़ी से पीछे हटना पड़ा, और इस वित्तीय नुकसान को रोकने के लिए हार्ड यूसेज कैप्स (hard usage caps), API key provisioning पर सख्त गवर्नेंस, और हर एक कर्मचारी के लिए कोटा लागू करना पड़ा।

#यह क्यों मायने रखता है

Uber की यह परेशानी कोई इकलौती घटना (isolated incident) नहीं है; यह उस "AI FinOps" संकट का एक ट्रेलर है जिसका सामना कई organizations जल्द ही करने वाले हैं।

ऐतिहासिक रूप से, enterprise software पर होने वाला खर्च काफी हद तक predictable रहा है। आप सीट काउंट के आधार पर एक SaaS कॉन्ट्रैक्ट negotiate करते हैं, एक फिक्स्ड सालाना फीस चुकाते हैं, और चाहे कर्मचारी सॉफ्टवेयर का कितनी भी बार इस्तेमाल करें, आपकी लागत स्थिर (static) रहती है। Generative AI मूल रूप से इस मॉडल को तोड़ देता है। LLM का उपयोग पूरी तरह से consumption पर आधारित होता है। हर एक prompt, हर autocomplete सजेशन, और हर एक API कॉल tokens कंज्यूम करता है।

जब आप इसे हजारों engineers, data scientists, और product managers के बीच स्केल करते हैं, तो आप predictable CapEx/OpEx से पूरी तरह से volatile, यूसेज-ड्रिवन बिलिंग (usage-driven billing) की तरफ चले जाते हैं। यहाँ समझने वाली बात यह है कि डेवलपर्स को state-of-the-art रीज़निंग मॉडल्स का अनियंत्रित एक्सेस (unfettered access) देना, उन्हें एक अनलिमिटेड कॉर्पोरेट क्रेडिट कार्ड थमाने जैसा है।

#Technical Implications

AI consumption को मैनेज करना सिर्फ अकाउंटिंग की समस्या नहीं है; यह एक जटिल इंजीनियरिंग चुनौती है। जब organizations को यह एहसास होता है कि उन्हें अपने LLM खर्च को कम करने की ज़रूरत है, तो ज़रूरी guardrails बनाने की जिम्मेदारी अनिवार्य रूप से platform और infrastructure टीमों पर आ जाती है।

इस बदलाव से जो मुख्य technical implications सामने आ रहे हैं, वे इस प्रकार हैं:

#1. "Blanket API Key" का अंत

इंटरनल टूल्स के लिए एक सिंगल, शेयर की गई organization API key प्रोविज़न करना किसी बड़ी आपदा को न्योता देने जैसा है। अब टीमों को मजबूरन proxy layers बनानी पड़ रही हैं जो बाहरी LLM प्रोवाइडर्स को जाने वाली requests को intercept कर सकें। ये proxies कई उद्देश्यों को पूरा करते हैं:

  • Authentication और Attribution: हर एक API कॉल को किसी विशिष्ट यूजर, टीम, या प्रोजेक्ट के कॉस्ट सेंटर (cost center) से मैप करना।
  • Rate Limiting: सिर्फ raw request volume के बजाय, विशेष रूप से token counts के लिए ट्यून किए गए token bucket या leaky bucket algorithms को लागू करना।

#2. Semantic Caching अब अनिवार्य है

अगर कोई इंजीनियर एक ही test suite चलाता है और एक generative AI टूल दिन में दस बार बिल्कुल उन्हीं failure logs को समराइज़ करता है, तो उस inference के लिए दस बार पैसे देना सरासर पैसे की बर्बादी है। Exact matches को कैश (cache) करना आसान है, लेकिन LLM prompts अक्सर थोड़े बहुत अलग होते हैं।

# Example: Implementing a basic Redis semantic cache wrapper
import redis
from sentence_transformers import SentenceTransformer
from sklearn.metrics.pairwise import cosine_similarity

class SemanticCache:
    def __init__(self, threshold=0.95):
        self.cache = redis.Redis(host='localhost', port=6379, db=0)
        self.embedder = SentenceTransformer('all-MiniLM-L6-v2')
        self.threshold = threshold

    def get_cached_response(self, prompt):
        # 1. Convert incoming prompt to an embedding vector
        prompt_embedding = self.embedder.encode([prompt])[0]
        
        # 2. Compare against cached prompt embeddings (simplified for illustration)
        for key in self.cache.keys():
            cached_emb = self.get_embedding_from_key(key)
            similarity = cosine_similarity([prompt_embedding], [cached_emb])[0][0]
            
            # 3. Return cached LLM response if similarity is high enough
            if similarity > self.threshold:
                return self.cache.get(key)
        return None

GPTCache जैसे टूल्स या कस्टम Redis-backed semantic caches क्वेरीज़ को intercept करते हैं, embeddings कंप्यूट करते हैं, और semantically similar (अर्थ के हिसाब से मिलते-जुलते) prompts के लिए cached responses वापस भेजते हैं, जिससे बाहरी API कॉल्स में भारी कमी आती है।

#3. Model Routing और Tiering

हर समस्या के लिए एक frontier model की आवश्यकता नहीं होती है। Model routing architectures की दिशा में एक बहुत बड़ा तकनीकी बदलाव आ रहा है। आसान काम—जैसे बेसिक टेक्स्ट फॉर्मेटिंग, syntax चेकिंग, या लॉग पार्सिंग (log parsing)—छोटे और सस्ते मॉडल्स को रूट (route) किए जाते हैं। वहीं, कॉम्प्लेक्स रीज़निंग वाले काम केवल ज़रूरत पड़ने पर ही प्रीमियम और हाई-पैरामीटर मॉडल्स को भेजे (escalate) जाते हैं।

Task ComplexityExample Use CaseRecommended Model TierCost Profile
LowSyntax formatting, regex generationLlama 3 8B, Claude HaikuMinimal / Free (अगर local है)
MediumCode summarization, standard refactoringGPT-4o-mini, Claude SonnetModerate
HighSystem architecture design, deep debuggingGPT-4o, Claude OpusHigh

#आगे क्या?

"किसी भी कीमत पर AI" (AI at any cost) का युग अब आधिकारिक रूप से समाप्त हो गया है। हम generative AI hype cycle के optimization फेज़ में प्रवेश कर रहे हैं।

अगले 12 से 18 महीनों में, AI observability पर केंद्रित specialized इंटरनल टूल्स में भारी उछाल देखने की उम्मीद है। Dashboards अब सिर्फ CPU और मेमोरी ही नहीं, बल्कि "Tokens per Second" और "Cost per Deployment" जैसी metrics को भी ट्रैक करेंगे। इसके अलावा, इंजीनियरिंग टीमों को prompt engineering को सिर्फ बेहतर जवाब पाने के तरीके के रूप में नहीं, बल्कि एक महत्वपूर्ण कॉस्ट-सेविंग (cost-saving) उपाय के रूप में देखना होगा—ताकि context windows को optimize करके केवल बिल्कुल ज़रूरी डेटा ही भेजा जाए।

हमें लोकल, open-weights मॉडल्स के लिए एक नया पुश भी देखने को मिलेगा। डेवलपर के हार्डवेयर पर locally छोटे पैरामीटर वाले मॉडल्स को रन करने से, रोज़मर्रा के कोडिंग कामों (day-to-day coding tasks) के लिए क्लाउड API की लागत पूरी तरह से बच जाती है, जिससे भारी-भरकम कामों के लिए क्लाउड बजट को रिज़र्व रखा जा सकता है।

#Conclusion

Uber का चार महीने में बजट का खत्म हो जाना एक चेतावनी (cautionary tale) है जो आधुनिक AI integration की अपार शक्ति और उसके साथ आने वाली भारी लागत को उजागर करता है। डेवलपर्स के रूप में, हम स्वाभाविक रूप से उन frictionless टूल्स की ओर आकर्षित होते हैं जो हमारा काम आसान बनाते हैं, लेकिन कंप्यूट (compute) के पीछे के अर्थशास्त्र को हमेशा के लिए नज़रअंदाज़ नहीं किया जा सकता।

भविष्य में सबसे सफल इंजीनियरिंग टीमें वे नहीं होंगी जो AI को सबसे तेज़ी से अपनाएंगी; बल्कि वे होंगी जो इसका लाभ उठाने के लिए सबसे स्मार्ट और cost-effective तरीके आर्किटेक्ट करेंगी। यह समय आ गया है कि AI API कॉल्स के साथ भी वैसी ही सख्त optimization और monitoring की जाए, जैसी हम database queries, मेमोरी लीक्स (memory leaks), और नेटवर्क बैंडविड्थ (network bandwidth) के लिए करते हैं।