1.客户端puppetd向master发起认证请求。或使用带签名的证书。

2.master告诉client你是合法的。

3.客户端puppetd调用facter,facter探测出主机的一些变量,例如主机名,内存大小,ip地址等。pupppetd 把这些信息通过ssl连接发送到服务器端;

4.服务器端的puppetmaster 检测客户端的主机名,然后找到manifest里面对应的node配置,并对该部分内容进行解析,facter送过来的信息可以作为变量处理,node牵涉到的代码才解析,其他没牵涉的代码不解析。解析分为几个阶段,语法检查,如果语法错误就报错。如果语法没错,就继续解析,解析的结果生成一个中间的“伪代码”(catelog),然后把伪代码发给客户端;

5.客户端接收到“伪代码”,并且执行。

6.客户端在执行时判断有没有file文件,如果有向fileserver 发起请求。

7.客户端判断有没有配置report。如果配置把执行结果发送给服务器;

8.服务器端把客户端的执行结果写入日志。并可以发送给报告系统(DashBoard)