Agenda
- Introduction
- What is oVirt
- Basic view of oVirt Infrastructure
- Release flow
- Gerrit hooks
- Jenkins jobs types
- Jenkins jobs builder
- Publishing builds to a repository server
- Future plans
- Questions
Introduction
- Who are we ?
Kiril Nesenko - Infrastructure Maintainer and release engineer. Responsible for release engineering activities for oVirt project.
Eyal Edri - Infrastructure Maintainer at oVirt and CI team lead at Red Hat.
WHAT IS OVIRT
- oVirt is a virtual data center manager
- Delivers powerful management of multiple virtual machines on multiple hosts
- Uses KVM, libvirt and vdsm.
- Can be installed on Fedora, CentOS or RHEL
data:image/s3,"s3://crabby-images/ebeb9/ebeb976e1311eeb693b8ed3e1e0339a63cd58331" alt=""
ovirt architecture
OVIRT UI
data:image/s3,"s3://crabby-images/5909b/5909b32b5941a63188ed669fb1b7a72f0b82021d" alt=""
ovirt infrastructure view
data:image/s3,"s3://crabby-images/b94d6/b94d6853cd70ce991b24bbf589ca95e35bb20a35" alt=""
services
data:image/s3,"s3://crabby-images/12526/12526475efcc7cd04cf63648b81156e64d8c8830" alt=""
data:image/s3,"s3://crabby-images/5602c/5602ccd93c7eb40b30d324b6b68b57345b52dfd3" alt=""
data:image/s3,"s3://crabby-images/edbaf/edbafa69abeb62f235a34cb4e8294cfb76849fa4" alt=""
data:image/s3,"s3://crabby-images/df798/df7980baf2bd9623b58fa1216f0232ac339a8f0b" alt=""
data:image/s3,"s3://crabby-images/8e540/8e54088b36c8d36095cdf9339c2eec7864b9fdf7" alt=""
- Provisioning: Foreman
- Configuration: Puppet
- Artifacts (mirror): Artifactory
- Source Control: git
- Code Review: gerrit
- CI: Jenkins
- Slaves: VMs + Bare Metal hosts
- Virtualization: oVirt, OpenStack
data:image/s3,"s3://crabby-images/2c8d6/2c8d6f210434b4e168186b29fb51b3e228650745" alt=""
RELEASE PROCESS
data:image/s3,"s3://crabby-images/cc08d/cc08d6e0de3b1002a47af916ec5237c0627de9a1" alt=""
commit life cycle
data:image/s3,"s3://crabby-images/4d177/4d177dc693404bc2e5b3fc5b91c340d18186a202" alt=""
ovirt continuous delivery
- One publisher per version
- Use a generic script to publish the builds
data:image/s3,"s3://crabby-images/30ccc/30ccc851d350160c4cec282a15b523efd9309746" alt=""
publisher job
data:image/s3,"s3://crabby-images/3bd6b/3bd6b1b26ae67ac741f35aa4e12b322af160e196" alt=""
publisher job
data:image/s3,"s3://crabby-images/ea782/ea78283bfb34fc92adf52522c811f86ebf8d6d07" alt=""
gerrit
What is Gerrit?
data:image/s3,"s3://crabby-images/326bf/326bfd16d89a6f0b7769dff95952d657ceb1e3d4" alt=""
data:image/s3,"s3://crabby-images/0bb50/0bb50ed4296d10a8db91b2c22c7706db8e20f61d" alt=""
GERRIT: gitweb
Code hosting (git frontend)
data:image/s3,"s3://crabby-images/0d05b/0d05bfabdd16a3cc1c96a5b27b7cb1f9a3033fc6" alt=""
GERRIT HOOK
What is a hook?
For each workflow step (event) a script gets executed
data:image/s3,"s3://crabby-images/bba0c/bba0cc05bd0e669bee6dff11b44064170673fa02" alt=""
Gerrit HOOKS
Default gerrit hooks flaws:
- 1 event <-> 1 hook
- Same hook for all projects
- Fire and forget, no interaction
Solution:
Build a dispatcher!
GERRIT HOOKS: TRIgger
- Patch Created
- Comment Added
- Change Merged
- Change Abandoned
- Reference updated
- (more on newer versions)
data:image/s3,"s3://crabby-images/e92c1/e92c1519f542ad74f78004be00833a85c6f56a3b" alt=""
GERRIT HOOKS: EVENT type
- By parameters passed
-
We will be able to detect
- Maintainer approved
- Tests passed
- Maintainer blocked
- ...
data:image/s3,"s3://crabby-images/eebeb/eebeb25adf911d3f89c71c83260ec5b7d9fd514b" alt=""
GERRIT HOOKS: Labels
What?
Label: label content
Where?
Commit message
Comment
Example:
Bug-Url: http://mytracker/bugid
Rerun-Hooks: all
data:image/s3,"s3://crabby-images/32d67/32d67dad040c0ef9d751dd896bb2f665d1da9191" alt=""
GERRIT HOOKS: CHAINS
- Using event name
- Chain as second term if wanted
- Hierarchical config files
- Main one at $gerrit_dir
- Per project
- Per event
Hook name template:
${event}.${chain}.${hook_name}
${event}.${hook_name}
${event}
data:image/s3,"s3://crabby-images/bd3b0/bd3b0f637550b3ffde6128dcf75b72db9e89dff6" alt=""
GERRIT HOOKS: EXECUTION
INFO::STARTING::change-merged
DEBUG::get_hooks::change-merged on vdsm.git/hooks
INFO::::AVAILABLE HOOKS::[
'change-merged.set_MODIFIED',
'change-merged.update_tracker']
Each hook can:
- Break it's hook chain
- Break whole execution
Everything to logfile (configurable):
Common stdout format (each section is optional):
V:VERIFIED SCORE\n
R:REVIEW SCORE\n
COMMENT
data:image/s3,"s3://crabby-images/931f1/931f17bb0ad52eb7500e372d3e2fcfd02b4a896c" alt=""
GERRIT HOOKS: REVIEW
Sum of all the reviews:
- negative ones prevail over positives
- no vote means no change
- 0 means reset negative value
data:image/s3,"s3://crabby-images/e9905/e9905fb35f2a078201e42c714e5438470b2749dc" alt=""
Execution summary of all the hooks:
data:image/s3,"s3://crabby-images/437db/437dbdd19ed1ca3428d2d78a9e92aff66cbfcec4" alt=""
GERRIT HOOKS: Source CODE
Patches are always welcome!
- Git:
- git clone git://gerrit.ovirt.org/gerrit-admin
- Web:
- http://gerrit.ovirt.org/gitweb?p=gerrit-admin.gi t
data:image/s3,"s3://crabby-images/15f85/15f8590fbee7e48381ba8e699a250f73a4585df6" alt=""
GERRIT HOOKS: LIBS
Some simple generic libs available for the hooks:
- Bugzilla
- Gerrit
- Configuration
- Tools
source bz.sh
source gerrit.sh
gerrit.parse_params "$@" # Sets the parameters into global vars
# get the bug ids in the commit message of the commit passed as
# parameter (--commit SHA)
bug_ids=($(bz.get_bug_id "$commit"))
from gerrit import Gerrit
from config import load_config
config = load_config() ## Loads the config hierarchicaly into a dict
gerrit = Gerrit(config.get('GERRIT_SRV')) ## Connect to the gerrit instance
GERRIT HOOKS: BUGZILLA
Update external tracker in bugzilla
data:image/s3,"s3://crabby-images/020fb/020fb7f46b3a1b0989d0b4a54444bba2e5724559" alt=""
Modify bug status when first patch sent
data:image/s3,"s3://crabby-images/4987d/4987dc72923f9c2d5a2a969c5dedec1581d75b31" alt=""
Modify bug status when all patches merged
data:image/s3,"s3://crabby-images/fc7f7/fc7f7b3dce2933e71a7b2fbd4526a4e29b349364" alt=""
Jenkins job builder
Problems with manual configuration
- Hard to maintain
- Hard to track
- Hard to review
- Hard to change common settings
...
Add an extra scm to jobs for projects A, B and C
New branch for project M, duplicate all it's jobs
Disable all the jobs for a project
Test a job configuration before deploying
Jenkins job builder
data:image/s3,"s3://crabby-images/3e02e/3e02e9b8d25c9533d8016f2ada26c377b456dcf0" alt=""
Jenkins job Builder to the rescue!
jenkins job builder
Some plugins that helped along the way:
- Configuration deduplication:
Matrix configurations
- Multijobs config changes:
Configuration slice
- Configuation change management:
Job Config history
- Manage jobs statuses:
Scriptler
Jenkins job builder
- Developed by OpenStack folks (Kudos!!)
- Configuration as code (yaml format)
- Easy to review changes (on Gerrit!)
- Code/config de-duplication
- Include external shell/groovy/... scripts
- Test before deploying
- Easier to organize (per directory, per file)
- Serves as backup (easily replicate on another jenkins)
Jenkins job builder
- This will create the jobs:
- projectA-whatever-fc19
- projectA-whatever-fc20
- job-group:
name: projectA
dist:
- fc19
- fc20
jobs:
- '{name}-wahtever-{dist}'
- job-template:
name: '{name}-whatever-{dist}'
node: 'slave-{dist}'
triggers:
- timed: '@midnight'
builders:
- shell: make whatever
publishers:
- archive:
artifacts: '*.log'
On slave-fc19 and slave-fc20
Executing 'make whatever'
Archiving the logs
Jenkins job builder
Oh! But I want to add a new distro, el6
- job-group:
name: projectA
dist:
- fc19
- fc20
- el6
jobs:
- '{name}-wahtever-{dist}'
And a cleanup after
- job-template:
name: '{name}-whatever-{dist}'
node: 'slave-{dist}'
triggers:
- timed: '@midnight'
builders:
- shell: make whatever
- shell: make clean
publishers:
- archive:
artifacts: '*.log'
Jenkins job builder
Official Openstack links:
Docs:
Code:
oVirt links
ovirt jenkins job types
- Triggered only on patch sets
- Triggered only on merges
- Matrix jobs
- COPR jobs
poll scm vs gerrit trigger
- We use gerrit trigger plugin instead of poll SCM
- Allows to test patches before merge
- Reduces the load on the gerrit server
data:image/s3,"s3://crabby-images/fc062/fc0627a18cf51eb773fd13fc46b274ce41ebfd18" alt=""
matrix jobs
- Allows to configure the jobs to run on different configurations
data:image/s3,"s3://crabby-images/0e084/0e084e2acfa54f9444bc3aa1a9c09d6f742571c9" alt=""
matrix reloadeD
-
Allows to rerun the job on a specific configuration
data:image/s3,"s3://crabby-images/2e243/2e2436f5441876e8d5ac88a7f61a4fd1d5a14a28" alt=""
copr
- Created by Fedora folks
- Is an easy to use automatic build system providing a package repository as its output
- Reduces the load on jenkins slaves
- CLI + Jenkins plugin
yum -y install copr-cli
copr-cli build vdsm http://jenkins.ovirt.org/view/vdsm-4.14.10-11.git1081e76.el6.src.rpm
copr jenkins plugin
data:image/s3,"s3://crabby-images/58d6a/58d6aa1c816dce5f425906c0fe7aae22a5682cfa" alt=""
release process
data:image/s3,"s3://crabby-images/ec78b/ec78bdb9790d81be55f2899d020bf679b96194a7" alt=""
Current problems/future solutions
Scarce resources
- Moving to a new infrastructure
- OS1 (openstack) slaves
Jobs management and control
- Move all jobs to yaml
- Get developers to help write/maintain jobs
Leverage manual procedures
- Automate the official release + signing packages
- Automate gerrit config/project creation
Current problems/future solutions
Isolate test environments
- Docker/mock on all simple builds
- One slave per job on complex builds
-
Provisioning of slaves on demand
Leverage package builds
- Build on Copr (has jenkins plugin!)
questions ?
data:image/s3,"s3://crabby-images/f9e4c/f9e4c2a35721da76279d1826ab2362cbf2b19e2e" alt=""
useful Links
contact us
data:image/s3,"s3://crabby-images/a1c1b/a1c1ba4944cf103cc9476cb758ced9858940a71b" alt=""
jenkins_conference_2014
By Kiril Nesenko
jenkins_conference_2014
- 2,948