linux service無法使用系統環境變量
詳細描述
之前在做一個mysql多實例安裝時,安裝成功,linux也能成功啟動;但是將support-files/mysqld_multi.server移動到/etc/init.d/目錄下并設置開機啟動(chkconfig xxx on)失敗;
問題探索
發現了問題,開始解決,發現service xxx start 無法啟動mysql的多實例,但是mysqld_multi start就可以使用;然后經過各種嘗試,發現在普通環境下可以打印出/etc/profile設置的mysql環境變量,但是在shell做成的service中無法打印該mysql環境變量;
我的/etc/frofile文件:
export?PATH=/usr/local/mysql/bin:$PATH
執行:可以看到是有設置的mysql環境變量的
[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
執行service:結果可以看到是沒有mysql環境變量的
[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等環境。
service文件中環境變量文件的使用
測試準備
c++測試程序
LogTest.cpp內容如下:
//?測試代碼 #include?<stdio.h> #include?<iostream> using?namespace?std; int?main(int?argc,?const?char*?argv[]) { ????int?size?=?0; ????//?解析傳入參數(argc和argv),代碼略 ????//?... ???? cout?<p><strong>service文件</strong></p> <p>LogTest.service文件</p> <pre class="brush:cpp;">[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
環境變量文件
環境變量文件LogTest放在/etc/sysconfig/目錄下。
#?環境變量文件,可根據需要新增 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,說明整個流程成功