स्थायी कर्मचारी बनाना

किसी समस्या की शिकायत करें सोर्स देखें रात · 7.3 · 7.2 · 7.1 · 7.0 · 6.5

नियमित कर्मचारियों की मदद से आपका काम तेज़ी से हो सकता है. अगर आपने आपने अपने ऐप्लिकेशन में बार-बार कुछ ऐसा किया हो जिसकी स्टार्टअप लागत ज़्यादा हो या क्रॉस-ऐक्शन कैशिंग का फ़ायदा मिलता है, तो हो सकता है कि आपको मैन्युअल तौर पर कर्मचारी को ये कार्रवाइयां करने के लिए कहेंगे.

Basel सर्वर stdin/stdout का इस्तेमाल करके कर्मचारी से संपर्क करता है. यह प्रोटोकॉल बफ़र या JSON स्ट्रिंग का इस्तेमाल करती है.

वर्कर लागू करने के दो हिस्से होते हैं:

कर्मचारी को

लगातार काम करने वाला कर्मचारी कुछ ज़रूरी शर्तों को पूरा करता है:

  • यह लिखा है WorkRequests stdin से.
  • यह लिखता है WorkResponses (और सिर्फ़ WorkResponses) stdout तक.
  • यह --persistent_worker फ़्लैग को स्वीकार करता है. रैपर को --persistent_worker कमांड लाइन फ़्लैग और खुद को सिर्फ़ तभी स्थायी बनाता है, जब फ़्लैग कर दिया जाता है, नहीं तो इसे एक-एक करके कंपाइल करना होगा और बाहर निकलना होगा.

अगर आपका प्रोग्राम इन ज़रूरी शर्तों को पूरा करता है, तो इसका इस्तेमाल लगातार कर्मचारी!

काम के अनुरोध

WorkRequest में वर्कर के लिए आर्ग्युमेंट की एक सूची होती है. पाथ-डाइजेस्ट पेयर उन इनपुट को दिखाते हैं जिन्हें कर्मचारी ऐक्सेस कर सकता है (यह लागू है, लेकिन इस जानकारी का इस्तेमाल कैश मेमोरी में करने के लिए किया जा सकता है) और अनुरोध आईडी, जो 0 है आसान काम करते हैं.

ध्यान दें: प्रोटोकॉल बफ़र में, "स्नेक केस" का इस्तेमाल किया जाता है (request_id), JSON प्रोटोकॉल में "कैमल केस" का इस्तेमाल किया जाता है (requestId). इस दस्तावेज़ में ऊंट के केस का इस्तेमाल किया गया है के उदाहरण हैं, लेकिन फ़ील्ड के बारे में बात करते समय सांप का केस प्रोटोकॉल का इस्तेमाल करना चाहिए.

{
  "arguments" : ["--some_argument"],
  "inputs" : [
    { "path": "/path/to/my/file/1", "digest": "fdk3e2ml23d"},
    { "path": "/path/to/my/file/2", "digest": "1fwqd4qdd" }
 ],
  "requestId" : 12
}

वैकल्पिक verbosity फ़ील्ड का इस्तेमाल, डीबग करने के ज़्यादा आउटपुट का अनुरोध करने के लिए किया जा सकता है से मिलता है. यह पूरी तरह कर्मचारी पर निर्भर करता है कि वह क्या और कैसे काम करेगा. ज़्यादा वैल्यू, ज़्यादा शब्दों वाले आउटपुट को दिखाती हैं. --worker_verbose फ़्लैग को पास किया जा रहा है Basel, verbosity फ़ील्ड को 10 पर सेट करता है, लेकिन छोटी या बड़ी वैल्यू का इस्तेमाल किया जा सकता है का इस्तेमाल करके मैन्युअल रूप से किया जा सकता है.

वैकल्पिक sandbox_dir फ़ील्ड का इस्तेमाल सिर्फ़ वे कर्मचारी करते हैं जो सहायता करते हैं मल्टीप्लेक्स सैंडबॉक्सिंग.

काम से जुड़े जवाब

WorkResponse में एक अनुरोध आईडी, एक शून्य या नॉन-ज़ीरो एक्ज़िट कोड होता है, और प्रोसेस या एक्ज़ीक्यूट करते समय हुई किसी गड़बड़ी की जानकारी देने वाला आउटपुट मैसेज अनुरोध किया है. कर्मचारी को चाहिए कि वह इसके किसी भी टूल के stdout और stderr को कैप्चर करे को कॉल करता है और WorkResponse के ज़रिए उनकी रिपोर्ट करता है. इसे इसके stdout पर लिख रहा है वर्कर प्रोसेस असुरक्षित है, क्योंकि इससे वर्कर प्रोटोकॉल में रुकावट आएगी. इसे stderr वर्कर प्रोसेस में लिखना सुरक्षित है, लेकिन इसका नतीजा यह है हर कर्मचारी की लॉग फ़ाइल में इकट्ठा किया जाता है.

{
  "exitCode" : 1,
  "output" : "Action failed with the following message:\nCould not find input
    file \"/path/to/my/file/1\"",
  "requestId" : 12
}

प्रोटोबफ़ के नियम के मुताबिक, सभी फ़ील्ड वैकल्पिक होते हैं. हालांकि, Basel को WorkRequest और उससे जुड़े WorkResponse में एक ही अनुरोध हो id, इसलिए अगर वह शून्य नहीं है, तो अनुरोध आईडी दर्ज करना आवश्यक है. यह एक मान्य है WorkResponse.

{
  "requestId" : 12,
}

0 का request_id "सिंगलप्लेक्स" को दिखाता है अनुरोध, इस अनुरोध के समय उपयोग किया जाता है को अन्य अनुरोधों के साथ प्रोसेस नहीं किया जा सकता. सर्वर गारंटी देता है कि किसी दिए गए वर्कर को या तो केवल request_id 0 या केवल request_id, शून्य से ज़्यादा है. सिंगलप्लेक्स अनुरोध, सीरियल में भेजे जाते हैं उदाहरण के लिए, सर्वर तब तक दूसरा अनुरोध नहीं भेजता, जब तक कि उसे जवाब (रद्द करने के अनुरोधों को छोड़कर, नीचे देखें).

ज़रूरी जानकारी

  • प्रत्येक प्रोटोकॉल बफ़र से पहले उसकी लंबाई varint प्रारूप में होती है (देखें MessageLite.writeDelimitedTo().
  • JSON के अनुरोधों और उनके जवाबों के पहले, साइज़ दिखाने वाला संकेत नहीं होता.
  • JSON अनुरोधों का स्ट्रक्चर, प्रोटोबफ़ के स्ट्रक्चर जैसा ही रहता है, लेकिन स्टैंडर्ड नियम का इस्तेमाल किया जाता है JSON और सभी फ़ील्ड के नामों के लिए ऊंट केस का इस्तेमाल करें.
  • पुराने और आगे जाने वाले कोड के साथ काम करने वाली प्रॉपर्टी को पहले जैसा बनाए रखने के लिए प्रोटोबफ़ के तौर पर, JSON कर्मियों को इन मैसेज में अज्ञात फ़ील्ड को सहन करना चाहिए, और अनुपलब्ध मानों के लिए प्रोटोबफ़ डिफ़ॉल्ट का उपयोग करें.
  • Basel, अनुरोधों को प्रोटोबफ़ के तौर पर सेव करता है और इनका इस्तेमाल करके उन्हें JSON में बदलता है प्रोटोबफ़ का JSON फ़ॉर्मैट

रद्द किया जाना

दूसरा तरीका यह है कि वर्कर, काम खत्म होने से पहले काम के अनुरोधों को रद्द करने की अनुमति दे सकते हैं. यह डाइनैमिक एक्ज़ीक्यूशन के मामले में खास तौर पर मददगार है, जहां लोकल तेज़ी से रिमोट तरीके से एक्ज़ीक्यूट करने की वजह से, एक्ज़ीक्यूशन में नियमित तौर पर रुकावट आ सकती है. अनुमति देने के लिए रद्द करने के बाद, supports-worker-cancellation: 1 को execution-requirements फ़ील्ड (नीचे देखें) और --experimental_worker_cancellation फ़्लैग.

रद्द करने का अनुरोध एक WorkRequest होता है, जिसमें cancel फ़ील्ड सेट होता है (और इसी तरह एक रद्द जवाब, was_cancelled के साथ एक WorkResponse होता है फ़ील्ड सेट). सिर्फ़ एक फ़ील्ड, जिसे रद्द करने के अनुरोध या रद्द करने के अनुरोध में होना चाहिए रिस्पॉन्स request_id है. इससे पता चलता है कि किस अनुरोध को रद्द करना है. request_id सिंगलप्लेक्स वर्कर के लिए फ़ील्ड 0 होगा या पहले के फ़ील्ड का नॉन-0 request_id होगा मल्टीप्लेक्स कर्मियों को WorkRequest भेजा. सर्वर, सदस्यता रद्द करने के अनुरोध भेज सकता है उन अनुरोधों के लिए जिनके जवाब कर्मचारी ने पहले ही दे दिए हैं. इस मामले में, अनुरोध पर ध्यान नहीं देना चाहिए.

रद्द नहीं किए गए WorkRequest मैसेज का सिर्फ़ एक बार जवाब देना ज़रूरी है, चाहे या नहीं, इसे रद्द किया गया. सर्वर से अनुरोध रद्द करने के बाद, वर्कर request_id सेट और was_cancelled के साथ WorkResponse की मदद से जवाब दें फ़ील्ड को 'सही' पर सेट किया गया है. नियमित WorkResponse भेजना भी स्वीकार किया जाता है, लेकिन output और exit_code फ़ील्ड को अनदेखा कर दिया जाएगा.

WorkRequest के लिए जवाब भेजे जाने के बाद, वर्कर को फ़ाइलों को अपनी वर्किंग डायरेक्ट्री में सेव कर सकते हैं. सर्वर फ़ाइलों को खाली कर सकता है, इसमें कुछ समय के लिए सेव की गई फ़ाइलें भी शामिल हैं.

कर्मचारी का इस्तेमाल करने वाला नियम बनाना

आपको एक ऐसा नियम भी बनाना होगा जो लागू की जाने वाली कार्रवाइयों को जनरेट करता हो कर्मचारी. स्टारलार्क के लिए कर्मचारी का इस्तेमाल करने वाला नियम बनाना कोई दूसरा नियम बनाना.

इसके अलावा, नियम में वर्कर का रेफ़रंस होना चाहिए और इसके तहत की जाने वाली कार्रवाइयों की कुछ शर्तें होती हैं.

कर्मचारी को रेफ़र किया जा रहा है

वर्कर का इस्तेमाल करने वाले नियम में, वर्कर के बारे में बताने वाला फ़ील्ड शामिल होना चाहिए , इसलिए आपको \*\_binary नियम का एक इंस्टेंस बनाना होगा, ताकि अपने कर्मचारी को. अगर आपके वर्कर को MyWorker.Java कहा जाता है, तो यह संबंधित नियम:

java_binary(
    name = "worker",
    srcs = ["MyWorker.Java"],
)

इससे "कर्मचारी" लेबल जोड़ा गया है, जो वर्कर बाइनरी से जुड़ा है. इसके बाद, आपको ऐसे नियम को तय करता है जो वर्कर का इस्तेमाल करता है. इस नियम से एक ऐसा एट्रिब्यूट तय होना चाहिए जो वर्कर बाइनरी को दिखाता है.

अगर आपकी बनाई गई वर्कर बाइनरी, "वर्क" नाम के पैकेज में है, जो सबसे ऊपर है , यह एट्रिब्यूट की परिभाषा हो सकती है:

"worker": attr.label(
    default = Label("//work:worker"),
    executable = True,
    cfg = "exec",
)

cfg = "exec" बताता है कि वर्कर को आपके डिवाइस पर चलने के लिए बनाया जाना चाहिए टारगेट प्लैटफ़ॉर्म के बजाय इस्तेमाल करने के लिए प्लैटफ़ॉर्म (यानी, वर्कर का इस्तेमाल किया जाता है) बिल्ड के दौरान टूल के तौर पर).

काम से जुड़ी कार्रवाई की ज़रूरी शर्तें

वर्कर का इस्तेमाल करने वाला नियम, वर्कर के लिए कार्रवाइयां बनाता है. ये कार्रवाइयों की कुछ ज़रूरी शर्तें होती हैं.

  • "तर्क" फ़ील्ड. यह स्ट्रिंग की एक सूची लेता है, जिसमें से अंतिम जो स्टार्टअप होने पर वर्कर को भेजे जाते हैं. इसमें अंतिम तत्व "तर्क" सूची एक flag-file (@-पूर्वानुमान) तर्क है. कर्मचारियों ने पढ़ा तय फ़्लैगफ़ाइल से हर WorkRequest के आधार पर आर्ग्युमेंट. आपका नियम इस फ़्लैगफ़ाइल में वर्कर के लिए नॉन-स्टार्टअप तर्क लिख सकता है.

  • "execution-requirements" फ़ील्ड, जिसमें एक शब्दकोश होता है जिसमें "supports-workers" : "1", "supports-multiplex-workers" : "1" या दोनों.

    "तर्क" और "लागू करने की ज़रूरी शर्तें" सभी फ़ील्ड में वैल्यू डालना ज़रूरी है कर्मियों को कार्रवाइयां भेजी गईं. इसके अलावा, ऐसी कार्रवाइयां जिन्हें JSON कर्मियों को "requires-worker-protocol" : "json" को ज़रूरी शर्तों वाला फ़ील्ड. "requires-worker-protocol" : "proto" भी एक्ज़ीक्यूशन की एक मान्य ज़रूरत होती है. हालांकि, प्रोटो वर्कर के लिए यह ज़रूरी नहीं होती, क्योंकि वे डिफ़ॉल्ट हैं.

    प्रोग्राम चलाने की ज़रूरी शर्तों में worker-key-mnemonic भी सेट किया जा सकता है. यह यह तब फ़ायदेमंद हो सकता है, जब एक से ज़्यादा ऐक्शन टाइप के लिए एक्ज़ीक्यूटेबल का फिर से इस्तेमाल किया जा रहा हो और इस वर्कर की कार्रवाइयों में अंतर करना है.

  • कार्रवाई के दौरान, जनरेट की गई अस्थायी फ़ाइलों को कर्मचारी की डायरेक्ट्री पर जाएं. इससे सैंडबॉक्सिंग की सुविधा चालू हो जाती है.

"कर्मचारी" के साथ नियम की परिभाषा मानते हुए एट्रिब्यूट की वैल्यू ऊपर बताई गई है. इसके अलावा, से लेकर "srcs" इनपुट के बारे में बताने वाला एट्रिब्यूट, एक "आउटपुट" विशेषता आउटपुट और "आर्ग" की वैल्यू दिखाता है कर्मचारी को दिखाने वाला एट्रिब्यूट स्टार्टअप तर्क हो, तो ctx.actions.run को किया जाने वाला कॉल यह हो सकता है:

ctx.actions.run(
  inputs=ctx.files.srcs,
  outputs=[ctx.outputs.output],
  executable=ctx.executable.worker,
  mnemonic="someMnemonic",
  execution_requirements={
    "supports-workers" : "1",
    "requires-worker-protocol" : "json"},
  arguments=ctx.attr.args + ["@flagfile"]
 )

एक अन्य उदाहरण के लिए, देखें परसिस्टेंट वर्कर को लागू करना.

उदाहरण

Basel कोड बेस का इस्तेमाल होता है Java कंपाइलर वर्कर, इसके अलावा, JSON वर्कर का उदाहरण इसका इस्तेमाल हमारे इंटिग्रेशन टेस्ट में किया जाता है.

आप इनका इस्तेमाल कर सकते हैं मैल बनाना का इस्तेमाल करें.

एक ऐसे नियम के उदाहरण के लिए जो कर्मचारी का उपयोग करता है, बेज़ल के लिए देखें वर्कर इंटिग्रेशन टेस्ट.

बाहरी योगदान देने वालों ने कई भाषाओं में कर्मचारियों को काम पर रखा है; CANNOT TRANSLATE इसे देखो बेज़ल के ज़रिए लगातार काम करने वाले कर्मचारियों पर, कई तरीकों से काम करने की सुविधा लागू करना. आप GitHub पर और भी कई उदाहरण देखें!