1.准备好编译环境的容器,所有容器的镜像制作在gemdale-dockerfile这个代码库里面,也可以直接拉取官方镜像部署
docker run --name node1420-patternx -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t node:14.20.0docker run --name node1615-patternx -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t node:16.15.1docker run --name nodejs1417-patternx -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t jelastic/nodejs:14.17.5-foreverFROM node:16.20.1-bullseye
docker run --name nodejs16 -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t linice/nodejs16:v1.1.0.0FROM golang:1.19.6-buster
docker run --name golang -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ -v /data/etc/cron.d/:/etc/cron.d/ -v /data/etc/supervisord.d/:/etc/supervisord.d/ -v /data/var/log/supervisor/:/var/log/supervisor/ --net host --restart always -d -t golang:1.19.6-bullseyeFROM node:14.20.0-buster
docker run --name nodejs14 -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t linice/nodejs14:v1.2.0.0FROM python:3.9.17-bullseye
docker run --name python39-testing -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t linice/python39-testing:v1.0.0.1FROM maven:3.8.6-openjdk-11
docker run --name maven3-openjdk11 -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t linice/maven3-openjdk11:v1.2.0.0FROM python:3.10.13-bullseye
docker run --name ansible --privileged -v /data/root/.ssh/:/root/.ssh/ -v /data/root/.tiup/:/root/.tiup/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ -v /data/ansible/:/data/ -v /data/etc/ansible/:/etc/ansible/ --restart always -d -t linice/ansible:v1.2.0.0FROM maven:3.8.6-openjdk-8
docker run --name maven3-openjdk8 -v /data/var/www/:/data/var/www/ -v /var/jenkins_home/:/var/jenkins_home/ -v /mnt/hgfs/:/mnt/hgfs/ --net host --restart always -d -t linice/maven3-openjdk8:v1.1.0.0
2.发布jenkins的shell执行脚本代码在仓库gemdale_jenkins
gemdale_jenkins
This project is parameterized
Choice Parameter 参数的名称这些参数作为环境变量公开用于构建
这个是定义项目脚本里面的变量
dr 默认是deploy部署脚本 可以选rollback回滚脚本
project ienjoys 项目变量
env test prod 环境变量
部署到服务器
实际部署的服务service是服务名称变量,gemdale_jenkins是实际服务名
代码分支
选择变量false,true:是否更新helm chart release. 默认为false, 即不更新.第一次执行要选true
回滚设置
bash /data/var/www/service/gemdale_jenkins/sourcecode/sourcecode.sh
#!/bin/bash
set -e #有报错就直接退出
######## define variables -- start ########
# current shell script file's directory
workdir=$(dirname $(readlink -f $0)) #当前文件所在的目录
######## define variables -- end ########
# arg
dr=${dr:-deploy} #-deploy等于jenkins设置的默认变量deploy
# comm_var
shell=$workdir/default/sourcecode-$dr.sh #设置一个变量
# exec
#执行变量脚本/data/var/www/service/gemdale_jenkins/default/sourcecode-$dr.sh
source $shell
source sourcecode-deploy.sh
#!/bin/bashecho 'renew my_tgt:'
rm -rf my_tgt
mkdir my_tgt######## define variables -- start ########
keep=20
######## define variables -- end ######### comm
#可无权限执行脚本/data/var/www/service/gemdale_jenkins/default/sourcecode-comm.sh
source $workdir/default/sourcecode-comm.sh# build_env
service_ws=$WORKSPACE
service_tgt_path=$service_wsecho 'compress service:'
cd $service_tgt_path
tgz_file=$service-${BUILD_ID}.tar.gz
tgz_file_path=$WORKSPACE/my_tgt/$tgz_file
tar --exclude=my_tgt -czf $tgz_file_path .# run
dest_tgz_file_path=$dest_d_dir/$service/$tgz_file
dest_d_path=$dest_d_dir/$service/$service-$BUILD_IDsource $workdir/default/sourcecode-run.shecho "on destination server: delete old tgz files and service directories, to keep last $keep services. -- start"
del_files=''
for ((i=$keep; i < $(($keep + 100)); i++)); doif (($BUILD_ID - $i <= 0)); thenbreak;fidel_files="$del_files $service-$(($BUILD_ID - $i)) $service-$(($BUILD_ID - $i)).tar.gz"
donedocker exec ansible ansible $rs -m shell -a "cd $dest_d_dir/$service && rm -rf $del_files"
echo "on destination server: delete old tgz files and service directories, to keep last $keep services. -- end"
source sourcecode-comm.sh
#!/bin/bash# comm_var
dest_dir=/data/var/www/service
dest_d_dir=/data/var/www/service.d
dest_path=$dest_dir/$service# env_service_var
case $env intest | uat )case $service inpatternx-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215,10.0.103.245,10.0.103.247,10.0.103.249};;carpark-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215};;gdimg-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215};;gdnb-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215};;gdr-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215};;gdyk-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215};;gemdale_charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215,10.0.103.245,10.0.103.247,10.0.103.249};;gemdale_jenkins )rs=${rs:-10.0.103.245,10.0.103.247,10.0.103.249};;gemdale-playbook )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215,10.36.21.224}echo ${rs};;pmc-charts )rs=${rs:-10.0.103.211,10.0.103.213,10.0.103.215,10.0.103.245,10.0.103.247,10.0.103.249};;esac;;prod )case $service inpatternx-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;ats-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;carpark-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;gdimg-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;gdnb-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;gdr-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;gdyk-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216};;gemdale_charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216,10.0.103.246,10.0.103.250};;gemdale_jenkins )rs=${rs:-10.0.103.246,10.0.103.250};;gemdale-playbook )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216,10.36.14.174};;pmc-charts )rs=${rs:-10.0.103.212,10.0.103.214,10.0.103.216,10.0.103.246,10.0.103.250};;esac;;
esac
source sourcecode-run.sh
#!/bin/bashecho 'on destination server, create directories:'
#在test70主机上创建一个名为testdir的目录,如果testdir目录已经存在,则不进行任何操作
docker exec ansible ansible $rs -m file -a "path=$dest_dir state=directory"
docker exec ansible ansible $rs -m file -a "path=$dest_d_path state=directory"echo 'scp tgz file to destination server:'
docker exec ansible ansible $rs -m copy -a "src=$tgz_file_path dest=$dest_d_dir/$service/"echo 'on destination server, decompress tgz file:'
docker exec ansible ansible $rs -m shell -a "tar -xzf $dest_tgz_file_path -C $dest_d_path/"echo 'on destination server, link to dest_path:'
docker exec ansible ansible $rs -m shell -a "ln -snf $dest_d_path $dest_path"