Linux?service無法使用系統環境變量問題如何解決

    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,說明整個流程成功

    ? 版權聲明
    THE END
    喜歡就支持一下吧
    點贊7 分享