本文共 4812 字,大约阅读时间需要 16 分钟。
Also: take a look at
https://wiki.jenkins-ci.org/display/JENKINS/Step+by+step+guide+to+set+up+master+and+slave+machines+on+Windows
创建jenkins用户
用root用户登录slave节点,首先创建jenkins用户,并指定主目录
$ useradd -m jenkins -d /home/jenkins
查看jenkins用户及组的信息
$ id jenkinsuid=500(jenkins) gid=500(jenkins) 组=500(jenkins)
再修改jenkins密码,若不修改是未知的
$ passwd jenkins
再切换到jenkins用户,确保jdk已安装
$ su - jenkins
同时确保slave已安装jdk
$ java -version
且sshd正确运行
$ service --status-all | grep ssh
创建公钥私钥,实现免用户密码登录
使用jenkins用户登录到jenkins master机器
使用jenkins用户登录时若发现连接失败(lost connection),可以先用root用户登录,打开/etc/passwd,找到
jenkins:x:498:499:Jenkins Continuous Integration Server:/var/lib/jenkins:/bin/false
将最后的/bin/false改为/bin/bash,便可以登录。记得使用完改回去,猜测是安全限制。
jenkins用户登录后执行以下命令,生成公私钥
$ ssh-keygenGenerating public/private rsa key pair.Enter file in which to save the key (/root/.ssh/id_rsa): /var/lib/jenkins/.ssh/id_rsa
将公钥和私钥保存到jenkins主目录下,注意确保.ssh目录和id_rsa都是jenkins用户所拥有或者有可读写权限
然后会要求输入passphrase(密码),这里还是不设置,直接两次enter
进入/var/lib/jenkins/.ssh,使用scp命令将生成的公钥id_rsa.pub拷贝到各个slave节点,并命名为authorized_keys
$ scp id_rsa jenkins@xxx.xxx.xxx.xxx:~/.ssh/authorized_keys
同时要修改authorized_keys的权限,
$ chmod 700 authorized_keys
回到jenkins控制台,打开以下页面,添加credentials,以下配置页面是添加slave的jenkins用户密码
另一种ssh免密码登录配置(基于公开密钥的认证),可指定jenkins master私钥的路径或者选择第三个From the Jenkins master ~./ssh,我们选择/var/lib/jenkins/.ssh/id_rsa,这是在上一节创建的私钥
创建slave
进入“系统管理>管理节点>新建节点”,输入节点名称,我已经建了一个节点,所以可以选择复制
进入配置页面,按要求填写,credentialsp这里选择用户密码登录,免密码登录需要指定一个属于它的id_rsa。
保存之后,点击Relaunch agent,启动节点
https://segmentfault.com/a/1190000008369457
作为slave的Linux机器为centos系统。
1) Linux 的 Slave机器设置
创建jenkins用户sudo /usr/sbin/useradd -m jenkins -d /home/jenkins;
查看jenkins用户及组的信息id jenkins :
uid=506(jenkins) gid=506(jenkins) groups=506(jenkins) ;
使用sudo /usr/bin/passwd jenkins来设置用户jenkins的密码为0;
切换到用户jenkins环境下su - jenkins;
确保java安装正确:java --version;
确保sshd正确运行: /sbin/service --status-all | grep ssh;
安装ant,在root下运行yum install ant;
2) 在Slave的linux机器上创建public/private key pair:
确保当前用户为jenkins;
执行ssh-keygen来创建public/private key pair,直接enter,表示key将存储在/home/jenkins/.ssh/id_rsa下,再直接enter,表示不设置密码,再次enter确认密码为空;
创建authorized_keys:
cd .ssh
cat id_rsa.pub > authorized_keys
chmod 700 authorized_keys
;
将id_rsa(相当于privatekey)拷贝到jenkins master机器上,例如c:\jenkins\id_rsa下。
3)创建Slave(note),配置如下:
确保jenkins 中ssh slave plugin正确安装,一般默认安装。
然后lunch slave,使得master和slave通过ssh成功连接。其实launch的时候jenkins自动地从拷贝slave.jar到slave,然后运行通过命令java -jar slave.jar来运行slave。
4)在新建的Linux的Slave上运行上节中的JavaHelloWorld(),且需要修改JavaHelloWorld job的Label为JavaHelloWorldLinux来使用此slave,运行如下:
完!
http://www.cnblogs.com/itech/archive/2011/11/10/2244690.html