事件起因,新加了个vncserver服务需要链接某个共享库,这个共享库放在自定义的库路径中,需要在服务启动前设置LD_LIBRARY_PATH环境变量。
把export LD_LIBRARY_PATH加到了 /etc/profile.d/中,直接在终端上运行vncserver是可以运行的。
但是运行systemd vncserver服务提示找不到库,所以有疑问,systemd需要如何配置所需的环境变量。
在网上翻了一下文档,总结如下:
1、/etc/profile或者/etc/security/limit.d这些文件中配置的环境变量仅对通过pam登录的用户生效,而systemd是不读这些配置的,所以这就造成登录到终端时查看环境变量和手动启动应用都一切正常,但是systemd无法正常启动应用
2、如果环境变量只有某个服务使用,可以在服务里用 Environment 或 EnvironmentFile来单独为该服务的进程设置环境变量。
参考:http://www.jinbuguo.com/systemd/systemd.exec.html#%E7%8E%AF%E5%A2%83%E5%8F%98%E9%87%8F
3、如果需要给systemd配置全局的默认参数,全局的配置在/etc/systemd/system.conf和/etc/systemd/user.conf中。同时还会加载两个配置文件对应的目录中所有的.conf配置文件/etc/systemd/system.conf.d/.conf和/etc/systemd/user.conf.d/.conf,一般的服务单元使用system.conf即可。加载优先级system.conf最低,所以system.conf.d目录中的配置会覆盖system.conf的配置。
因为全局环境变量是设置的systemd(pid=1)进程的,而所有的服务进程都是该systemd的子进程(或孙子等),所以对所有服务生效。
具体可以参考:
man systemd-system.conf
http://www.jinbuguo.com/systemd/systemd-system.conf.html
4、目前我已知的是更改system.conf配置,需要重启系统才能生效,还没找到如何重新加载此配置
5、systemd设置环境变量不会在字符串内部进行变量展开(也就是"$"没有特殊含义),这个在第2点的链接里有详细说明;