जेम्स का जवाब 1 से 1 निर्भरता के लिए काम करता है। 1 से कई के लिए, यानी, बी, सी और डी से पहले सेवा शुरू करने के लिए सुनिश्चित करने के लिए आपको एक और तरीका अपनाने की जरूरत है। आप संदर्भ के लिए वर्तमान पोर्टमैप स्क्रिप्ट देख सकते हैं लेकिन यहां सामान्य दृष्टिकोण है: एक प्रतीक्षा स्क्रिप्ट बनाएं।
परिदृश्य: आप चाहते हैं कि आपकी सेवा ए हमेशा सेवा-बी, सेवा-सी और सेवा-डी से पहले चले।
समाधान: सेवा ए के लिए प्रतीक्षा स्क्रिप्ट बनाएं "इसे कॉल करें" /etc/init/service-a-wait.conf "
# service-a-wait
start on (starting service-b
or starting service-c
or starting service-d)
stop on (started service-a or stopped service-a)
# We know that we have more than one job that needs to wait for service-a and
# will make use of this service, so we need to instantiate.
instance $JOB
# Needed to make starting the job successful despite being killed
normal exit 2
task
script
status service-a | grep -q "start/running" && exit 0
start service-a || true
# Waiting forever is ok.. upstart will kill this job when
# the service-a we tried to start above either starts or stops
while sleep 3600 ; do :; done
end script
सादे अंग्रेजी में इसका क्या मतलब है: जब सेवा बी, सी, या डी सिग्नल जो वे शुरू करना चाहते हैं, तो उन्हें सेवा शुरू होने तक इंतजार करना होगा। सेवा-ए-वेट नौकरी को सेवा-शुरू होने तक चलने के लिए डिज़ाइन किया गया है। एक बार सेवा-ए-वेट से बाहर निकल जाने के बाद, अब सेवाएं b, c और d को ले जाने और चलाने के लिए स्वतंत्र हैं।
यह किसी भी रिवर्स निर्भरता को शुरू करने के प्रयासों से पहले सेवा-ए-अप और चलने का आश्वासन देगा।
नोट: "उदाहरण $ JOB" लाइन इस "प्रारंभ ... या .. या .." परिदृश्य में महत्वपूर्ण है। अन्यथा आप वास्तव में B, C, या D में से जो भी पहले बंद हो, के लिए ब्लॉक कर देंगे।
(तात्कालिकता एक बेहतर व्याख्या के लिए ईमानदारी से हकदार है। अभी के लिए, बस करो;)