मैं अपने बूट समय को और कम कैसे कर सकता हूं?


11

मुझे जिन सेवाओं की आवश्यकता नहीं है उनमें से अधिकांश को हटाने के बाद, यह अभी भी लगभग 28 सेकंड बूट करने के लिए, एक तस्वीर लेता है और बंद कर देता है। मैं इसे और भी कम करना चाहूंगा, और मैंने एक किया systemd-analyze blameऔर निम्नलिखित प्राप्त किया:

7.476s disableusb.service
1.736s keyboard-setup.service
958ms kbd.service
789ms systemd-fsck-root.service
737ms systemd-setup-dgram-qlen.service
722ms fake-hwclock.service
580ms kmod-static-nodes.service
565ms console-setup.service
534ms dev-mqueue.mount
518ms systemd-udev-trigger.service
498ms networking.service
489ms raspi-config.service
449ms hdparm.service
444ms systemd-journal-flush.service
376ms systemd-tmpfiles-setup.service
375ms dhcpcd.service
345ms systemd-logind.service
332ms ntp.service
317ms systemd-modules-load.service
281ms tmp.mount
272ms triggerhappy.service
269ms sys-kernel-debug.mount
265ms systemd-fsck@dev-mmcblk0p6.service
223ms rsyslog.service
221ms sys-kernel-config.mount
212ms systemd-tmpfiles-setup-dev.service
200ms systemd-remount-fs.service
198ms systemd-sysctl.service
184ms boot.mount
173ms systemd-random-seed.service
168ms rc-local.service
167ms user@1000.service
165ms var-log.mount
141ms udev-finish.service
130ms sys-fs-fuse-connections.mount
111ms systemd-user-sessions.service
94ms systemd-update-utmp.service
94ms alsa-restore.service
93ms systemd-update-utmp-runlevel.service
77ms systemd-udevd.service
55ms takepicture.service

disableusb.serviceमेरा है, और इसके विपरीत नाम का अर्थ है कि यह अन्य चीजों को भी करता है। मुझे संदेह है कि मैं वहां समय सुधार सकता हूं।

मेरा सिस्टम सीरियल के द्वारा बिना सिर के चल रहा है। मुझे केवल wifi के माध्यम से नेटवर्किंग की आवश्यकता है (wifi शुरू नहीं होता है क्योंकि मैं usb पावर को अक्षम करता हूं, लेकिन कभी-कभी मैं इसे अक्षम नहीं करूंगा, ताकि यह शुरू हो सके)।

इस सूची को देखते हुए, मैं चीजों को देखता हूं जैसे: 1.736s keyboard-setup.serviceऔर 958ms kbd.service। उन्हें लगभग 3 सेकंड लगते हैं। यदि मैं कीबोर्ड का उपयोग नहीं कर रहा हूं तो क्या मुझे उनकी आवश्यकता है? यदि नहीं, तो मैं उन्हें कैसे निष्क्रिय करूँ?

मैं यहां से सुरक्षित रूप से और क्या अक्षम कर सकता हूं?

ठीक है, यहाँ वास्तव में कुछ अजीब है। मैंने कुछ और सेवाओं को अक्षम कर दिया है, और यह अभी भी कुल में इतना लंबा समय लेती है, केवल यह कि अब कुछ सेवाओं को अधिक समय लगने से पहले कम समय लगा ...

7.468s disableusb.service
1.676s console-setup.service
768ms systemd-logind.service
768ms systemd-fsck-root.service
726ms systemd-setup-dgram-qlen.service
714ms fake-hwclock.service
689ms networking.service
530ms systemd-journal-flush.service
524ms systemd-udev-trigger.service
509ms dev-mqueue.mount
509ms ntp.service
508ms kmod-static-nodes.service
439ms dhcpcd.service
334ms systemd-random-seed.service
331ms hdparm.service
318ms systemd-modules-load.service
281ms systemd-tmpfiles-setup.service
279ms systemd-fsck@dev-mmcblk0p6.service
279ms rsyslog.service
269ms systemd-remount-fs.service
265ms sys-kernel-config.mount
254ms systemd-tmpfiles-setup-dev.service
250ms systemd-sysctl.service
238ms rc-local.service
234ms systemd-udevd.service
232ms sys-kernel-debug.mount
224ms user@1000.service
187ms tmp.mount
176ms sys-fs-fuse-connections.mount
175ms var-log.mount
133ms systemd-update-utmp.service
122ms systemd-update-utmp-runlevel.service
122ms systemd-user-sessions.service
119ms alsa-restore.service
91ms boot.mount
88ms udev-finish.service
76ms takepicture.service

सेवा फ़ाइल: (पता नहीं कोड सिंटैक्स क्यों काम नहीं करता है)

[Unit]
Description=Disable USB power
Before=networking.service
After=local-fs.target
DefaultDependencies=no

[Service]
Type=oneshot
ExecStart=/sbin/usb_down

[Install]

यहाँ साजिश है: http://www.eternal-lands.com/plot.svg

यहाँ छवि विवरण दर्ज करें


1
शायद यह स्पष्ट हो सकता है कि समस्या क्या है यदि आप चलाते हैं systemd-analyze plotऔर यहां छवि को शामिल करते हैं (जो कि समय दिखाने वाले एक अच्छा एसवीजी चार्ट का उत्पादन करना चाहिए और शायद चीजों को साफ कर देगा)।
औरोरा ०१०१

1
सुझाव के लिए धन्यवाद, मैंने कथानक को जोड़ने के लिए पोस्ट को संपादित किया।
रादु

आपको सेवा फ़ाइल में पेस्ट करना चाहिए disableusb.service। BTW, तुम जल्दी से कर सकते हैं convert plog.svg plog.jpgआप स्थापित करता है, तो imagemagickपैकेज /
गोल्डीलॉक्स

मैंने सेवा फ़ाइल को जोड़ने के लिए प्रश्न संपादित किया।
रादु

प्रश्न: आपके पास किस तरह का एसडी कार्ड है? एक तेज एसडी कार्ड इनमें से किसी भी अनुकूलन की तुलना में तेजी से बूट समय प्रदान कर सकता है। क्या इसे कम से कम 60mb / s के लिए रेट किया गया है?
साइबरबरन

जवाबों:


7
7.476s disableusb.service

इसका मतलब है कि आप अग्रभूमि में कुछ चला रहे हैं क्योंकि यह लगातार नहीं है इसलिए आपको लगता है कि इसे पृष्ठभूमि में रखने का कोई मतलब नहीं है। हालाँकि, अगर इसे अपना काम करने में लंबा समय लगता है, तो शायद आपको इसे शुरू करते ही बैकग्राउंड में फोर्क करना चाहिए।

यहाँ मुद्दा बस इतना है कि आपके बूट समय को अग्रभूमि में छोड़ने की तुलना में इसका लाभ होने की अधिक संभावना है, हालांकि इससे कोई अंतर नहीं हो सकता है। हालांकि, अगर कुछ और इसे पूरा करने पर निर्भर करता है (जैसा कि बस सफलतापूर्वक आरंभीकरण को पूरा करने का विरोध किया जाता है, जो लगातार सेवा पर अधिक लागू होता है), तो आपको इसे छोड़ देना चाहिए।

मैं चीजों को देखता हूं जैसे: 1.736s कीबोर्ड-सेटअप. सर्विस और 958ms kbd.service। उन्हें लगभग 3 सेकंड लगते हैं।

मैंने कभी इस पर ध्यान नहीं दिया क्योंकि यह मेरे लिए बहुत मायने नहीं रखता है, लेकिन मेरा मानना ​​है कि "कीबोर्ड सेटअप" जिस तरह से रास्पियन पर संभाला जाता है, उसमें कुछ गड़बड़ है। मैंने देखा है कि यह systemd द्वारा मारे जाने से पहले 90 सेकंड तक चलता है।

यदि मैं कीबोर्ड का उपयोग नहीं कर रहा हूं तो क्या मुझे उनकी आवश्यकता है? यदि नहीं, तो मैं उन्हें कैसे निष्क्रिय करूँ?

मुझे लगता है कि नहीं, लेकिन यह आपके लिए एक परेशानी पैदा कर सकता है अगर आपको अचानक कीबोर्ड की आवश्यकता होती है ... या इससे कोई फर्क नहीं पड़ सकता है - मेरे संदेह का हिस्सा यह है कि यह वास्तव में कुछ भी पूरा नहीं कर रहा है, क्योंकि "कीबोर्ड" सेटअप "एक ऐसी चीज है जो स्थिर विन्यास है और इसे आवश्यकतानुसार बदला जा सकता है।

एक सेवा को अक्षम करने के sudo systemd disable ...

raspi-config.service

अजीब यह अभी भी है क्योंकि इसे चलाने के बाद खुद को अक्षम करना चाहिए - लेकिन अगर आपने इसे अनदेखा किया तो ऐसा नहीं हो सकता है। यह कीबोर्ड की चीज़ से संबंधित हो सकता है। यदि संभव हो तो आपको मॉनिटर में प्लग करना चाहिए और यह देखना चाहिए कि क्या यह पोस्ट बूट पॉप अप करता है। किसी भी मामले में यह कुछ और है जो आप अक्षम कर सकते हैं।

यहाँ साजिश है: http://www.eternal-lands.com/plot.svg

मुझे लगता है कि आपको बनाना चाहिए disableusb.service After=sysinit.target


मैंने एक: pi@raspberrypi:~$ sudo systemd disable raspi-config.serviceऔर किया Excess arguments.। साथ ही, उन सेवाओं में से कई सूचीबद्ध नहीं हैं systemctl list-unit-files
रादु

1
किस संबंध के बारे में networking.service? मुझे लगता है कि जानबूझकर नहीं था, यही कारण है कि मैं sysinit के बाद शुरू करने के लिए सिफारिश की है (जो नेटवर्किंग को शुरू करने के लिए इंतजार कर रहा है)। वैसे भी, ध्यान रखें कि यदि 28 सेकंड में आपका शामिल है disableusb, तो यह पाई के किसी भी मॉडल के लिए एक बहुत ही उचित बूट समय है। उनमें से कोई भी तेज नहीं है।
गोल्डीलॉक्स

1
Usb को निष्क्रिय करने से रोकने के लिए नहीं, बल्कि शक्ति के संरक्षण में भूमिका है। विचार यह है कि वाईफाई SHOULD कभी-कभी शुरू होता है, और स्क्रिप्ट उस स्थिति में शक्ति को अक्षम नहीं करेगी।
रादु

2
यदि आप disableusbनेटवर्किंग शुरू होने से पहले जोर देना चाहते हैं तो आप अपना समय बर्बाद करने की कोशिश कर रहे हैं, क्योंकि यह है कि आप यह सुनिश्चित करना चाहते हैं कि वाईफाई शुरू न हो। वह सिर्फ गूंगा है, फ्रैंक होने के लिए; तुम खेल रहे हो मेरा केक और खाओ भी। यदि आप पावर को संरक्षित करने के लिए USB को अक्षम करना चाहते हैं, तो बढ़िया, लेकिन आपको अलग से wifi मुद्दे से निपटना चाहिए। यदि आप परेशान नहीं हो सकते हैं, तो अपना समय अपने बूट समय से कुछ सेकंड के लिए निचोड़ने का प्रयास न करें।
गोल्डीलॉक्स

1
मुझे नहीं लगता कि मैं समझता हूं कि आप क्या कह रहे हैं। मैंने आपको बताया कि मैंने आपके द्वारा सुझाए गए स्क्रिप्ट के थोक को स्थानांतरित कर दिया, और बूट समय लगभग 2 सेकंड तक बढ़ गया ...
रादु

3

ग्राफ को देखते हुए, यह स्पष्ट लगता है कि अक्षम करने console-setup.serviceसे वास्तव में कुछ भी गति नहीं होगी। जैसा कि आप देख सकते हैं networking.serviceकि disableusb.serviceपूर्ण होने तक प्रतीक्षा की जा रही है , इसलिए console-setup.serviceसमानांतर में चलाने के लिए 1.6 सेकंड का लोड समय समग्र बूट समय को प्रभावित नहीं करेगा।

एक महत्वपूर्ण पथ के समय निर्धारण में एक विचार है जो, जब इस पथ में किसी भी गतिविधि में देरी हो जाती है, तो पूरे प्रोजेक्ट में देरी होती है। अन्य गतिविधियों में 'फ्लोट' है, अर्थात वे महत्वपूर्ण नहीं हैं, और अंतिम समय को प्रभावित किए बिना विलंबित किया जा सकता है।

यह महत्वपूर्ण मार्ग है, जिस पर आपको समय की बचत करनी चाहिए, न कि गैर-महत्वपूर्ण गतिविधियों पर। systemd-analyze critical-chainमहत्वपूर्ण गतिविधियों को पहचानने में आपकी मदद करेगा, हालाँकि आप उन्हें प्लॉट पर बहुत अधिक स्थान दे सकते हैं। किसी भी सीमांत लाभ से disableusb.serviceआपके बूट समय में काफी मदद मिलेगी।

यह समझने में भी मदद मिल सकती है कि आपकी सेवाएं इतनी लंबी क्यों हैं । इसके लिए, Bootchart2 उपयोगी हो सकता है। इसके साथ स्थापित किया जा सकता है:

apt-get install systemd-bootchart

वास्तव में इसे सक्षम करने के लिए, संपादित करें /boot/cmdline.txtऔर सेट करें:

init=/lib/systemd/systemd-bootchart

बूटिंग पूर्ण होने के बाद, आपको चार्ट को /run/logSVG फ़ाइल के रूप में सहेजा जाएगा । फिर, init=...इसकी प्रारंभिक सेटिंग पर वापस लौटें (या इसे हटा दें यदि यह पहले नहीं था)।

इसके लिए मैन पेजsystemd-bootchart भी देखें ।


केवल cpu महंगी चीज मेरी अक्षमता raspistill -o /home/pi/test_boot.jpg। सेवा इसे करती है । यह सिर्फ एक परीक्षण है, मैं मापदंडों को थोड़ा और संशोधित कर सकता हूं और कुछ समय बचा सकता हूं, लेकिन भविष्य में मैं कच्चे आउटपुट को भी सक्षम करना चाहता हूं, जिसका अर्थ होगा प्रत्येक पिक के लिए एक और ~ 10 एमबी या ऐसा होगा, जो संभवतः एक अतिरिक्त सेकंड लेगा। लिखना। मैं बूटचार्ट बात की कोशिश करूँगा, मुझे आशा है कि इसे मॉनिटर की आवश्यकता नहीं है :)
रादु

मुझे लगता है कि एक पीएनजी का उत्पादन भी किया जाता है; यह प्रलेखन में ध्यान दिया जाना चाहिए जहां यह रास्पियन में बचाता है।
औरोरा ०१०१

दुर्भाग्य से, यह काम नहीं करता है। Setting up bootchart2 (0.14.4-3) ... update-rc.d: warning: start and stop actions are no longer supported; falling back to defaults update-rc.d: warning: stop runlevel arguments (6 0) do not match bootchart-done Default-Stop values (none)। जब मैं शुरू करता pybootchartgui -iहूं तो मुझे एक: चेतावनी मिलती है: पथ '/var/log/bootchart.tgz' नजरअंदाज नहीं करता है। पार्स त्रुटि: खाली राज्य: '/var/log/bootchart.tgz' मान्य bootchart शामिल नहीं है
राडू

2
ओह, यह पता चलता है कि स्ट्रेच में अब बूटकट को सिस्टमड -बूटचार्ट कहा जाता है और सिस्टमड के साथ अधिक निकटता से एकीकृत किया जाता है। मैंने उचित चरणों के साथ, @Radu संपादित किया है।
औरोरा ०१०१

1
तो, मुझे पता चला कि कैमरा ऐप में 5 सेकंड की देरी है, सिर्फ इसलिए। मैं प्रयोग किया जाता है --timeout 1और यह 15.389s को :) बूट समय कम
राडू

2

मैं एक सिर-कम रसभरी ज़ीरो चला रहा हूं और मैं इससे कुछ सेकंड शेव कर सकता हूं:

systemd

# Don't start the Light Display Manager on headless
sudo systemctl disable lightdm.service

# In a headless environment you don't need the keyboard setup.
sudo systemctl disable keyboard-setup.service

# Checks if the country is set in the WIFI config. This is likely a regulatory precaution.
sudo systemctl disable wifi-country.service

# Unless you have an external joystick or something that uses `/dev/input/`
sudo systemctl disable triggerhappy.service 

# I read that the swap file actually slows the PI down and decreases SD card lifetime. 
sudo systemctl disable dphys-swapfile.service

# Disable Bluetooth unless you need it
sudo systemctl disable hciuart.service

# Unless you have a hardware button to disable the WIFI you won't need this
sudo systemctl mask systemd-rfkill.service # disabling won't work


# Open GL should be obsolete on a headless machine
sudo systemctl disable gldriver-test.service

# Only disable this one if you're not using `/etc/rc.local`
sudo systemctl mask rc-local

# You might to re-enable this service when making changes using `sudo raspi-config`
sudo systemctl disable raspi-config.service

कृपया ध्यान दें कि systemd-analyzeबूट समय आउटपुट:

Startup finished in 1.532s (kernel) + 20.862s (userspace) = 22.395s

न्यूनतम बूट उत्पादन

के बाद में अंत में boot/cmdline.txtबदलने के tty1लिए tty3और loglevel=3 quiet logo.nologoकरने के लिएrootwait

इसने मेरे लिए एक और दूसरा बचा लिया।

विविध

यह आदमी 3 सेकंड का एक रास्पबेरी बूट प्राप्त करता है: https://www.samplerbox.org/article/fastbootrpi

यह बूट समय को कम करने के कुछ चरणों के साथ एक अच्छा ब्लॉग है: http://himeshp.blogspot.com/2018/08/fast-boot-with-raspberry-pi.html

DougieLawson, raspberrpi सेवाओं में से कुछ को https://www.raspberrypi.org/forums/viewtopic.php?t=195692 बताते हैं

पीडीएफ के रूप में गहराई से ट्यूटोरियल

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.