Systemd postgresql स्क्रिप्ट शुरू करता है


14

मैं एक दूसरे सर्वर पर postgresql स्थापित करने की प्रक्रिया में हूं

पहले मैंने पोस्टग्रैक्स्ल स्थापित किया और फिर आपूर्ति की गई स्क्रिप्ट का उपयोग किया

./contrib/start-scripts/linux

सही डायर में रखा

# cp ./contrib/start-scripts/linux /etc/rc.d/init.d/postgresql92
# chmod 755 /etc/rc.d/init.d/postgresql92

जिसके बाद मैं उम्मीद के मुताबिक प्रदर्शन कर सकता था

# service postgresql92 start

हालाँकि नई मशीन Systemd का उपयोग कर रही है और ऐसा लगता है कि ऐसा करने के लिए एक पूरी तरह से अलग तरीका है

मैं इस पर हैक नहीं करना चाहता हूं और कुछ को बर्बाद करना चाहता हूं इसलिए मैं सोच रहा था कि क्या कोई भी मुझे परिणाम की सही दिशा में इंगित कर सकता है कि कैसे परिणाम प्राप्त किया जाए

जवाबों:


22

स्रोत से इंस्टॉल करते समय, आपको सिस्टम यूनिट फ़ाइल को जोड़ना होगा जो स्रोत स्थापित के साथ काम करता है। आरएचईएल, फेडोरा के लिए मेरी यूनिट फ़ाइल इस प्रकार है:

/usr/lib/systemd/system/postgresql.service

[Unit]
Description=PostgreSQL database server
After=network.target

[Service]
Type=forking

User=postgres
Group=postgres

# Where to send early-startup messages from the server (before the logging
# options of postgresql.conf take effect)
# This is normally controlled by the global default set by systemd
# StandardOutput=syslog

# Disable OOM kill on the postmaster
OOMScoreAdjust=-1000
# ... but allow it still to be effective for child processes
# (note that these settings are ignored by Postgres releases before 9.5)
Environment=PG_OOM_ADJUST_FILE=/proc/self/oom_score_adj
Environment=PG_OOM_ADJUST_VALUE=0

# Maximum number of seconds pg_ctl will wait for postgres to start.  Note that
# PGSTARTTIMEOUT should be less than TimeoutSec value.
Environment=PGSTARTTIMEOUT=270

Environment=PGDATA=/usr/local/pgsql/data


ExecStart=/usr/local/pgsql/bin/pg_ctl start -D ${PGDATA} -s -w -t ${PGSTARTTIMEOUT}
ExecStop=/usr/local/pgsql/bin/pg_ctl stop -D ${PGDATA} -s -m fast
ExecReload=/usr/local/pgsql/bin/pg_ctl reload -D ${PGDATA} -s

# Give a reasonable amount of time for the server to start up/shut down.
# Ideally, the timeout for starting PostgreSQL server should be handled more
# nicely by pg_ctl in ExecStart, so keep its timeout smaller than this value.
TimeoutSec=300

[Install]
WantedBy=multi-user.target

फिर स्टार्टअप पर सेवा को सक्षम करें और PostgreSQL सेवा शुरू करें:

$ sudo systemctl daemon-reload # load the updated service file from disk
$ sudo systemctl enable postgresql
$ sudo systemctl start postgresql

6
# systemctl start postgresql.service

कुछ वातावरण अनुवाद होगा service <name> startकरने के लिए systemctl start <name>.service, लेकिन आप इसे पर भरोसा करने की जरूरत नहीं है।


लेकिन मैं postgresql92 स्क्रिप्ट को कहां रखूंगा?
TheLovelySausage

अब आप इसे systemd में उपयोग नहीं करते हैं। आपका वितरण आपको postgresql systemd सेवा फ़ाइल प्रदान करना चाहिए ताकि आप सेवा शुरू कर सकें।
एमरिक

Postgresql स्रोत से स्थापित किया गया था, हालांकि, dnf का उपयोग नहीं कर रहा हूं क्योंकि मुझे विशिष्ट निर्देशिकाओं में पोस्टग्रेज के 3 संस्करण स्थापित करने की आवश्यकता है, क्या पोस्टग्रेजल शुरू करने के लिए आपूर्ति की गई स्क्रिप्ट-लिपिक्स फ़ाइल का उपयोग करना संभव है?
TheLovelySausage

मेरा वितरण इस स्क्रिप्ट को जोड़ता है /usr/lib/systemd/system/postgresql.service। Postgresql द्वारा प्रदान की जाने वाली स्टार्ट-स्क्रिप्ट केवल कवर करने के लिए लगती हैं SysV
एमिक

क्या आपने dnf या yum का उपयोग करके पोस्टग्रैस को स्थापित किया है?
TheLovelySausage

0

ऊपर दिए गए systemctl यूनिट फ़ाइल में मेरी बहुत मदद करें लेकिन आपको जो भी चाहिए उसे बनाने के लिए बस आपको इसे लगाना होगा:

/etc/systemd/system/postgresql92.service
systemctl enable postgresql92.service
systemctl start postgresql92.service

अपने इंस्टॉल के अनुसार बिनय pg_ctl पथ को बदलने के बारे में सोचें, और यदि आप एक और उदाहरण चलाना चाहते हैं, तो आपको अपने सुनने के तरीके को भी बदलना होगा:

ExecStart=/usr/local/pgsql/bin/pg_ctl -o "-p 5489"
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.