持续集成篇 --Hudson持续集成服务器的安装配置与使用

简介:
IP:192.168.4.221  8G内存(Hudson多个工程在同时构建的情况下比较耗内存)
环境:CentOS 6.6、JDK7
Hudson不需要用到数据库
 
Hudson只是一个持续集成服务器(持续集成工具),要想搭建一套完整的持续集成管理平台,还需要用到前面课程中所讲到的SVN、Maven、Sonar等工具,按需求整合则可。
JZPBK75cXArz2TPrYfpfKadkJGEDQFhJ.png

1、  安装JDK并配置环境变量(略)
JAVA_HOME=/usr/local/java/jdk1.7.0_72
 
2、  Maven本地仓库的安装(使用Maven作为项目构建与管理工具):
(1)下载maven-3.0.5
(注意:建议不要下载3.1或更高版本的Maven,因为与Hudson进行集成时会有问题,之前有遇到过):
 wget http://mirrors.hust.edu.cn/apache/maven/maven-3/3.0.5/binaries/apache-maven-3.0.5-bin.tar.gz
 
(2)解压:
 tar -zxvf apache-maven-3.0.5-bin.tar.gz
 mv apache-maven-3.0.5 maven-3.0.5
 
(3)配置Maven环境变量:
 vi /etc/profile
 maven env
export MAVEN_HOME=/root/maven-3.0.5
export PATH=$PATH:$MAVEN_HOME/bin
 
 source /etc/profile
 
(4)Maven本地库配置:
<?xml version="1.0" encoding="UTF-8"?>

<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" 
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
          xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
<localRepository>/root/maven-3.0.5/.m2/repository</localRepository>
<interactiveMode>true</interactiveMode>
    <offline>false</offline>
    <pluginGroups>
        <pluginGroup>org.mortbay.jetty</pluginGroup>
        <pluginGroup>org.jenkins-ci.tools</pluginGroup>
    </pluginGroups>
<!--配置权限,使用默认用户-->
<servers>
<server>
<id>nexus-releases</id>
<username>deployment</username>
<password>deployment123</password>
</server>
<server> 
<id>nexus-snapshots</id>
<username>deployment</username>
<password>deployment123</password>
</server>
</servers>

    <mirrors>

    </mirrors>

<profiles>
<profile>
<id>edu</id>
<activation>
<activeByDefault>false</activeByDefault>
<jdk>1.6</jdk>
</activation>
<repositories>
<!-- 私有库地址-->
<repository>
<id>nexus</id>
<url>http://localhost:8081/nexus/content/groups/public/</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>      
<pluginRepositories>
<!--插件库地址-->
<pluginRepository>
<id>nexus</id>
<url>http://localhost:8081/nexus/content/groups/public/</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
  </snapshots>
</pluginRepository>
</pluginRepositories>
</profile>
<profile>
<id>sonar</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<!-- Example for MySQL-->
<sonar.jdbc.url>
jdbc:mysql://localhost:3306/sonarqube?useUnicode=true&amp;characterEncoding=utf8
</sonar.jdbc.url>
<sonar.jdbc.username>root</sonar.jdbc.username>
<sonar.jdbc.password>wusc.123</sonar.jdbc.password>

<!-- Optional URL to server. Default value is http://localhost:9000 -->
<sonar.host.url>
http://localhost:9090/sonarqube
</sonar.host.url>
</properties>
</profile>
</profiles>
<!--激活profile-->
<activeProfiles>
<activeProfile>edu</activeProfile>
</activeProfiles>
</settings>

3、  配置HudsonHome,在/root目录下创建HudsonHome目录,并配置到环境变量
 mkdir HudsonHome
 
切换到root用户,在/etc/profile中配置全局环境变量
 vi /etc/profile
 hudson env
export HUDSON_HOME=/root/HudsonHome
 
 source /etc/profile
 
4、  下载最新版Tomcat7,当前最新版为7.0.59:
 wget http://apache.fayea.com/tomcat/tomcat-7/v7.0.59/bin/apache-tomcat-7.0.59.tar.gz
 
5、  解压安装Tomcat:
 tar -zxvf apache-tomcat-7.0.59.tar.gz
 mv apache-tomcat-7.0.59 hudson-tomcat
 
移除/root/hudson-tomcat/webapps目录下的所有文件:
 rm -rf /root/hudson-tomcat/webapps/*
        
  将Tomcat容器的编码设为UTF-8:
  vi /root/hudson-tomcat/conf/server.xml

```
Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" URIEncoding="UTF-8" /
```
如果不把Tomcat容器的编码设为UTF-8,在以后配置Hudson是有下面的提示:

GdxzATyEWJzpnraW3fRa8sKPCJjAE32b.png

设置hudson-tomcat的内存
          vi /root/hudson-tomcat/bin/catalina.sh
          !/bin/sh 下面增加:
JAVA_OPTS='-Xms512m -Xmx2048m'
        
6、  下载最新版的Hudson(这里是3.2.2版)包:
 wget http://mirror.bit.edu.cn/eclipse/hudson/war/hudson-3.2.2.war
 
将war包拷贝到hudson-tomcat/weapps目录,并重命名为hudson.war
 cp /root/hudson-3.2.2.war /root/hudson-tomcat/webapps/hudson.war
 
7、  防火墙开启8080端口,用root用户修改/etc/sysconfig/iptables,
 vi /etc/sysconfig/iptables
增加:
 hudson-tomcat port:8080
-A INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT
重启防火墙:
 service iptables restart
 
8、  设置hudson-tomcat开机启动:
在虚拟主机中编辑/etc/rc.local文件,
 vi /etc/rc.local
加入:
/root/hudson-tomcat/bin/startup.sh
 
9、  启动hudson-tomcat
 /root/hudson-tomcat/bin/startup.sh
 
10、              配置Hudson:
(1)浏览器输入:http://192.168.4.221:8080/hudson/

aYQ6apk7Kfm63wx5EtSCGS6bMNX42BPw.png
TxrSbFTywmJrTnmQswWdEKdJEfKPwzFm.png

初始化安装需要安装3个默认勾选中的插件(如上图红色部分),其它插件可以等初始化安装完成之后再选择安装。
点击“Install”安装按钮后,需要等待一会时间才能安装完成。安装完成后按“Finish”按钮。
安装的插件保存在 /root/HudsonHome/plugins 目录。
 
(2)初始化完成后就会进行Hudson的配置管理界面:
BE84dRpriY5wdSh2dKmJBTmhThjBMJKc.png

安全配置
YDCeyAAM5Eicm7eJ2JRkbj5xp2weRtja.png

启用安全配置
P5Wdf6B7EFdJ8Edhz7nMJBChxySEsWGW.png

使用项目矩阵授权策略
MRhzFPe3w4MKwXw7KabM2cSPemXZir6e.png

注册一个超级管理员账号
2HhbykXRXfwF7jCWGARaTX4h8Ke2jjmi.png

zxTZJsKTfRyaeAEF8hmm6fpZHPykhbPW.png

EFNdwfh25ySwQXCr4GPQ6pfYS7ecHjfS.png

系统设置
6mNaAzHkTC7jZDcWBNKT5QjB8Cz6Dp3f.png

配置系统信息、JDK、Maven
5Dk6k2hWWCbEK6kzEFNxKhWzD8sJbkFG.png

wSkrApeZzjBY6yY24HA2e2wtXma5aCD6.png

SA4WWKTaZmfyZj4mHND3bsbtXS43xCRi.png

保存后的效果
MCwJZkRsmTzN6GAQDJrNTx5DHn86tzh7.png

插件安装
Gh756faYZQJHHnXiirNcGhbzjSXnieKr.png

结合我们想要实现的持续集成功能,需要安装如下几个插件。如想集成更多功能,自行添加插件并配置则可。(注意:现在我们使用了SonarQube质量管理不台,则不再需要在Hudson中单独去安装CheckStyle、Findbugs、PMD、Cobertura等Sonar中已有的插件)
逐个搜索你想要安装的插件并点击安装,安装完之后重启Hudson。
如下图所示:

A8dAZNJ8zb6JnkzcJZ5FTKFJm3Cek5Dj.png

sdC3nTPYS3Tkn8hxWjFFzxAC4WhxfaWj.png

在Hudson中配置SonarQube链接

e4DGX42ZzHaA2dm8j4aNBwJy3bMiHYxB.png

以上就是Hudson的基本安装和配置,更多其它配置和功能可自行扩展。
 
Hudson的使用(使用Hudson来自动化编译、分析、打包、发布、部署项目)
 
添加项目

24wRZcKMfFXk8FwXXYcPWThyiR3axwb3.png
mGNpDy2reDEwbThCmDddFrdpxmQXYMSG.png
j2ZZzp8tYc4TBAM5fA6mGacGczpP8F6n.png
eTCxsx5TztQW8Q2f4jPFw3Z5dXECshHZ.png
JHAfPF3FkHnNKMz73hcJ5a75SRd4SZsx.png
SKXt8at2EmfPjQSyW6ntZjfCcFSbeTsE.png


目录
相关文章
|
14天前
|
消息中间件 安全 Unix
SSH配置多台服务器之间的免密登陆以及登陆别名
SSH配置多台服务器之间的免密登陆以及登陆别名
26 1
|
1月前
|
弹性计算 负载均衡 容灾
slb配置后端服务器组
配置阿里云SLB后端服务器组涉及四个主要步骤:创建服务器组、添加ECS实例、关联监听规则和设定负载均衡策略。这使得流量根据业务需求和服务器特性进行转发,便于应用架构的灵活管理和扩展,支持蓝绿部署、灰度发布,并通过多可用区提升系统可用性和容灾能力。
26 3
|
29天前
|
弹性计算
2024年阿里云服务器不同实例规格与配置实时优惠价格整理与分享
2024年阿里云服务器的优惠价格新鲜出炉,有特惠云服务器也有普通优惠价格,本文为大家整理汇总了2024年阿里云服务器的优惠价格,包含特惠云服务器和其他配置云服务器的优惠价格。以便大家了解自己想购买的云服务器选择不同实例规格和带宽情况下的价格,仅供参考。
2024年阿里云服务器不同实例规格与配置实时优惠价格整理与分享
|
11天前
|
存储 弹性计算 安全
阿里云服务器2核2G、2核4G配置最新租用收费标准及活动价格参考
2核2G、2核4G配置是很多个人和企业建站以及部署中小型的web应用等场景时首选的云服务器配置,这些配置的租用价格也是用户非常关心的问题,本文为大家整理汇总了2024年阿里云服务器2核2G、2核4G配置不同实例规格及地域之间的收费标准,同时整理了这些配置最新活动价格,以供大家参考和选择。
阿里云服务器2核2G、2核4G配置最新租用收费标准及活动价格参考
|
13天前
|
域名解析 网络协议 应用服务中间件
阿里云服务器配置免费https服务
阿里云服务器配置免费https服务
|
16天前
|
安全 关系型数据库 MySQL
国产麒麟服务器等保二级 配置规范(一)
国产麒麟服务器等保二级 配置规范(一)
33 0
|
16天前
|
数据采集
robots.txt配置 减小服务器压力
robots.txt配置 减小服务器压力
13 0
|
27天前
|
网络协议 Linux 网络安全
Linux服务器DNS服务器配置实现bind的正向解释和反向解释
Linux服务器DNS服务器配置实现bind的正向解释和反向解释
17 0
|
29天前
|
弹性计算 网络安全 虚拟化
ECS数据问题之升级配置预防数据丢失如何解决
ECS(Elastic Compute Service,弹性计算服务)是云计算服务提供商提供的一种基础云服务,允许用户在云端获取和配置虚拟服务器。以下是ECS服务使用中的一些常见问题及其解答的合集:
|
30天前
|
弹性计算 Kubernetes 安全
ECS选型推荐配置
在构建Kubernetes集群时,应避免使用过多小规格ECS,因它们可能带来网络限制、容量不足和资源碎片化问题。采用大规格ECS能提升网络性能,优化镜像拉取效率。选择Master节点时,要考虑集群规模,生产环境建议选择较高规格。Worker节点推荐使用CPU≥4核、内存≥8GiB的ECS,根据集群总核数和容错率来决定节点数量。当规模达1000核,可选用裸金属神龙服务器,它提供超强网络、零计算抖动和安全性能,适合大促等需快速扩展的场景。
26 1

热门文章

最新文章