Mac系统的launchd、守护进程daemon(2013笔记整理)

1. launchd

Mac系统下通用的进程管理器,是Mac系统下非常重要的一个进程,一般来说该进程不允许直接以命令行的形式调用。只能通过其控制管理界面,launchctl来进行控制。
launchd主要功能是进程管理。可以理解成是一个常驻在后台的进程,根据用户的配置,来响应特定的系统事件。launchd既可以用于系统级别的服务,又可以用于个人用户级别的服务。

2. 在launchd的语境中,常驻进程有两种:

daemon 	# 也就是我们常说的守护进程,这种一般对所有用户都有相同的行为,响应相同的事件,始终运行于后台,没有前台交互界面。
agent 	# 这种是用户级别的服务进程,一般以用户的身份运行。

3. 守护进程(daemon)
是指在UNIX或其他多任务操作系统中在后台执行的电脑程序,并不会接受电脑用户的直接操控。此类程序会被以进程的形式初始化。守护进程程序的名称通常以字母“d”结尾:例如,syslogd就是指管理系统日志的守护进程。
通常,守护进程没有任何存在的父进程(即PID=1),且在UNIX系统进程层级中直接位于init之下。守护进程程序通常通过如下方法使自己成为守护进程:对一个子进程调用fork,然后使其父进程立即终止,使得这个子进程能在init下运行。这种方法通常被称为“脱壳”。
系统通常在启动时一同起动守护进程。守护进程为对网络请求,硬件活动等进行响应,或其他通过某些任务对其他应用程序的请求进行回应提供支持。守护进程也能够对硬件进行配置(如在某些Linux系统上的devfsd),运行计划任务(例如cron),以及运行其他任务。
DOS环境中,此类应用程序被称为驻留程序(TSR)。在Windows系统中,由称为Windows服务的应用程序来履行守护进程的职责。
在原本的Mac OS系统中,此类应用程序被称为“extensions”。而作为Unix-like的 Mac OS X有守护进程。(在Mac OS X中也有“服务”,但他们与Windows中类似的程序在概念上完全不相同。)

4. Mac的守护进程目录有以下几处:

~/Library/LaunchAgents 	# 用户的进程
/Library/LaunchAgents 	# 管理员设置的用户进程
/Library/LaunchDaemons 	# 管理员提供的系统守护进程
/System/Library/LaunchAgents 	# Mac操作系统提供的用户进程
/System/Library/LaunchDaemons 	# Mac操作系统提供的系统守护进程

另:/Library/StartupItems 这个目录下也有可能存在开机启动项目的配置

以上是launchd的相关配置的存放目录,可以看到,一般我们个人编写的守护进程,都应该放到~/Library/LaunchAgents目录里面。

5. 举个例子,我以Jenkins为例来讲。

MacOSX系统下,守护进程文件都是存在Library文件夹,用户相关的Library可能存在于以下三处:

/System/Library
/Library
$HOME/Library

上面3处均有可能存在jenkins的守护进程文件(xxx.plist)。根据上面讲的几处守护进程的目录,找到jenkins的启动配置文件/Library/LaunchDaemons/org.jenkins-ci.plist。
另外,查的过程中我还发现jenkins的uninstall脚本存放于'/Library/Application Support/Jenkins/'下,Uninstall.command和jenkins-runner.sh。我想一些其他通过dmg或者pkg安装的app也是如此,要卸载的话,依次从上头的几个目录中删除配置文件即可。



参考资料:link1 
 link2

 

原文地址:https://www.cnblogs.com/timelyxyz/p/3586136.html