Linux service無法使用系統(tǒng)環(huán)境變量的問題及解決
Linux service無法使用系統(tǒng)環(huán)境變量
詳細描述
之前在做一個mysql多實例安裝時,安裝成功,linux也能成功啟動;但是將support-files/mysqld_multi.server移動到/etc/init.d/目錄下并設置開機啟動(chkconfig xxx on)失??;
問題探索
發(fā)現(xiàn)了問題,開始解決,發(fā)現(xiàn)service xxx start 無法啟動mysql的多實例,但是mysqld_multi start就可以使用;然后經過各種嘗試,發(fā)現(xiàn)在普通環(huán)境下可以打印出/etc/profile設置的mysql環(huán)境變量,但是在shell做成的service中無法打印該mysql環(huán)境變量;
我的/etc/frofile文件:
export PATH=/usr/local/mysql/bin:$PATH
執(zhí)行:可以看到是有設置的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
賦予權限并設置為service
[root@localhost init.d]#chmod +x /etc/init.d/mysqlmul [root@localhost init.d]#chkconfig --add mysqlmul
執(zhí)行service:結果可以看到是沒有mysql環(huán)境變量的
[root@localhost init.d]# service mysqlmul start /sbin:/usr/sbin:/bin:/usr/bin
解決辦法
1、在/etc/init.d/xxx剛才設置的service中添加export PATH=/usr/local/mysql/bin:$PATH
注意:
當把一個shell腳本放入到service中時,需要設定好PATH等環(huán)境。
service文件中環(huán)境變量文件的使用
測試準備
c++測試程序
LogTest.cpp內容如下:
// 測試代碼
#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)日志配置
關于日志相關配置,可查看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,說明整個流程成功
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Linux如何修改hosts文件并刷新DNS生效hosts文件
這篇文章主要介紹了Linux如何修改hosts文件并刷新DNS生效hosts文件問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07
Linux 3.X/4.x/5.x 忘記寶塔面板密碼的解決方法
在本篇文章里我們給大家整理的是關于忘記Linux 3.X/4.x/5.x 寶塔面板密碼的解決方案,有需要的朋友們可以學習下。2019-10-10
Linux中date命令轉換日期提示date: illegal time format問題解決
date命令是顯示或設置系統(tǒng)時間與日期,最近在使用中發(fā)現(xiàn)了一個問題,所以下面這篇文章主要給大家介紹了關于Linux中date命令轉換日期提示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-05
linux查看系統(tǒng)編碼和修改系統(tǒng)編碼的方法
本文為大家介紹了linux查看系統(tǒng)編碼和修改系統(tǒng)編碼的方法,這里使用的是redhat系統(tǒng),大家參考使用吧2014-01-01

