सही ढंग से होस्टनाम सेट करना - अमेज़ॅन ईसी 2 पर फेडोरा 20


11

प्रसंग

मेरे पास अमेज़न ईसी 2 पर एक फेडोरा 20 क्लाउड छवि चल रही है (इसलिए "उदाहरण" कहा जाता है)। और मुझे इसके होस्टनाम को लगातार स्थापित करने के बारे में कुछ अनिश्चितता है।

लक्ष्य

इस मामले में, मान लें कि मैं उदाहरण के मेजबाननाम को penpen.homelinux.org पर सेट करना चाहता हूं । (यह नाम भी का उपयोग करते हुए DynDNS में पंजीकृत किया जाएगा ddclient, लेकिन यह एक और पहलू है जिसे हम यहां रुचि नहीं लेते हैं।)

मेजबाननाम बेशक बूट पूरा होने के बाद मैन्युअल रूप से सेट किया जा सकता है ( hostnamectlदूसरों के बीच का उपयोग करके )। लेकिन हम पहले लॉगिन से पहले सही होस्टनाम सेट करना चाहते हैं।

परंपरागत रूप से, होस्टनाम को लगातार कॉन्फ़िगर करने के लिए, किसी की सामग्री को संशोधित किया जाएगा /etc/hostname। दुर्भाग्य से यह यहाँ काम नहीं करता है।

डिफ़ॉल्ट प्रणाली व्यवहार

डिफ़ॉल्ट रूप से, उदाहरण होस्टनाम को आंतरिक EC2 नाम में सेट करता है। बूट करने के बाद, हम उन सभी छोटे स्थानों को देख सकते हैं जो होस्टनाम का उत्पादन करते हैं, और हम पाते हैं:

Kernel hostname via 'sysctl'                      : ip-10-164-65-105.ec2.internal
Kernel domainname via 'sysctl'                    : (none)
File '/etc/hostname'                              : contains 'ip-10-164-65-105.ec2.internal'
File '/etc/sysconfig/network'                     : exists but has no 'HOSTNAME' line
According to the shell                            : HOSTNAME = ip-10-164-65-105.ec2.internal
Nodename given by 'uname --nodename'              : ip-10-164-65-105.ec2.internal
Hostname ('hostname')                             : ip-10-164-65-105.ec2.internal
Short hostname ('hostname --short')               : ip-10-164-65-105
NIS domain name ('domainname')                    : (none)
YP default domain ('hostname --yp')               : [hostname --yp failed]
DNS domain name ('hostname --domain')             : ec2.internal
Fully qualified hostname ('hostname --fqdn')      : ip-10-164-65-105.ec2.internal
Hostname alias ('hostname --alias')               : 
By IP address ('hostname --ip-address')           : 10.164.65.105
All IPs ('hostname --all-ip-addresses')           : 10.164.65.105 
All FQHNs via IPs ('hostname --all-ip-addresses') : ip-10-164-65-105.ec2.internal 
Static hostname via 'hostnamectl'                 : ip-10-164-65-105.ec2.internal
Transient hostname via 'hostnamectl'              : ip-10-164-65-105.ec2.internal
Pretty hostname via 'hostnamectl'                 : 

तो चलिए / etc / hostname को लिखने का प्रयास करते हैं ...

यदि कोई वांछित होस्टनाम को लिखता है /etc/hostname, तो यह परिवर्तन अगले बूट पर फिर से खो जाता है। चलिए बूट प्रक्रिया की जांच करते हैं, जिसके द्वारा प्रदर्शन किया जाता है systemd

उदाहरण चलाते हैं

लिखने rorororoor.homelinux.orgके लिए /etc/hostnameहै, तो रीबूट करें।

का उपयोग करते हुए journald हम पाते हैं (ध्यान दें कि लॉग लाइनों पूरी तरह से समय से orderd नहीं हैं):

बूट प्रक्रिया होस्टनाम के साथ शुरू होती है क्योंकि लोकलहोस्ट तब रूट स्विच करता है, जिस बिंदु पर होस्टनाम rorororoor.homelinux.org हो जाता है ।

Dec 26 15:12:08 localhost systemd[1]: Starting Cleanup udevd DB...
Dec 26 15:12:08 localhost systemd[1]: Started Cleanup udevd DB.
Dec 26 15:12:08 localhost systemd[1]: Starting Switch Root.
Dec 26 15:12:08 localhost systemd[1]: Reached target Switch Root.
Dec 26 15:12:08 localhost systemd[1]: Starting Switch Root...
Dec 26 15:12:08 localhost systemd[1]: Switching root.
Dec 26 15:12:08 localhost systemd-journal[67]: Journal stopped
Dec 26 15:12:12 rorororoor.homelinux.org systemd-journal[155]: Runtime journal is using 8.0M
Dec 26 15:12:12 rorororoor.homelinux.org systemd-journal[155]: Runtime journal is using 8.0M
Dec 26 15:12:12 rorororoor.homelinux.org systemd-journald[67]: Received SIGTERM
...........
Dec 26 15:12:12 rorororoor.homelinux.org kernel: SELinux: initialized
Dec 26 15:12:12 rorororoor.homelinux.org systemd-journal[155]: Journal started
Dec 26 15:12:08 rorororoor.homelinux.org systemd-cgroups-agent[128]: Failed to get D-Bus connection: Failed to connect to socket /run/systemd/private: No such file or directory
Dec 26 15:12:10 rorororoor.homelinux.org systemd[1]: systemd 208 running in system mode.
Dec 26 15:12:10 rorororoor.homelinux.org systemd[1]: Detected virtualization 'xen'.
Dec 26 15:12:10 rorororoor.homelinux.org systemd[1]: Set hostname to <rorororoor.homelinux.org>.
Dec 26 15:12:10 rorororoor.homelinux.org systemd[1]: Failed to open private bus connection: Failed to connect to socket /var/run/dbus/system_bus_socket: No such file or directory
Dec 26 15:12:11 rorororoor.homelinux.org systemd[1]: Mounted Debug File System.

हम देखते हैं कि systemdहोस्टनाम को rorororoor.homelinux.org पर सेट करता है , जाहिर है सफलतापूर्वक लॉग के होस्ट कॉलम में परिवर्तन होता है। कुछ त्रुटियां जारी की जाती हैं, संभवतः क्योंकि hostnamectlइस समय डीबस से संपर्क नहीं किया जा सकता है।

मुझे यकीन नहीं है कि यहाँ नामकरण कौन करता है; Systemd का कुछ आंतरिक हिस्सा? वैसे भी, पत्रिका के माध्यम से जारी है, हम पाते हैं कि होस्टनाम EC2 आंतरिक नाम पर जल्द ही सेट हो गया है:

Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] util.py[DEBUG]: Running command ('resize2fs', '/dev/xvda1') with allowed return codes [0] (shell=False, capture=True)
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] cc_resizefs.py[DEBUG]: Resizing took 0.067 seconds
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] cc_resizefs.py[DEBUG]: Resized root filesystem (type=ext4, val=True)
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] helpers.py[DEBUG]: config-set_hostname already ran (freq=once-per-instance)
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] helpers.py[DEBUG]: Running config-update_hostname using lock (<cloudinit.helpers.DummyLock object at 0x2559210>)
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] cc_update_hostname.py[DEBUG]: Updating hostname to ip-10-164-65-105.ec2.internal (ip-10-164-65-105)
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] util.py[DEBUG]: Running command ['hostname'] with allowed return codes [0] (shell=False, capture=True)
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] __init__.py[DEBUG]: Attempting to update hostname to ip-10-164-65-105.ec2.internal in 1 files
Dec 26 15:12:33 rorororoor.homelinux.org cloud-init[485]: [CLOUDINIT] util.py[DEBUG]: Running command ['hostnamectl', 'set-hostname', 'ip-10-164-65-105.ec2.internal'] with allowed return codes [0] (shell=False, capture=True)
Dec 26 15:12:33 rorororoor.homelinux.org dbus-daemon[226]: dbus[226]: [system] Activating via systemd: service name='org.freedesktop.hostname1' unit='dbus-org.freedesktop.hostname1.service'
Dec 26 15:12:33 rorororoor.homelinux.org dbus[226]: [system] Activating via systemd: service name='org.freedesktop.hostname1' unit='dbus-org.freedesktop.hostname1.service'
Dec 26 15:12:34 rorororoor.homelinux.org systemd[1]: Starting Hostname Service...
Dec 26 15:12:34 rorororoor.homelinux.org dbus-daemon[226]: dbus[226]: [system] Successfully activated service 'org.freedesktop.hostname1'
Dec 26 15:12:34 rorororoor.homelinux.org dbus[226]: [system] Successfully activated service 'org.freedesktop.hostname1'
Dec 26 15:12:34 rorororoor.homelinux.org systemd[1]: Started Hostname Service.
Dec 26 15:12:34 rorororoor.homelinux.org systemd-hostnamed[598]: Changed static host name to 'ip-10-164-65-105.ec2.internal'
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal systemd-hostnamed[598]: Changed host name to 'ip-10-164-65-105.ec2.internal'
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal systemd[1]: Started Initial cloud-init job (metadata service crawler).
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal systemd[1]: Starting Cloud-config availability.
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal systemd[1]: Reached target Cloud-config availability.
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal systemd[1]: Starting Apply the settings specified in cloud-config...
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal [485]: [CLOUDINIT] helpers.py[DEBUG]: Running config-update_etc_hosts using lock (<cloudinit.helpers.DummyLock object at 0x2559350>)
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal [485]: [CLOUDINIT] cc_update_etc_hosts.py[DEBUG]: Configuration option 'manage_etc_hosts' is not set, not managing /etc/hosts in module update_etc_hosts
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal [485]: [CLOUDINIT] helpers.py[DEBUG]: config-rsyslog already ran (freq=once-per-instance)
Dec 26 15:12:34 ip-10-164-65-105.ec2.internal [485]: [CLOUDINIT] helpers.py[DEBUG]: config-users-groups already ran (freq=once-per-instance)

यहां होस्टनाम सेटिंग "सिस्टमड-होस्टनाम" इकाई के माध्यम से की जाती है। "सिस्टमड-होस्टनाम" के लिए "यूनिट फ़ाइल" है /usr/lib/systemd/system/systemd-hostnamed.serviceऔर इसमें शामिल हैं:

[Unit]
Description=Hostname Service
Documentation=man:systemd-hostnamed.service(8) man:hostname(5) man:machine-info(5)
Documentation=http://www.freedesktop.org/wiki/Software/systemd/hostnamed

[Service]
ExecStart=/usr/lib/systemd/systemd-hostnamed
BusName=org.freedesktop.hostname1
CapabilityBoundingSet=CAP_SYS_ADMIN CAP_DAC_OVERRIDE CAP_SYS_PTRACE

उपरोक्त द्वारा आमंत्रित कार्यक्रम /usr/lib/systemd/systemd-hostnamedवास्तव में एक द्विआधारी (WHY!) है। हालांकि सोर्स कोड पाया जा सकता है।

मुद्दा यह है कि हम वापस आईपी ​​-10-164-65-105.ec2.internal पर हैं

क्या करना है?

जवाबों:


11

आपको दो काम करने की ज़रूरत है (लेकिन उनमें से केवल एक को ही किया है):

  1. में होस्टनाम सेट करें /etc/hostname
  2. संपादित करें /etc/cloud/cloud.cfgऔर सेट preserve_hostnameकरें True। (आप इस विकल्प को अपने उपयोगकर्ता डेटा के साथ भी पास कर सकते हैं।)

दूसरा चरण आवश्यक है, क्योंकि फेडोरा cloud-initउदाहरण का प्रावधान करने के लिए EC2 वातावरण से उपयोगकर्ता डेटा लाने के लिए उपयोग करता है, और cloud-initयह बताने की आवश्यकता है कि होस्टनाम को जारी रहना चाहिए।


ठीक है। मैं तुरंत कोशिश करूँगा।
डेविड टोनहोफर

1
रुको, यह क्या है? ठीक है, YAML ( en.wikipedia.org/wiki/YAML )। तो के अनुसार, मैं इस तरह के "" forerve_hostname : toplevel में "preserve_hostname: true" जोड़ते हैं। ... हाँ, यह काम करता है।
डेविड टोनहोफर

हाँ, यह सिर्फ सादा पुराने YAML है।
माइकल हैम्पटन

वह सब ट्रायल-एंड-एरर। ओह ठीक है, मैंने काफी कुछ सीखा है। धन्यवाद।
डेविड टोनहोफर

धन्यवाद, यह CentOS 7.3 पर काम करता है - दूसरे चरण के बिना, रिबूट पर क्लाउड-इनिट द्वारा होस्टनाम को अधिलेखित कर दिया जाता है। पहले कदम के लिए, मैंने इस्तेमाल किया sudo hostnamectl set-hostname --static myhost.example.com, जो भी लिखता है /etc/hostname
रिचवेल

2

एक अन्य विकल्प उपयोगकर्ता डेटा के माध्यम से होस्टनाम सेट करना है

जैसे

#cloud-config
hostname: foo
fqdn: foo.bar.net

यह होस्टनाम को बूट पर सेट करेगा, हालांकि मैं अनिश्चित हूं कि अगर यह हमेशा पहले लॉगिन से पहले होगा।


1

ऐसा लगता है कि उत्तर होस्टनामेक्टल मैन पेज में है अब 3 होस्टनाम हैं, स्थिर, क्षणिक और सुंदर होस्टनाम।

स्थिर होस्टनाम सेट करने के लिए जो मुझे लगता है कि आप चाहते हैं,

hostnamectl --static set-hostname somehost.tld

आप उन सभी को एक साथ सेट कर सकते हैं

hostnamectl set-hostname somehost.tld

सही, लेकिन ... मुझे एहसास है कि मुझे यह स्पष्ट करना चाहिए था कि मेरी यूनिट फ़ाइल क्या करती है; यह "होस्टनामेक्टल" का उपयोग करके अन्य, स्थिर और क्षणिक होस्टनामों के बीच सेट करता है; यह काम करता है लेकिन मुझे जो हासिल करना है उसके लिए "बड़े पैमाने पर कॉन्फ़िगरेशन" लगता है। पाठ को ठीक करना ...
डेविड टोनहोफर

@DavidTonhofer: मैं भ्रमित हूं। आपके प्रश्न में शब्दों की कमी है, लेकिन यह इस बात को उबालता है कि मैं अपने F20 सिस्टम पर होस्टनाम कैसे सेट करूं। शायद अगर आपने सभी
क्रियाओं को

हममम ... आपके पास एक बिंदु हो सकता है। ठीक है, मुझे पता है कि hostname कैसे सेट करें। लेकिन मैं इसे बूट समय पर अमेज़ॅन EC2 छवि पर ठीक से कैसे सेट करूं?
डेविड टोनहोफर

1

एक अतिरिक्त यूनिट फ़ाइल का उपयोग करके हल करें

निम्नलिखित वास्तव में काम नहीं करता है:

(और संभवतः के बाद ही ) के बाद /usr/lib/systemd/system/penpen-naming.serviceशुरू होने के लिए एक सिस्टम यूनिट फ़ाइल बनाएं ।systemd-hostnamed.servicedbus.service

(मुझे "सही जगह" खोजने के लिए कुछ परीक्षणों को शांत करना था ताकि systemdनई इकाई को सरल न बनाया जाए क्योंकि "एक चक्र का पता चला था"। ध्यान दें कि आप इकाई फ़ाइल निर्भरता ग्राफ को ग्राफ कर सकते हैं systemd-analyze dot, जो "डॉट बनाता है।" "फ़ाइल को" ग्राफ़विज़ " dotप्रोग्राम में पास किया जाना है, लेकिन परिणाम सिर्फ एक बड़ा भ्रमित ग्राफ है, जब तक कि आप पहले से तैयार न हों))

इकाई फ़ाइल की सामग्री /usr/lib/systemd/system/penpen-naming.service:

[Unit]
Description= *** Hostname becomes 'penpen.homelinux.org' ***
After=default.target 
# After=systemd-hostnamed.service -- NOPE 
# After=dbus.service  -- NOPE

[Service]
Type=oneshot
RemainAfterExit=yes
ExecStart=/usr/local/toolbox/setting_hostnames/penpen

[Install]
WantedBy=multi-user.target

इसका उपयोग करके सक्रिय करें systemctl enable penpen-naming

क्या करता /usr/local/toolbox/setting_hostnames/penpenहै? अगर penpen.homelinux.org लिखता है /etc/hostname। लेकिन यह वास्तव में पर्याप्त नहीं है, किसी को भी होस्टनाम का उपयोग करके सेट करना होगा hostnamectl

फिर भी, यूनिट को इतनी देर से चलाना पड़ता है (After=default.target)कि लॉगिन शेल अभी भी EC2 आंतरिक होस्टनाम प्रदर्शित करता है। और अभी भी DBus से कनेक्ट करने में समस्याएं हैं।

तो यह एक अच्छा समाधान नहीं है, या कम से कम इसे "यूनिट फ़ाइल निर्भरता पेड़ में स्थिति" और "क्या नर्क के साथ ऊपर है"

इसके बाद के होस्टनाम हैं:

Kernel hostname via 'sysctl'                      : penpen.homelinux.org
Kernel domainname via 'sysctl'                    : (none)
File '/etc/hostname'                              : contains 'penpen.homelinux.org'
File '/etc/sysconfig/network'                     : exists but has no 'HOSTNAME' line
According to the shell                            : HOSTNAME = ip-10-164-65-105.ec2.internal
Nodename given by 'uname --nodename'              : penpen.homelinux.org
Hostname ('hostname')                             : penpen.homelinux.org
Short hostname ('hostname --short')               : penpen
NIS domain name ('domainname')                    : (none)
YP default domain ('hostname --yp')               : [hostname --yp failed]
DNS domain name ('hostname --domain')             : homelinux.org
Fully qualified hostname ('hostname --fqdn')      : penpen.homelinux.org
Hostname alias ('hostname --alias')               : 
By IP address ('hostname --ip-address')           : 54.221.0.63
All IPs ('hostname --all-ip-addresses')           : 10.164.65.105 
All FQHNs via IPs ('hostname --all-ip-addresses') : ip-10-164-65-105.ec2.internal 
Static hostname via 'hostnamectl'                 : penpen.homelinux.org
Transient hostname via 'hostnamectl'              : penpen.homelinux.org
Pretty hostname via 'hostnamectl'                 : 

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