Compare commits

..

No commits in common. "6c98db347369c3ddf9232da22c44a71156a64884" and "8f3d69ef5671480d8f685e3b2934f47739a49fef" have entirely different histories.

3 changed files with 84 additions and 118 deletions

179
Jenkinsfile vendored
View File

@ -1,115 +1,84 @@
pipeline {
agent {
label 'pi501.in.thelinuxpro.net'
}
stages {
stage("verify tooling") {
steps {
sh '''
docker version
docker info
docker compose version
'''
}
}
stage("Build Containers and push to registry") {
steps {
script {
def status_p = sh(returnStatus: true, script: 'docker images | grep bind9-primary | grep $(grep image docker-compose.yml | grep primary | awk -F\':\' \'{ print $4 }\')')
def status_s = sh(returnStatus: true, script: 'docker images | grep bind9-secondary | grep $(grep image docker-compose.yml | grep secondary | awk -F\':\' \'{ print $4 }\')')
if (status_p != 0) {
sh 'docker compose build primary --push'
} else {
echo "Primary Image version already exists, no need to rebuild."
}
if (status_s != 0) {
sh 'docker compose build secondary --push'
} else {
echo "Secondary Image version already exists, no need to rebuild."
}
agent {
label 'pi501.in.thelinuxpro.net'
}
}
}
stage('Stop primary container') {
steps {
script {
if (status_p != 0) {
sh 'docker compose down'
sh 'sleep 5'
}
}
}
}
stages {
stage("verify tooling") {
steps {
sh '''
docker version
docker info
docker compose version
'''
}
}
stage('Start primary container') {
steps {
script {
if (status_p != 0) {
sh 'docker compose down'
sh 'docker compose up -d --no-color primary'
sh 'docker compose ps'
}
}
}
}
stage("Build Containers and push to registry") {
steps {
sh 'docker compose build --push'
}
}
stage('Create contexts') {
steps {
sh 'docker context ls | grep pi502 || docker context create pi502 --docker "host=ssh://pi502.in.thelinuxpro.net"'
}
}
stage('Stop primary container') {
steps {
sh 'docker compose down'
sh 'sleep 5'
}
}
stage('Stop secondary container') {
steps {
script {
if (status_s != 0) {
sh 'docker --context pi502 compose down'
sh 'sleep 5'
}
}
}
}
stage('Start primary container') {
steps {
sh 'docker compose down'
sh 'docker compose up -d --no-color primary'
sh 'docker compose ps'
}
}
stage('Start secondary container') {
steps {
script {
if (status_s != 0) {
sh 'docker --context pi502 compose up -d --no-color secondary'
sh 'docker --context pi502 compose ps'
}
}
}
}
stage('Create contexts') {
steps {
sh 'docker context ls | grep pi502 || docker context create pi502 --docker "host=ssh://pi502.in.thelinuxpro.net"'
}
}
stage('test primary dns') {
steps {
sh 'dig ns1.thelinuxpro.net ANY @204.8.15.80'
sh 'dig ns1.in.thelinuxpro.net ANY @10.99.153.241'
sh 'dig ns1.thelinuxpro.net ANY @204.8.15.81'
sh 'dig ns1.in.thelinuxpro.net ANY @10.99.153.242'
sh 'dig kameronkenny.com @204.8.15.80 a'
sh 'dig kameronkenny.com @10.99.153.241 a'
sh 'dig kameronkenny.com @204.8.15.81 a'
sh 'dig kameronkenny.com @10.99.153.242 a'
}
}
stage('Stop secondary container') {
steps {
sh 'docker --context pi502 compose down'
sh 'sleep 5'
}
}
stage('verify SOA serial') {
steps {
sh 'dig +multi ns1.thelinuxpro.net ANY @204.8.15.80 soa'
sh 'dig +multi ns1.in.thelinuxpro.net ANY @10.99.153.241 soa'
sh 'dig +multi ns1.thelinuxpro.net ANY @204.8.15.81 soa'
sh 'dig +multi ns1.in.thelinuxpro.net ANY @10.99.153.242 soa'
sh 'dig +multi kameronkenny.com @204.8.15.80 soa'
sh 'dig +multi kameronkenny.com @10.99.153.241 soa'
sh 'dig +multi kameronkenny.com @204.8.15.81 soa'
sh 'dig +multi kameronkenny.com @10.99.153.242 soa'
}
}
}
stage('Start secondary container') {
steps {
sh 'docker --context pi502 compose up -d --no-color secondary'
sh 'docker --context pi502 compose ps'
}
}
stage('test primary dns') {
steps {
sh 'dig ns1.thelinuxpro.net ANY @204.8.15.80'
sh 'dig ns1.in.thelinuxpro.net ANY @10.99.153.241'
sh 'dig ns1.thelinuxpro.net ANY @204.8.15.81'
sh 'dig ns1.in.thelinuxpro.net ANY @10.99.153.242'
sh 'dig kameronkenny.com @204.8.15.80 a'
sh 'dig kameronkenny.com @10.99.153.241 a'
sh 'dig kameronkenny.com @204.8.15.81 a'
sh 'dig kameronkenny.com @10.99.153.242 a'
}
}
stage('verify SOA serial') {
steps {
sh 'dig +multi ns1.thelinuxpro.net ANY @204.8.15.80 soa'
sh 'dig +multi ns1.in.thelinuxpro.net ANY @10.99.153.241 soa'
sh 'dig +multi ns1.thelinuxpro.net ANY @204.8.15.81 soa'
sh 'dig +multi ns1.in.thelinuxpro.net ANY @10.99.153.242 soa'
sh 'dig +multi kameronkenny.com @204.8.15.80 soa'
sh 'dig +multi kameronkenny.com @10.99.153.241 soa'
sh 'dig +multi kameronkenny.com @204.8.15.81 soa'
sh 'dig +multi kameronkenny.com @10.99.153.242 soa'
}
}
}
}

View File

@ -18,7 +18,7 @@ services:
container_name: ns1
build:
dockerfile: Dockerfile.primary
image: docker-registry1.in.thelinuxpro.net:5000/tlp/bind9-primary:240515.2.2
image: docker-registry1.in.thelinuxpro.net:5000/tlp/bind9-primary:240515.2.1
restart: always
user: root
environment:

View File

@ -1,19 +1,16 @@
$ORIGIN net.
$TTL 2m
thelinuxpro IN SOA ns1.thelinuxpro.net. root.thelinuxpro.net. (
24051502 ; serial number YYMMDDNN
1h ; Refresh
15m ; Retry
10d ; Expire
1d ; Min TTL
@ IN SOA thelinuxpro.net. root.thelinuxpro.net. (
24051501 ; serial number YYMMDDNN
1h ; Refresh
15m ; Retry
10d ; Expire
1d ; Min TTL
)
;
IN NS ns1.thelinuxpro.net.
IN NS ns2.thelinuxpro.net.
IN TXT "The Linux Pro Net"
;
$ORIGIN thelinuxpro.net.
NS ns1.thelinuxpro.net.
NS ns2.thelinuxpro.net.
TXT "The Linux Pro Net"
;
ns1 IN A 204.8.15.80
ns2 IN A 204.8.15.81