- JDK 1.8 or later
- Maven 3 or later
- MySQL 5.6 or later
- Spring MVC
- Spring Security
- Spring Data JPA
- Maven
- JSP
- Sonarqube (ubuntu 18.04 | port 9000)
- Nexus (centos7 | port 8081)
- Sonarqube scanner
- maven
- Maven pipeline configuration
- Slack Notification
- Nexus
Architecture:
data:image/s3,"s3://crabby-images/f4ee2/f4ee21cd55aff7d66416d8f4bc2fd9dbb3b30573" alt="image"
- Go to global configuration and set the sonarqube scanner.
- Save settings.
data:image/s3,"s3://crabby-images/ff478/ff47822c829a967d9200c23b204dcdb686fd9737" alt="image"
- Now go to configure settings and configure the sonarqube server.
- Generate token from Sonarqube site and paste it in configure.
data:image/s3,"s3://crabby-images/a7e33/a7e334eb0922c92be15c6610e031cbd7609a7e4e" alt="image"
- Use Chechstyle branch and my repo link.
- Create a new item and select pipeline.
- paste the above Jenkinsfile and change the tools name accordingly
- Build the job now.
data:image/s3,"s3://crabby-images/b5bf2/b5bf2a060709152ef3d3d8b92b425e67654b3075" alt="image"
- Use sonar_analysis branch and my repo link.
- Create a new item and select pipeline.
- Paste the above Jenkinsfile and change the tools name accordingly
- Build the job now.
- This is server name in jenkins for sonarqube.
withSonarQubeEnv('sonar_server')
data:image/s3,"s3://crabby-images/be3f8/be3f8f319e6c78a05e899c77a120ff88d6068b56" alt="image"
- Bugs: 60
- Go to project in sonarqube -> project settings -> quality gate -> select the created quality gate.
- Now go to sonarqube -> project settings -> webhooks -> create webhook.
http://<jenkins-IP>:8080/sonarqube-webhook
- Now checkout the quailty-gate branch and use the jenkinfile as pipeline code and paste it in jenkins
- BUILD NOW
data:image/s3,"s3://crabby-images/3c26f/3c26f6811f0fee86fb5a77a31ac4df3ade815e08" alt="image"
- Build success because the actual bugs is less than < 60
data:image/s3,"s3://crabby-images/29e41/29e4123dc8ec88756440677c42a81c216f07a7f3" alt="image"
- Go to nexus server -> repository -> maven2(hosted)
- Create a repo in nexus.
- Go to manage config in jenkins change the ip of jenkins and sonarqube to private ips
- Save it
- Now go to manage credentials create a credential for nexus.
- Build NOW
data:image/s3,"s3://crabby-images/453dd/453dd6eb9d7d3b691c1b548f2990af88d1aad98e" alt="image"
- Nexus browse page
data:image/s3,"s3://crabby-images/4659d/4659d61885535d2a3328bf92f227f7d9fa9e3b9f" alt="image"
- Create account in
https://slack.com
- Create Workspace and channel in slack.
- Go to apps in slack and search for jenkinsCI.
- Copy the secret key.
- Now go to jenkins manage configure and add the secret key.
- Add pipeline code now
data:image/s3,"s3://crabby-images/f14be/f14be13078c9bcc2f7d18282c36778eb6cc861a1" alt="image"
#DockerCI
- Create IAM user in aws.
- Add the aws credentials to jenkins