• hudson安装


    Hudson 只是一个持续集成服务器(持续集成工具),要想搭建一套完整的持续集成管理平台,
     SVN、Maven、Sonar 等工具按需求整合则可。
     
    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 本地库配置:
    vi /root/maven-3.0.5/conf/settings.xml
    [html] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. <?xml version="1.0" encoding="UTF-8"?>  
    2.   
    3. <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"   
    4.           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
    5.           xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">  
    6.     <localRepository>/root/maven-3.0.5/.m2/repository</localRepository>  
    7.     <interactiveMode>true</interactiveMode>  
    8.     <offline>false</offline>  
    9.     <pluginGroups>  
    10.         <pluginGroup>org.mortbay.jetty</pluginGroup>  
    11.         <pluginGroup>org.jenkins-ci.tools</pluginGroup>  
    12.     </pluginGroups>  
    13.       
    14.     <!--配置权限,使用默认用户-->  
    15.     <servers>  
    16.         <server>  
    17.             <id>nexus-releases</id>  
    18.             <username>deployment</username>  
    19.             <password>deployment123</password>  
    20.         </server>  
    21.         <server>   
    22.             <id>nexus-snapshots</id>  
    23.             <username>deployment</username>  
    24.             <password>deployment123</password>  
    25.         </server>  
    26.     </servers>  
    27.   
    28.     <mirrors>  
    29.   
    30.     </mirrors>  
    31.   
    32.     <profiles>  
    33.         <profile>  
    34.             <id>edu</id>  
    35.             <activation>  
    36.                 <activeByDefault>false</activeByDefault>  
    37.                 <jdk>1.6</jdk>  
    38.             </activation>  
    39.             <repositories>  
    40.                 <!-- 私有库地址-->  
    41.                 <repository>  
    42.                     <id>nexus</id>  
    43.                     <url>http://localhost:8081/nexus/content/groups/public/</url>  
    44.                     <releases>  
    45.                         <enabled>true</enabled>  
    46.                     </releases>  
    47.                     <snapshots>  
    48.                         <enabled>true</enabled>  
    49.                     </snapshots>  
    50.                 </repository>  
    51.             </repositories>        
    52.             <pluginRepositories>  
    53.                 <!--插件库地址-->  
    54.                 <pluginRepository>  
    55.                     <id>nexus</id>  
    56.                     <url>http://localhost:8081/nexus/content/groups/public/</url>  
    57.                     <releases>  
    58.                         <enabled>true</enabled>  
    59.                     </releases>  
    60.                     <snapshots>  
    61.                         <enabled>true</enabled>  
    62.                    </snapshots>  
    63.                 </pluginRepository>  
    64.             </pluginRepositories>  
    65.         </profile>  
    66.           
    67.         <profile>  
    68.             <id>sonar</id>  
    69.             <activation>  
    70.                 <activeByDefault>true</activeByDefault>  
    71.             </activation>  
    72.             <properties>  
    73.                 <!-- Example for MySQL-->  
    74.                 <sonar.jdbc.url>  
    75.                     jdbc:mysql://localhost:3306/sonarqube?useUnicode=true&characterEncoding=utf8  
    76.                 </sonar.jdbc.url>  
    77.                 <sonar.jdbc.username>root</sonar.jdbc.username>  
    78.                 <sonar.jdbc.password>wusc.123</sonar.jdbc.password>  
    79.   
    80.                 <!-- Optional URL to server. Default value is http://localhost:9000 -->  
    81.                 <sonar.host.url>  
    82.                     http://localhost:9090/sonarqube  
    83.                 </sonar.host.url>  
    84.             </properties>  
    85.         </profile>  
    86.           
    87.     </profiles>  
    88.       
    89.     <!--激活profile-->  
    90.     <activeProfiles>  
    91.         <activeProfile>edu</activeProfile>  
    92.     </activeProfiles>  
    93.       
    94. </settings>  

    3、 配置 HudsonHome,在/root 目录下创建 HudsonHome 目录,并配置到环境变量 
    # mkdir HudsonHome 
     
    切换到 root 用户,在/etc/profile 中配置全局环境变量 
    [html] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. # vi /etc/profile   
    2. ## hudson env   
    3. 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 是有下面的提示: 
     
     
    设置 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/ 
     
     
    初始化安装需要安装 3 个默认勾选中的插件(如上图红色部分),其它插件可以等初始
    化安装完成之后再选择安装。 
    点击“Install”安装按钮后,需要等待一会时间才能安装完成。安装完成后按“Finish”按钮。 
    安装的插件保存在 /root/HudsonHome/plugins 目录。 
     
     
    (2)初始化完成后就会进行 Hudson 的配置管理界面:
     
    安全配置
     
    启用安全配置 
     
    使用项目矩阵授权策略
     
     
    注册一个超级管理员账号 
     
    系统设置
     
    配置系统信息、JDK、Maven 
     
     
     
    保存后的效果
     
    插件安装 
     
    结合我们想要实现的持续集成功能,需要安装如下几个插件。如想集成更多功能,自行
    添加插件并配置则可。(注意:现在我们使用了 SonarQube 质量管理不台,则不再需要在
    Hudson 中单独去安装 CheckStyle、Findbugs、PMD、Cobertura 等 Sonar 中已有的插件) 
    逐个搜索你想要安装的插件并点击安装,安装完之后重启 Hudson。 
    如下图所示:
     
    在 Hudson 中配置 SonarQube 链接
    以上就是 Hudson 的基本安装和配置,更多其它配置和功能可自行扩展。
     
     
    Hudson 的使用(使用 Hudson 来自动化编译、分析、打包、发布、部署项目) 
     
    添加项目
     
     
     
     
     
    Poll SCM  中的***** 代表 每隔一分钟检查svn下项目有发生变化,就从svn检出该项目执行的编译,打包
     
     
     
     
     
    添加自动化部署任务
     
     
    设置 Publish over ssh
     
     
     
    在添加项目里设置Post-bulid Actions
     
     
    Source files : 目录是hubson编译后项目后产生 /root/HudsonHome/jobs/xxx-项目/workspace路径下的相对目录 
    (即root/HudsonHome/jobs/xxx-项目/workspace/target/xxx.war)
    Remove prefix : 拷贝时把前缀target去掉
    Remote directory : 拷贝到远程的目录(相对Publish over ssh设置的远程目录即:/home/dubbo/me/web/me-web-tomcat/webaaps目录)
    Exec command:执行的脚本命令
     
     
    restart.sh 
    [html] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. ## java env  
    2. export JAVA_HOME=/usr/java/jdk1.7.0_55  
    3. export JRE_HOME=$JAVA_HOME/jre  
    4.   
    5. ## restart tomcat  
    6. /home/dubbo/me/web/me-web-tomact/bin/shutdown.sh  
    7. sleep 3  
    8. rm -rf /home/dubbo/me/web/me-web-tomact/webapps/me-web  
    9. /home/dubbo/me/web/me-web-tomact/bin/startup.sh  

    Hudson的配置与使用入门

    Hudson 是一个可扩展的持续集成引擎。
    主要用于:
    1.持续、自动地构建/测试软件项目,如CruiseControl与DamageControl。2.监控一些定时执行的任务。

    Hudson拥有的特性包括:
    易于安装-只要把hudson.war部署到servlet容器,不需要数据库支持。
    易于配置-所有配置都是通过其提供的web界面实现。
    集成RSS/E-mail/IM-通过RSS发布构建结果或当构建失败时通过e-mail实时通知。
    生成JUnit/TestNG测试报告。
    分布式构建支持-Hudson能够让多台计算机一起构建/测试。
    文件识别- Hudson能够跟踪哪次构建生成哪些jar,哪次构建使用哪个版本的jar等。
    插件支持-Hudson可以通过插件扩展,你可以开发适合自己团队使用的工具。

    scrumcn1321450176

    一、安装hudson:

    下载http://hudson-ci.org/latest/hudson.war ,把下载的war包直接扔到tomcat下,启动tomcat。

    hudson就安装完毕,是不是很简单啊。

    二、 配置hudson:

    1、打开 http://localhost:8080/hudson/ ,第一次进入里面没有数据,我们需要创建job,我们这有2个项目,需要创建2个job.

    2、点击左上角的new job,在new job页面需要选择job的类型,hudson支持几种类型,我们选择maven2 project:见下图:

    scrum1321450295

    3、选择完job类型后,进会进入详细配置界面,详细配置界面的配置项很多,不过不用怕,大部分使用默认配置就可以了,下面就说说我们需要修改的几个地方:

    1): Source Code Management

    因为我们使用的SVN,所以这里选择subversion,并在Repository URL中输入我们的SVN地址:
    http://localhost/svn/Entites

    scrumcn1321450352
    注:在输入URL后,如果SVN需要验证(hudson会自动检测是否需要验证),会展URL输入框下方显示需要验证,点击输入验证信息的链接,输入SVN的用户名和密码就可以。在试用的过程中发现如果使用svn自带的服务器,使用svn://方式访问,如果svn需要验证,hudson支持不论,如果不需要验证就可以,建议还是通过apache http方式来访问svn,这样hudson支持比较好。

    2) : 配置自动构建的计划,假设我们想让项目中每天12点和晚上8点自动构建一次,只需要在Build Triggers中选择

    Build periodically,并在Schedule中输入 0 12,20 * * *。
    注: Schedule的配置规则是有5个空格隔开的字符组成,从左到右分别代表:分 时 天 月 年。*代表所有,

    0 12,20 * * * 表示在任何年任何月的任何天的12和20点的0分 进行构建
    3):配置到这里,可能有人发现在Build配置节点,有红色错误信息,提示

    Hudson needs to know where your Maven2 is installed.
    Please do so from the system configuration.

    这是因为hudson找不到maven的原因,点击”system configuration”,是system configuration的maven配置中添加

    maven目录就OK,如下图:

    scrumcn1321450398
    4) 保存好所有配置后,我们第1个job就算是完成了。

    5) 创建web的job, 这里的配置和上面的配置一样,只需要把svn地址改成:http://localhost/svn/Web

    三、手动构建试试

    在经过上面的配置后,回到hudson首页,在首页可以看到刚才添加的2个job,如下图:

    scrumcn1321450444
    点击某1个job后后面的Schedule a build图片手动构建,点击完后,会在左边的Build Queue或者Build Executor Status显示正在构建的任务,在自动构建完后,刷新页面,就可以看到构建结果了,如何某个项目构建失败,点击项目后面的构建数字(从1开始递增)进入项目的”Console Output “可以查看项目构建失败的原因。当然我们也可以配置把构建失败的结果发到我们邮箱。
    到目前为止,1个简单的自动构建环境就搭建好了,很简单吧。
    四、自动部署
    看完上面发现hudson配置真的很简单,几分钟自动构建环境就出来了,但环境搭建好后发现1个问题,现在是能自动构建了,但是构建好的web.war都还是在hudson目录下,并没有发布到tomcat中,还需要手动copy过去?
    是个问题,不过别急,要达到自动部署的目的,需要安装1个hudson的部署插件,下载地址:
    https://hudson.dev.java.net/files/documents/2402/106347/deploy.hpi

    下载完后,进入hudson的插件管理中心:http://localhost:8080/hudson/pluginManager/  (可以点击首页的”Manage Hudson”)找到这个链接,在插件管理中心点击Advanced,在upload plugin 中上传刚才下载的插件,上传完毕后需要重启hudson才能完成安装(即重启tomcat),重启后重新进入web的configure 配置界面,在最下面会发现多处1个配置项,我们配置如下:

    scrumcn1321450489
    注:war file使用的是hudson workspace的相对目录,hudon默认的目录在:

    C:Documents and Settings用户名.hudson

    workspace目录:C:Documents and Settings用户名.hudson jobswebworkspace

    最终产生的war在:C:Documents and Settings用户名.hudson jobswebworkspaceWeb argetweb.war

    保存配置再重新构建一次,打开tomcat的webapps目录,发现web.war终于过来了,大功告成

  • 相关阅读:
    HTTP协议
    idea新建工程项目结构
    idea使用的JDK版本1.9换成1.8后相关的更改设置
    Servlet
    Tomcat三种项目部署方式
    Tomcat环境变量配置命令行报错:The JRE_HOME environment variable is not defined correctl This environment variable is needed to run this program
    JDBC面试题
    XML基础入门
    数据库连接池——Druid
    $.ajax 分页
  • 原文地址:https://www.cnblogs.com/hujihon/p/5679607.html
Copyright © 2020-2023  润新知