আমার সিস্টেমড ইউজার ইউনিট বুট থেকে শুরু হয় না কেন?


39

আমি একটি সিস্টেমযুক্ত ব্যবহারকারী ইউনিট তৈরি করার চেষ্টা করছি এবং সিস্টেম বুট হওয়ার সাথে সাথে এটি শুরু করা হোক। পরিষেবাটি ম্যানুয়ালি শুরু হয়, তবে এটি বুটে শুরু হয় না।

ইন্টারনেট অনুসন্ধান থেকে আমি শিখেছি যে ইউজার ইউনিটগুলি বুট থেকে শুরু করার জন্য, আমার সম্ভবত চালানো দরকার loginctl enable-linger <username>, তবে এটির কোনও প্রভাব ছিল না বলে মনে হয়। প্রকৃতপক্ষে, ম্যান পেজটি বলেছেন:

       Enable/disable user lingering for one or more users. If enabled for
       a specific user, a user manager is spawned for the user at boot and
       kept around after logouts. This allows users who are not logged in
       to run long-running services.

এই আদেশটি চালানো সত্ত্বেও, আমার পরিষেবা বুট শুরু হয় না।

loginctl enable-linger error

একক:

$ cat ~/.config/systemd/user/thin\@.service
[Unit]
Description=A fast and very simple Ruby web server

[Service]
Type=simple
EnvironmentFile=/home/error/.config/thin/%i
ExecStart=/usr/bin/bash /home/error/.rvm/wrappers/%i/thin start -a $THIN_BIND -p $THIN_PORT
WorkingDirectory=/srv/www/%i
PrivateTmp=true

[Install]
WantedBy=multi-user.target

আমি পুনরায় বুট করার সময় এটি চলমান নয়:

$ systemctl --user status thin@redmine -l
● thin@redmine.service - A fast and very simple Ruby web server
   Loaded: loaded (/home/error/.config/systemd/user/thin@.service; enabled; vendor preset: enabled)
   Active: inactive (dead)

# systemctl status user@1000 -l
● user@1000.service - User Manager for UID 1000
   Loaded: loaded (/usr/lib/systemd/system/user@.service; static; vendor preset: disabled)
   Active: active (running) since Wed 2015-12-23 19:43:27 GMT; 13s ago
 Main PID: 613 (systemd)
   Status: "Startup finished in 38ms."
   CGroup: /user.slice/user-1000.slice/user@1000.service
           ├─613 /usr/lib/systemd/systemd --user
           └─615 (sd-pam)                                                          

Dec 23 19:43:27 redmine systemd[613]: Reached target Sockets.
Dec 23 19:43:27 redmine systemd[613]: Starting Sockets.
Dec 23 19:43:27 redmine systemd[613]: Reached target Timers.
Dec 23 19:43:27 redmine systemd[613]: Starting Timers.
Dec 23 19:43:27 redmine systemd[613]: Reached target Basic System.
Dec 23 19:43:27 redmine systemd[613]: Starting Basic System.
Dec 23 19:43:27 redmine systemd[613]: Reached target Default.
Dec 23 19:43:27 redmine systemd[613]: Startup finished in 38ms.
Dec 23 19:43:27 redmine systemd[613]: Starting Default.
Dec 23 19:43:27 redmine systemd[1]: Started User Manager for UID 1000.

আমি এটি ম্যানুয়ালি শুরু করতে পারি এবং এটি কাজ করে:

$ systemctl --user start thin@redmine
$ systemctl --user status thin@redmine -l
● thin@redmine.service - A fast and very simple Ruby web server
   Loaded: loaded (/home/error/.config/systemd/user/thin@.service; enabled; vendor preset: enabled)
   Active: active (running) since Wed 2015-12-23 19:43:50 GMT; 5s ago
 Main PID: 1265 (ruby)
   CGroup: /user.slice/user-1000.slice/user@1000.service/thin.slice/thin@redmine.service
           └─1265 ruby /home/error/.rvm/gems/ruby-2.2.1@redmine/bin/thin start -a ::1 -p 8008

Dec 23 19:43:50 redmine systemd[613]: Started A fast and very simple Ruby web server.
Dec 23 19:43:50 redmine systemd[613]: Starting A fast and very simple Ruby web server...
Dec 23 19:43:52 redmine bash[1265]: /home/error/.rvm/gems/ruby-2.2.1@redmine/gems/htmlentities-4.3.1/lib/htmlentities/mappings/expanded.rb:465: warning: duplicated key at line 466 ignored: "inodot"

# systemctl status user@1000 -l
● user@1000.service - User Manager for UID 1000
   Loaded: loaded (/usr/lib/systemd/system/user@.service; static; vendor preset: disabled)
   Active: active (running) since Wed 2015-12-23 19:43:27 GMT; 40s ago
 Main PID: 613 (systemd)
   Status: "Startup finished in 38ms."
   CGroup: /user.slice/user-1000.slice/user@1000.service
           ├─613 /usr/lib/systemd/systemd --user
           ├─615 (sd-pam)                                                       
           └─thin.slice
             └─thin@redmine.service
               └─1265 ruby /home/error/.rvm/gems/ruby-2.2.1@redmine/bin/thin start -a ::1 -p 8008                                                               

Dec 23 19:43:27 redmine systemd[613]: Startup finished in 38ms.
Dec 23 19:43:27 redmine systemd[613]: Starting Default.
Dec 23 19:43:27 redmine systemd[1]: Started User Manager for UID 1000.
Dec 23 19:43:50 redmine systemd[613]: Created slice -.slice.
Dec 23 19:43:50 redmine systemd[613]: Starting -.slice.
Dec 23 19:43:50 redmine systemd[613]: Created slice thin.slice.
Dec 23 19:43:50 redmine systemd[613]: Starting thin.slice.
Dec 23 19:43:50 redmine systemd[613]: Started A fast and very simple Ruby web server.
Dec 23 19:43:50 redmine systemd[613]: Starting A fast and very simple Ruby web server...
Dec 23 19:43:52 redmine bash[1265]: /home/error/.rvm/gems/ruby-2.2.1@redmine/gems/htmlentities-4.3.1/lib/htmlentities/mappings/expanded.rb:465: warning: duplicated key at line 466 ignored: "inodot"

এই পরিষেবাটি কেন বুট থেকে শুরু হয় না এবং কীভাবে করব তা আমি কীভাবে বুঝব?

অপারেটিং সিস্টেমটি ফেডোরা 23 x86_64, সিস্টেমড 222-10।

উত্তর:


60

চিত্রগুলি যে আমি এটি নিজেই খুঁজে বের করতে পারি।

ক্লুটি এখানে ছিল, ব্যবহারকারী পরিষেবা আউটপুট:

Dec 23 19:43:27 redmine systemd[613]: Reached target Default.

আমার ইউনিটটি multi-user.targetবোঝাইতে বলছিল, তবে ব্যবহারকারী সিস্টেমে তেমন কোনও লক্ষ্য নেই।

আমি default.targetইউনিট ফাইলে এটিকে পরিবর্তন করেছিলাম , পরিষেবাটি অক্ষম করে দিয়েছি এবং পরিষেবাটি পুনরায় সক্ষম করেছি এবং এটি এখন বুট সময় শুরু হয়।

[Install]
WantedBy=default.target

এবং তারপর

$ systemctl --user disable thin@redmine
Removed symlink /home/error/.config/systemd/user/multi-user.target.wants/thin@redmine.service.
$ systemctl --user daemon-reload
$ systemctl --user enable thin@redmine
Created symlink from /home/error/.config/systemd/user/default.target.wants/thin@redmine.service to /home/error/.config/systemd/user/thin@.service.

2
গ্রেট। ধন্যবাদ! আমার ব্যবহারকারী ইউনিটের জন্য
মাল্টি

2
আপনাকে অনেক ধন্যবাদ! systemctl --user list-units --type=targetব্যবহারকারী সিস্টেমডের জন্য লক্ষ্যগুলি তালিকাবদ্ধ করতে ব্যবহার করুন ।
phinz
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.