Linux service無法使用系統(tǒng)環(huán)境變量的問題及解決
Linux service無法使用系統(tǒng)環(huán)境變量
詳細描述
之前在做一個mysql多實例安裝時,安裝成功,linux也能成功啟動;但是將support-files/mysqld_multi.server移動到/etc/init.d/目錄下并設(shè)置開機啟動(chkconfig xxx on)失??;
問題探索
發(fā)現(xiàn)了問題,開始解決,發(fā)現(xiàn)service xxx start 無法啟動mysql的多實例,但是mysqld_multi start就可以使用;然后經(jīng)過各種嘗試,發(fā)現(xiàn)在普通環(huán)境下可以打印出/etc/profile設(shè)置的mysql環(huán)境變量,但是在shell做成的service中無法打印該mysql環(huán)境變量;
我的/etc/frofile文件:
export PATH=/usr/local/mysql/bin:$PATH
執(zhí)行:可以看到是有設(shè)置的mysql環(huán)境變量的
[root@localhost init.d]# echo $PATH /usr/local/mysql/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
然后我們定義一個system V的腳本
[root@localhost init.d]# vi /etc/init.d/mysqlmul #!/bin/bash #chkconfig: - 75 15 #description: test
賦予權(quán)限并設(shè)置為service
[root@localhost init.d]#chmod +x /etc/init.d/mysqlmul [root@localhost init.d]#chkconfig --add mysqlmul
執(zhí)行service:結(jié)果可以看到是沒有mysql環(huán)境變量的
[root@localhost init.d]# service mysqlmul start /sbin:/usr/sbin:/bin:/usr/bin
解決辦法
1、在/etc/init.d/xxx剛才設(shè)置的service中添加export PATH=/usr/local/mysql/bin:$PATH
注意:
當(dāng)把一個shell腳本放入到service中時,需要設(shè)定好PATH等環(huán)境。
service文件中環(huán)境變量文件的使用
測試準(zhǔn)備
c++測試程序
LogTest.cpp內(nèi)容如下:
// 測試代碼 #include <stdio.h> #include <iostream> using namespace std; int main(int argc, const char* argv[]) { int size = 0; // 解析傳入?yún)?shù)(argc和argv),代碼略 // ... cout << size <<endl; while(1); return 0; }
service文件
LogTest.service文件
[Unit] Description=LogTest After=network.target? [Service] Type=simple EnvironmentFile=-/etc/sysconfig/LogTest ExecStart=/usr/local/MyTest/LogTest -s ${TESTSIZE} ExecStop=/bin/kill -s QUIT $MAINPID StandardOutput=syslog StandardError=syslog SyslogIdentifier=LogTest [Install] WantedBy=multi-user.target ??
環(huán)境變量文件
環(huán)境變量文件LogTest放在/etc/sysconfig/目錄下。
# 環(huán)境變量文件,可根據(jù)需要新增 TESTSIZE=10
測試流程
1)編譯c++測試程序,并將測試程序拷貝至/usr/local/MyTest/目錄下。
cp LogTest /usr/local/MyTest/
2)日志配置
關(guān)于日志相關(guān)配置,可查看https://blog.csdn.net/www_dong/article/details/128053496。
3)service文件加載
# 文件拷貝 cp LogTest.service /usr/lib/systemd/system # 文件加載 systemctl daemon-reload # 程序啟動 systemctl start LogTest # 查看進程是否啟動成功 ps -aux | grep LogTest
4)查看LogTest程序日志
# 進入日志所在目錄 cd /var/log # 查看LogTest.log cat LogTest.log
說明: 日志打印出10,說明整個流程成功
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Linux如何修改hosts文件并刷新DNS生效hosts文件
這篇文章主要介紹了Linux如何修改hosts文件并刷新DNS生效hosts文件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07Linux 3.X/4.x/5.x 忘記寶塔面板密碼的解決方法
在本篇文章里我們給大家整理的是關(guān)于忘記Linux 3.X/4.x/5.x 寶塔面板密碼的解決方案,有需要的朋友們可以學(xué)習(xí)下。2019-10-10詳解如何實現(xiàn)Linux服務(wù)Crash后自動重啟
近期碰到了一個?Linux?Systemd?服務(wù)?Crash,?Crash?后需要人工介入重啟.?那么,?有沒有辦法如何實現(xiàn)?Linux?服務(wù)?Crash?后自動重啟,下面就來和大家分享一下2023-08-08Linux中date命令轉(zhuǎn)換日期提示date: illegal time format問題解決
date命令是顯示或設(shè)置系統(tǒng)時間與日期,最近在使用中發(fā)現(xiàn)了一個問題,所以下面這篇文章主要給大家介紹了關(guān)于Linux中date命令轉(zhuǎn)換日期提示date: illegal time format錯誤的解決方法,需要的朋友可以參考借鑒,下面隨著小編來一起看看吧。2017-12-12詳解Lamp環(huán)境搭建Linux CentOS6.5編譯安裝mysql5.6
這篇文章主要介紹了詳解Lamp環(huán)境搭建Linux CentOS6.5編譯安裝mysql5.6,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05linux查看系統(tǒng)編碼和修改系統(tǒng)編碼的方法
本文為大家介紹了linux查看系統(tǒng)編碼和修改系統(tǒng)編碼的方法,這里使用的是redhat系統(tǒng),大家參考使用吧2014-01-01