-
Notifications
You must be signed in to change notification settings - Fork 295
/
sample
821 lines (509 loc) · 19.8 KB
/
sample
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
Jenkins Triggers.
To automatically execute a jenkins job, you will use Jenkins triggers
Based on:
Periodic time- schedule
Whenever there is a commit in github repo
A parent job can trigger execution of child job
Execute a job from remote script
You will go to build triggered section in the job to set up a trigger for automatic execution of the job
Trigger prieodically
Go to Job Clone repo --> build trigger--> build preodically --> give */2 * * * * --> Save and build now
All build will be generated automatically every 2 mins
Build Triggers--> Poll SCM --> * * * * *
Build will be generated each time there is a chnage in the repository only.
****************************************
Build too : Maven
***************************
> Powerful project management tool, This tool will help a developer to write his source code and test scripts and maintain them locally
> maven at heart is a plugin based tool (plugin execution framework)
> It is used for Java based code
> All the work in maven is done by plugins (extensions, which when downloaded and executed will enhance the features of actual tool)
> Compile the code → Maven plugin
> 2 types of plugin in Maven:
> Core Build plugins
Tasks Plugin Command (GOAL)
Compile the code Compiler compile
Execute Test cases Surefire test
Package the code package package
Delete previous
build files Clean clean
Check dependencies install install
Deploy the package to
Artifactory deploy deploy
> Reporting Plugins
Plugins that are needed for validation and review the code and generate reports
Reports by maven plugins are generated in the format : .xml, .csv, .html or .txt
Tasks Plugin Command(GOAL)
Code review
(Static Analysis tool) pmd pmd:pmd
Test reports surefire-reporting test
Code Coverage cobertura(deprecated)
JACOCO
Code review
& Code Coverage Sonarqube sonar:sonar
Code Review with PMD: The PMD Plugin allows you to automatically run the PMD code analysis tool on your project's source code and generate a site report with its results.
Code Coverage : Using code coverage tool against your compiled classes it helps you determine how well the unit testing and integration testing efforts have been, and it can then be used to identify which parts of your Java program are lacking test coverage.
A developer will create a Maven project locally in his/her IDE and write source code and test cases inside it
Traditionally, they will build all the above steps in their local machine.
Every project will include following folders:
/src/main/java ⇒ main java source code
/src/test/java ⇒ test cases will be present
In a maven project, you will have the main POM.xml
Which created by Java developer
This file will be prepared before you write the code
This file will be updated while the code
In this file Java developer will write :
> name of the artifact which will be build
> type of artifact
> Dependencies ⇒ softwares that will download automatically for code to work
****
Build section:
> name and version of plugins
Which all plugin we will use for build process
SetUp
**************************
Jenkins--> Manage Jenkins-->Global Tool configuration
Under GIT==> leave it same
Under maven ==> let's install it automatically
Type name as mymaven
check the install automatically box.
Save the changes
****************************************
CREATION OF COMPILE JOB
***********************************
1. new Job --1.complie-->freestyle project
2. Source code management --> select git
--->give git path ===> https://github.com/Sonal0409/DevOpsCodeDemo.git
3. build ==> select invoke top level maven targets
select maven version===> mymaven
goal ==> compile
4. save ==> build now
So all the compiled files will be present at this location
==> look for this line in console output at the end on jenkins
Compiling 13 source files to /var/lib/jenkins/workspace/compile1/target/classes
5. Go to workspace on the left side of jenkins Job compile
In the folder go to ==> target folder==> go to classes/com/edurekademo
==> click on edurekademo==> got to utilities==> all class files will be there which have recently been compiled.
******************************
2nd JOB ==>Code Review
*********************
Jenkins--> new item--> Name= code Review==> freestyle project
==> source codemanagement==>select git==>
give git repo name https://github.com/Sonal0409/DevOpsClassCodes
Step 2: build ==> invoke top level maven target==>
select maven version==>mymaven ==> goal = pmd:pmd
save==> build now
==> click on build number and see the console
Goto Workspace on the left side of jenkins Job code review
In the folder go to ==> target folder ==> you will find pmd.xml file.
CONVERT FILE TO TREND REPORT
*******************************
manage jenkins--> manage plugins--> available --> Search for warning next gen plugin--> install it.
Retsrat in case plugin fails installation.
Now go to the job Code Review==> go to post build actions ==> select recordcomplier warnings and static result analysis
Under tool ==> select PMD
under report file format ==> give path of pmd.xml file ie: target/pmd.xml
or as mentioned in message below : copy **/pmd.xml ( no quotes)
Save the file and build now.
After the build is successfull, you will see PMD Warnings
So you will see 12 new warning have been generated on the code.
Scroll down
Under package click on first one to check warnings.
*********************************
JOB3: Testing --Unit Test report
********************************
1. jenkins--> new item--> Name= 3.unitTest==> freestyle project
==> source codemanagement==>select git==> give git repo name
https://github.com/Sonal0409/DevOpsCodeDemo.git
2. build ==> invoke top level maven target==> select maven version==>mymaven ==> goal = test
3. Save and Build now.
4. Check the workspace
5. surefire-reports will be present
But we cannot understand them easily. So lets generate understandable reports by using Junit reports option under post build actions
6. Go back to job==> post build actions==> select junit test result job
==> give target/surefire-reports/*.xml ===>under test report xml
This is path where xml files are there.
Here *.xml is as we want to use all the xml files
7. Save and build again
Go to build number ===> on left side you will see Test Result
Click on it and you can see all pass and fail details of the tests
**********************************
Job4 Package Job
***************************
Go to jenkins--> new item--> Name= Package==> freestyle project
==> source codemanagement==>select git==> give git repo name https://github.com/Sonal0409/DevOpsClassCodes
build ==> invoke top level maven target==>mymaven
goal = package
==> save==> build now
==> click on build number and see the console
==> go to workspace ==> target/addressbook.war
**************
Connecting all the 4 jobs so that each job can be triggered:
Go to manage plugins → available section
Search for build pipeline plugin
Click on the checkbox and click on Install without restart
Plugin will be installed. It will display all connected jobs on the dashboard
This plugin falls in the category of Jenkins view. It creates a build pipeline view
Lets build the pipeline:
********************************
*****************
Day4:
********************
******************************
Pipeline as a code
**************************
Lets create a pipeline using code:
Create a new job ==> select project as pipeline
pipeline{
tools{
// what tool version to use for build stages
maven 'mymaven'
}
agent any
stages{
stage ('CloneRepo')
{
steps{
echo 'This is stage 1'
git 'https://github.com/Sonal0409/DevOpsCodeDemo.git'
}
}
stage ('Compile')
{
steps{
sh 'mvn compile'
}
}
stage ('CodeReview')
{
steps{
sh 'mvn pmd:pmd'
}
post{
success{
recordIssues(tools: [pmdParser(pattern: '**/pmd.xml')])
}
}
}
stage ('Test')
{
steps{
sh 'mvn test'
}
post{
success{
junit 'target/surefire-reports/*.xml'
}
}
}
stage('package')
{
steps{
sh 'mvn package'
}
}
}
}
> Jenkinsfile
It is a simple text file with no extension
This file contains declarative pipeline code for CI/CD pipeline
The name of this file is always Jenkinsfile
This will is maintained in the root directory of your project repo on SCM tool
Every team member can now make changes to the pipeline code without logging on the jenkins server.
In the github we can also maintain every version of pipeline code
We write the pipeline code in IDE and push the Jenkinsfile in the repository
In jenkins you will create a job, that will fetch the Jenkinsfile and jenkins will execute the pipeline for you.
Demo:
Click on new Item → give the job name as JenkinsfileDemo → Select pipeline project→ press OK
In the job template → click on pipeline tab → select the dropdown option as Pipeline script from SCM
Select SCM as → git
Repository URL? ⇒ https://github.com/Sonal0409/DevOpsCodeDemo.git
We will also add a trigger → Go to Build triggers tab above→ POLL SCM → * * * * *
So that if there is any commit, my pipeline should get executed everytime.
> MultiBranch Pipeline
Basically we have many branches in github for a repository
Each branch may have separate set of tasks/jobs to be executed
Whenever a branch is created on the repo, Make sure the branch has a Jenkinsfile init
In the Jenkinsfile you write the code which is needed to execute certain tasks related to the branch
we will set up a job in jenkins that will scan every branch of your github repository
Whichever branch has the jenkinsfile present on it
> for that branch a jenkins pipeline job will be created with same name as branch name and Jenkinsfile code will be executed
Whichever branch of your repo does not have Jenkinsfile on it. No job will be created for it.
Demo:
Click on new item→ create job -> give name as MultibranchdemoJob → select the template as Multibranch Pipeline → press Ok
In General section → give Display name as : Multibranch Pipeline
In branch Sources section → Click on Add source → select git
Give git Project Repository -> https://github.com/Sonal0409/MultiBranchDemo.git
Nomore changes and save the job.
Jenkins will automatically scan the branches of the repo and create pipeline jobs.
Click on multibranch pipeline job name and you will see the 3 jobs created for 3 branches.
Agenda: Day 5:
*********************
> DSL scripts for automation:
Jenkins DSL is a programmatic way to implement the jenkins JOB
In order to write DSL script, you will have to use DSL plugin which will automatically create jobs in jenkins for you
Using the DSL plugin you will be able to create jenkins job on the fly just with help of simple groovy code.
Groovy scripts are very easy to write and read, it is like java
Demo:
Install DSL plugin
Go to Manage Jenkins → Manage plugins → Available → search for DSL → select the plugin Job DSL plugin → click on install without restart.
Now Go to Manage jenkins → Configure global security →Scroll down to CSRF protection and
Uncheck → Enable script security for Job DSL scripts
Important:
**************
We have to create a job with name as seedjob → in this job we will write the DSL scripts
The operation of seed job is to create new jobs programmatically
Seed job will always be a Freestyle job
In the seed job under Build steps you will write the DSL scripts and execute the seed job.
*******************
DSL script1:
***************
Write DSL script to automatically create a job with name as Firstjob and description as “my first DSL job”
Demo:
Create a Seed Job in jenkins
New item→ SeedJob → freestyle project–press OK
Go to Build steps → Process Job DSLs —>
Select the option -> Use the provided DSL script
Define variable in groovy and use it in Job
def jobname = 'Firstjob'
job(jobname){
}
*******
Create job with Description
def jobname = 'Firstjob'
job(jobname){
description('my testjob')
triggers{
cron ('* * * * *')
}
}
**************
ADD SCM option
def jobname = 'Firstjob'
def repo = 'sonal0409/DevOpsClassCodes'
job(jobname){
description('my testjob')
scm {
github repo
}
}
****************
Add triggers & build step
def jobname = 'Firstjob'
def repo = 'sonal0409/DevOpsClassCodes'
job(jobname){
description('my testjob')
scm {
github repo
}
triggers{
cron ('H/15 * * * *')
}
steps {
shell ("echo 'Hello World'")
}
}
*********************
Delete job created programitically
jenkins.model.Jenkins.theInstance.getProjects().each { job ->
if (job.name.contains('job')) {
println job.name
job.delete()
}
}
OR
jenkins.model.Jenkins.theInstance.getProjects().each { job ->
if (job.name.contains('Job')) {
println job.name
job.delete()
}
Upstream/Downstream pipeline using DSL script job
job('job-checkout') {
scm {
github('sonal0409/DevOpsClassCodes', 'master')
}
publishers {
downstream 'job-compile', 'SUCCESS'
}
}
job('job-compile'){
scm {
github('sonal0409/DevOpsClassCodes', 'master')
}
steps{
maven('compile')
}
publishers {
downstream 'job-test', 'SUCCESS'
}
}
job('job-test'){
scm {
github('sonal0409/DevOpsClassCodes', 'master')
}
steps{
maven('test')
}
publishers {
downstream 'job-package', 'SUCCESS'
}
}
job('job-package'){
scm {
github('sonal0409/DevOpsClassCodes', 'master')
}
steps{
maven('package')
}
}
********************************************
Steps to integrate sonarqube to jenkins:
Launch a Ec2 instanace - t2 small - 2 GB
Install java on the machine
sudo amazon-linux-extras install java-openjdk11 -y
Download Sonarqube
https://www.sonarqube.org/downloads/
on ec2
cd /opt
wget https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-8.9.10.61524.zip
ls
unzip sonarqube-8.9.10.61524.zip
ls
go inside the soanrqube repo
cd sonarqube-8.9.10.61524
cd bin
In order to run the script to start sonarqube, we have to create a new user
useradd sonaradmin
chown -R sonaradmin:sonaradmin /opt/sonarqube-8.9.10.61524
ll
CHnage to sonaradmin user
su - sonaradmin
go into sonar directoru
cd /opt/sonarqube-8.9.10.61524
cd bin
cd linux x86-64
start sonar.sh scrpit
./sonar.sh start
./sonar.sh status
now go to browser
ipaddress:9000
username admin/admin
Create project and genrate token
copy the token
Go jenkins
download sonarqube plugin
Sonalqube scanner
In jenkins → Secutory→ Global Credentials→ click on global→ click on add credentials
Kind → select secret text
give secret → the token copied form sonar Project
Give id and description → anything
Save the credentials.
Manage Jenkins → Go to Configure system
scroll to Sonarqube Server section
Select checkbox Environment Varibale
Click on Sonarqube server
Give a Name
Server URL : url of sonarqube http://44.5345.567.6:9000/
Select the Server authetication token
select credentials
Now create freestyle job
add the repo
Build environment: Select Prepare SOnaqube scanner environment
invoke top level maven target: clean install sonar:sonar
Save the job
*************************
Agenda:
******************
Master and slave architecture in Jenkins
Create a linux slave and dispatch job from master to slave
Create a new EC2 instance with OS as Amazon linux 2
Provide the security group rule 2 also.
Connect to the instance and install following tools:
Execute command to become root
sudo su -
Java:
sudo amazon-linux-extras install java-openjdk11 -y
GIT:
yum install git -y
Create a root directory
This directory will be used exclusively my Jenkisn master to place remote files and create job workspace
You need to create a directory and give read/write/execute access to it
Execute:
$ cd /tmp
$ mkdir jenkinsdir
The path of root directory will be /tmp/jenkinsdir
give read/write/execute access to the root directory
$ chmod -R 777 /tmp/jenkinsdir
**********************************************
Setup on Jenkins master:
Go to manage jenkins → Configure system → Scroll down to jenkins location and change the Jenkisn URL to be the latest URL
http://3.147.195.251:8080/
Save the page
2. Manage jenkins → configure global security→ scroll down → Agents → select Random radio button
Save the page
Manage Jenkins – Manage nodes and Clouds
Click on + New node
Give node name: slave1
Select Permanent Agent
Click on create
Now give description : anything text
Number of executors: 1
Remote root directory: /tmp/jenkinsdir
Labels : slave1
Usage : select second option from dropdown
Launch method: launch agents via ssh
Host : private ip address of slave machine
Add credentials.
Scroll down to Node properties
Select tool location:
Click on ADD
Now go to slave server and execute command
$ which git
Path of git will be
/usr/bin/git
Now add Java
On slave execute : alternatives --config java
Give number of version 11 java
Copy the path of verison 11
Go to jenkins and paste the path
Windows Agent:
restart the instance.
Restart the jenkins server
now take public ip and loginto jenkins
Step 1: Go to Manage Jenkins ---> CONFIGURE SYSTEM ---> Check the Jenkins URL is same as URL of browser --> Save
Step 2: Go to Manage Jenkins---> CONFIGURE GLOBAL SECURITY --> Scroll down to AGENTS-->select RANDOM radiobutton--> Save
Step 3: Go to Manage Jenkins---> MAnage Nodes and Clouds --> New Node
Select New Node--> give name as Winslave--> select radio button permanamet Agent
Name : winslave
Description: give windows 10 machine
==> # of executors = 1 ==> means number of jobs that we want to run on this slave node. Let it be 1 for now
===> Remote root directory ==> C:\jenkinsdir
Location of a directory folder on your windows machine , so that jenkins can create a workspace folder and store all the files. As we have seen earlier while executiong jobs.
For this --> got to C drive and create an emapty folder.
C:\jenkinsdir
====> Label : win_slave ==> this is like a tag to slave machine. This is how we will identify the slave machine--> remeber this
===> Usage:
Select 2nd option: Only build jobs with label expressionmatching the job :
This means for which ever job we will give label as win_slave that job only will run on this job.
===> Launch Method : select option : Launch agent by connecting to master.
Scroll down
Add tools
Add git path as C:\Program Files\Git\cmd\git.exe
SAVE the job.
Now go to win_slave ==> download the agent.jar file and put it in your jenkinsdir folder.
Copy the path and change the public ip in below path
java -jar agent.jar -jnlpUrl http://3.139.60.71:8080/computer/winslave/slave-agent.jnlp -secret 61e8e20badd531b48caeffac8d686f182eb2d77a1c303ee39c5db9d00117c0be -workDir "C:\jenkinsdir"
Go to bash and start jenkins, refresh instance
Go to cmd prompt
change to cd c:\jenkinsdir
copy the above jenkins agent path
System will get connected.
***************************************
RUN a job on Agent
Go to Dashboard
Select the package job---> configure --> GENERAL --> click on Restrict where this project can be run and enter win_slave
SAVE THE JOB
CLICK on BUILD NOW -- to start the build
CLick on build number--> got to console --to check it is executing on AGent
Go to C folder-->jekinsdir---> C:\jenkinsdir\workspace\package\target==>
you will see addressbook.war file.