Ubuntu 上搭建 JSP 项目的持续集成
想在Ubuntu系统上为你的JSP项目搭建一套靠谱的持续集成环境?这事儿说简单不简单,但理清了脉络,其实也没那么复杂。核心就是让代码从提交到部署,实现自动化流水线。下面咱们就来一步步拆解,从环境准备到任务执行,把每个环节的关键点都捋清楚。
一 架构与准备
正所谓“工欲善其事,必先利其器”。在开搞Jenkins之前,先把运行环境这个地基打牢。需要准备的几样核心工具,一个都不能少:
- 运行环境:安装OpenJDK 11或17(Jenkins本身要求Java 8以上)。装完后,别忘了用
java -version验证一下。 - 构建工具:安装Maven,负责拉取项目依赖并最终打包成WAR文件。同样,用
mvn -v检查是否安装成功。 - 版本控制:安装Git,这是代码管理的基石。通过
git --version确认。 - 应用容器:准备Apache Tomcat 9,这是JSP项目的运行容器。建议将其安装到
/opt/tomcat目录,并配置好JAVA_HOME、CATALINA_HOME等关键环境变量。 - 资源建议:为了保证Jenkins和后续构建流程的稳定,服务器至少配备2GB内存和10GB磁盘空间。资源紧张的话,后续跑复杂任务可能会比较吃力。
把这些基础组件搭建好,就等于为整个CI/CD流水线铺好了跑道。
二 安装与初始化 Jenkins
基础环境就绪,接下来就是主角Jenkins的登场了。这里提供两种主流的安装方式,可以根据你的运维习惯来选择。
- 安装方式一(系统包管理器):这是Ubuntu/Debian系统下最通用、最直接的方法。
- 依次执行以下命令,导入密钥、添加软件源并安装:
sudo apt update wget -q -O - https://pkg.jenkins.io/debian/jenkins.io.key | sudo apt-key add - sudo sh -c ‘echo deb http://pkg.jenkins.io/debian-stable binary/ > /etc/apt/sources.list.d/jenkins.list’ sudo apt update && sudo apt install -y jenkins - 启动Jenkins服务并设置为开机自启:
sudo systemctl start jenkins && sudo systemctl enable jenkins。 - 打开浏览器,访问
http://<你的服务器IP>:8080。初始管理员密码可以在/var/lib/jenkins/secrets/initialAdminPassword这个文件里找到。
- 依次执行以下命令,导入密钥、添加软件源并安装:
- 安装方式二(Docker):如果你追求环境隔离和便捷迁移,Docker方式会更适合。一条命令即可启动:
初始密码通过docker run -d --name jenkins -p 8080:8080 -p 50000:50000 -v jenkins_home:/var/jenkins_home jenkins/jenkins:ltsdocker exec jenkins cat /var/jenkins_home/secrets/initialAdminPassword命令获取。
无论用哪种方式,安装完毕后,如果系统启用了UFW防火墙,记得放行8080端口(或者你自定义的端口)。
三 配置 Jenkins 与插件
第一次进入Jenkins管理界面,它会提示你安装插件。直接选择“安装推荐插件”是个省事的办法。不过,为了后续更好地支持JSP项目,建议再补充安装几个核心插件:Git Plugin、Maven Integration Plugin和Pipeline Plugin(后者能让你以可视化的方式管理复杂的流水线)。
插件装好,接下来是关键一步:配置全局工具。进入“Manage Jenkins” -> “Global Tool Configuration”:
- JDK:指定已安装的OpenJDK 11或17的路径,或者让Jenkins自动安装一个。
- Git:通常就在
/usr/bin/git。 - Maven:同样,指定已安装的Maven路径,或选择自动安装。
这个配置相当于给Jenkins配备了“编译工具链”,后面所有项目的构建都会调用这里设定的工具。
四 创建 CI 任务与流水线
工具都配好了,现在可以创建具体的构建任务了。主要有两种风格,适合不同阶段的团队。
- 方式 A(Freestyle 任务):适合快速上手,通过图形界面点点划划就能配置。
- 新建一个“Freestyle project”。在“源码管理”部分选择Git,填入你的代码仓库URL和分支(比如main),并配置好访问凭证(SSH密钥或用户名密码)。
- 配置构建触发器:
– 定时轮询:例如H/5 * * * *表示每5分钟检查一次代码库是否有变更。
– 事件触发(推荐):勾选“GitHub hook trigger for GITScm polling”,这需要在你的Git仓库(如GitHub)中配置Webhook,将代码推送事件直接通知到Jenkins。 - 在“构建”步骤中,选择“Invoke top-level Maven targets”,目标填写
clean package,这会在项目目录下生成target/xxx.war文件。 - 最后,在“构建后操作”里,可以归档生成的WAR包(Archive the artifacts),或者发布JUnit测试报告。
- 方式 B(Pipeline):这是更专业、也更推荐的方式。它将构建流程以代码(Jenkinsfile)的形式描述,存储在项目根目录,便于版本管理和复用。下面是一个典型的Pipeline脚本示例:
这个脚本清晰地定义了四个阶段:拉取代码、编译构建、运行测试、部署到Tomcat。部署阶段通过SSH免密登录,将WAR包拷贝到远程Tomcat服务器并重启服务。注意,其中用到的SSH凭证需要在Jenkins的“凭据”管理中预先配置好。pipeline { agent any tools { jdk ‘openjdk-11’ maven ‘maven-3.8.6’ } stages { stage(‘Checkout’) { steps { git branch: ‘main’, url: ‘https://github.com/yourname/jsp-project.git’ } } stage(‘Build’) { steps { sh ‘mvn clean package’ } } stage(‘Test’){ steps { sh ‘mvn test’ } } stage(‘Deploy’){ when { branch ‘main’ } // 仅对 main 分支执行部署 steps { sshagent([‘tomcat-ssh-credentials’]) { // 使用SSH凭证 sh ‘scp target/*.war user@tomcat-server:/opt/tomcat/webapps/’ sh ‘ssh user@tomcat-server “systemctl restart tomcat”’ } } } } post { success { emailext body: ‘Build succeeded: ${BUILD_URL}’, subject: ‘JSP Project Build Success’, to: ‘dev@example.com’ } failure { emailext body: ‘Build failed: ${BUILD_URL}’, subject: ‘JSP Project Build Failure’, to: ‘dev@example.com’ } } }
五 部署与运维要点
把流水线跑起来只是第一步,要让它在生产环境中稳定、安全地运行,还有一些要点需要关注。
- 部署策略:
- 简单场景:如果Jenkins和Tomcat在同一台服务器上,最简单的方式就是在构建后直接拷贝WAR包到
/opt/tomcat/webapps目录并重启Tomcat。如果是跨机器部署,则建议像上面Pipeline示例那样,使用SSH免密或Tomcat Manager API来远程操作。 - 生产建议:对于正式项目,最好引入Nexus或Artifactory作为独立的制品仓库,管理所有构建产物。在部署策略上,可以考虑滚动升级或蓝绿发布,以最大限度降低发布风险。
- 简单场景:如果Jenkins和Tomcat在同一台服务器上,最简单的方式就是在构建后直接拷贝WAR包到
- 安全加固:
- 为Jenkins、Tomcat及其管理端口设置严格的访问控制,遵循最小权限原则。
- 所有密码、密钥等敏感信息,务必使用Jenkins Credentials功能统一托管,避免在脚本中明文出现。
- 合理限制构建代理(Agent)和节点的权限,并开启审计日志,方便追溯所有操作。
- 性能与稳定性:
- 根据服务器情况,适当调整Jenkins的JVM参数(例如
-Xmx2048m),防止构建过程中内存溢出(OOM)。 - 当构建任务增多、资源紧张时,可以考虑增加额外的Agent节点,或者启用Pipeline的并行构建步骤,提升效率。
- 定期备份
JENKINS_HOME目录(可以使用ThinBackup这类插件),这是Jenkins的所有配置和数据的根本,容不得闪失。
- 根据服务器情况,适当调整Jenkins的JVM参数(例如
把这些都做到位,一套健壮、自动化的JSP项目持续集成环境,就算真正搭建完成了。剩下的,就是享受代码提交后自动测试、打包、部署带来的顺畅感了。