背景:
顺序有点乱了在ci/cd过程中应该是先进行代码的静态扫描再去进行扫描镜像的呢,就佛系的写了。反正步骤都是独立的。这里写一下sonarqube的安装与集成,估计实践的我还要好好研究一下!
helm安装sonarqube
参照官方文档: https://docs.sonarqube.org/8.9/setup/sonarqube-on-kubernetes/
helm增加repo仓库
[root@k8s-master-01 helm]# helm repo add sonarqube https://SonarSource.github.io/helm-chart-sonarqube
[root@k8s-master-01 helm]# helm repo update
data:image/s3,"s3://crabby-images/bc00b/bc00bef2cce0c376e3d83a761839d58da300f1b0" alt="image.png"
helm fetch包到本地
[root@k8s-master-01 helm]# helm search repo sonarqube
[root@k8s-master-01 helm]# helm fetch sonarqube/sonarqube-lts
data:image/s3,"s3://crabby-images/d0c56/d0c56cfffc0acc59983dcf03bde299796db52c60" alt="image.png" 没有办法,墙裂…手动下载ing,rz上次到服务器
解压缩tgz包并修改value.yaml文件
[root@k8s-master-01 helm]# tar zxvf sonarqube-lts-1.0.20+140.tgz
data:image/s3,"s3://crabby-images/a6209/a6209d920ac587439c7a62f6ee6253863754f474" alt="image.png" data:image/s3,"s3://crabby-images/4d0ed/4d0ed71bfdad904fc69bd0224d79ae21a8126828" alt="image.png" value.yam就修改了存储storageclass:如下 data:image/s3,"s3://crabby-images/56489/5648933f6e257c0debfbc704e4b86f3f004a53e4" alt="image.png"
data:image/s3,"s3://crabby-images/55023/55023e44c686cceb6d9d42d5bb8bf59e6f8bf365" alt="image.png"
helm install安装sonarqube到kube-ops namespace
[root@k8s-master-01 sonarqube-lts]# helm install sonarqube -f values.yaml . -n kube-ops
data:image/s3,"s3://crabby-images/6622d/6622d9561da8fe6ffaac458343bfcdbdee1f5666" alt="image.png"
[root@k8s-master-01 anchore-engine1]# kubectl get svc -n kube-ops
[root@k8s-master-01 anchore-engine1]# kubectl get pods -n kube-ops
data:image/s3,"s3://crabby-images/a6632/a663285dcf6f8df295c1851fdde10c1797ddee4e" alt="image.png"
ingress对外映射
ingress使用的traefik,详情参照:Kubernetes 1.20.5 安装traefik在腾讯云下的实践
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: sonarqube-sonarqube-lts
namespace: kube-ops
annotations:
kubernetes.io/ingress.class: traefik
traefik.ingress.kubernetes.io/router.entrypoints: web
spec:
rules:
- host: sonarqube.xxxx.com
http:
paths:
- pathType: Prefix
path: /
backend:
service:
name: sonarqube-sonarqube-lts
port:
number: 9000
data:image/s3,"s3://crabby-images/213d4/213d4447e359d447712adb8ce553c9a64b5a0009" alt="image.png"
web登陆sonarqube验证
默认用户名密码admin admin(我蒙的),进去修改了密码 data:image/s3,"s3://crabby-images/e5d5a/e5d5aa1b8b67a5fc9caa8051de79c6b71eb753c1" alt="d992bfb411e25358ed409c5daa85277.png" data:image/s3,"s3://crabby-images/004f9/004f9f717fd4a780143e705ba35fec1c81801585" alt="image.png" 更改中文语言包(觉得换成中文真心不好,非必要的还是英文吧我觉得!) data:image/s3,"s3://crabby-images/18d23/18d2370993b5e3370cacd75b369a315a6d4a1d7d" alt="image.png" data:image/s3,"s3://crabby-images/d5714/d5714575d3844be6e7ec9fc64690bfc0bfca76c2" alt="image.png" 可能会无法从gitlab下载插件 pod log 日志报错如下 data:image/s3,"s3://crabby-images/84c77/84c7794a6c16852aad93ec2d1a2d84538ab2ff39" alt="image.png" 可以手动下载插件kubectl cp插件到pod /opt/sonarqube/extensions/plugins目录中,然后重启服务,重启服务可以在web操作 data:image/s3,"s3://crabby-images/5890d/5890d315c3fb84c7d700b300ff94910cc56068e4" alt="image.png" 默认语言的扫描插件应该新版本貌似都安装了: data:image/s3,"s3://crabby-images/f1976/f1976823d9d774d5169545d20354d9aec9a61ac8" alt="image.png" data:image/s3,"s3://crabby-images/c0ed0/c0ed0f2305b5d7f0b6bc0b78ff9add43e2b10fba" alt="image.png" 当然了 我的还是试了几次在线安装成功了 直接有了restart server的提示,然后重启server! data:image/s3,"s3://crabby-images/12522/125229cf98f810f9bba7016004a578da017b4a94" alt="image.png" 重新登陆,成功切换语言为中文 data:image/s3,"s3://crabby-images/15926/159265610cca2243e0175ace912eb2402948f85f" alt="image.png"
jenkins集成sonar
参照:https://docs.sonarqube.org/latest/analysis/scan/sonarscanner-for-jenkins/
创建SonaQube的账户token
data:image/s3,"s3://crabby-images/4e339/4e339a1f6aa77f8c803b112bde21b89fc2525c9f" alt="image.png"
将token保存到Jenkins凭据中
data:image/s3,"s3://crabby-images/6a86a/6a86a23ce77148a003b9671c2984f19e5abfa941" alt="image.png" ?
在Jenkins中安装插件sonarqube scanner。
data:image/s3,"s3://crabby-images/2f9bb/2f9bbfd8a819bf3f363b134ef0ea5a2767d16fbf" alt="62c2e9175211fac8d397c4bd96b54b8.png"
jenkins配置sonarqube服务器
转到"管理Jenkins>系统配置",向下滚动到SonarQube配置部分,单击Add SonarQube,添加服务器,选择凭据。
data:image/s3,"s3://crabby-images/ba326/ba326b4ba3dfc414b7af165de798ad4663ffe20c" alt="image.png"
[root@k8s-master-01 anchore-engine1]# kubectl cp sonar-gitlab-plugin-4.1.0-SNAPSHOT.jar sonarqube-sonarqube-lts-0:/opt/sonarqube/lib/extensions/sonar-gitlab-plugin-4.1.0-SNAPSHOT.jar -n kube-ops
Defaulted container "sonarqube-lts" out of: sonarqube-lts, wait-for-db (init), init-sysctl (init), inject-prometheus-exporter (init)
[root@k8s-master-01 anchore-engine1]# kubectl exec -it sonarqube-sonarqube-lts-0 bash -n kube-ops
kubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a future version. Use kubectl exec [POD] -- [COMMAND] instead.
Defaulted container "sonarqube-lts" out of: sonarqube-lts, wait-for-db (init), init-sysctl (init), inject-prometheus-exporter (init)
bash-5.0$ cd /opt/sonarqube/lib/extensions/
bash-5.0$ ls
sonar-csharp-plugin-8.22.0.31243.jar sonar-go-plugin-1.8.3.2219.jar sonar-javascript-plugin-7.4.4.15624.jar sonar-ruby-plugin-1.8.3.2219.jar
sonar-css-plugin-1.4.2.2002.jar sonar-html-plugin-3.4.0.2754.jar sonar-kotlin-plugin-1.8.3.2219.jar sonar-scala-plugin-1.8.3.2219.jar
sonar-flex-plugin-2.6.1.2564.jar sonar-jacoco-plugin-1.1.1.1157.jar sonar-php-plugin-3.17.0.7439.jar sonar-vbnet-plugin-8.22.0.31243.jar
sonar-gitlab-plugin-4.1.0-SNAPSHOT.jar sonar-java-plugin-6.15.1.26025.jar sonar-python-plugin-3.4.1.8066.jar sonar-xml-plugin-2.2.0.2973.jar
我的jenkins build节点
我的jenkins是部署在kubernetes集群中的,嗯集群的cri用了containerd…故构建我用了一台单独的服务器安装了docker做build节点使用了jnlp的方式启动一个jar程序包!,嗯主机节点命名是build01。 个人习惯 build(嗯算是soft软件吧)的包都扔到/data/ci/buildtools目录下了,改名也是个人习惯忽略…
[root@k8s-node-06 buildtools]# pwd
/data/ci/buildtools
[root@k8s-node-06 buildtools]# wget https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-cli-4.6.2.2472-linux.zip
[root@k8s-node-06 buildtools]# unzip sonar-scanner-cli-4.6.2.2472-linux.zip
[root@k8s-node-06 buildtools]#mv sonar-scanner-cli-4.6.2.2472-linux.zip sonar-scanner
修改/etc/profile加入环境
vim /etc/profile
export SONAR_SCANNER_HOME=/data/ci/buildtools/sonar-scanner
export PATH=$SONAR_SCANNER_HOME/bin:$PATH
source /etc/profile
data:image/s3,"s3://crabby-images/c85f5/c85f5d42eea66074a35f70b90368b3dd53438448" alt="6f3d74e0806848a4f43d0e4b7b5cd27.png" 关于sonar-scanner默认的jdk是11,代码都是java8…有必要修改一下… data:image/s3,"s3://crabby-images/d0cc4/d0cc4d43d0a762bd0a9ce12e4e6f14743d31ba4b" alt="7c9278674012cd058ca94dac3aca500.png" use_embedded_jre=true修改为false data:image/s3,"s3://crabby-images/a8f3b/a8f3bba374ad41f157357b8f750e6579968aa7b6" alt="image.png" 注:当然了前提我的服务器server早安装了java8,毕竟jenkins跑起来了早…,参加/etc/profile中java配置 data:image/s3,"s3://crabby-images/a0fe9/a0fe9bbc534f41c2240e36d08a62652a3dc83e40" alt="image.png"
sonar pipeline demo
搞一个java的demo
gitlab中仓库以及测试代码
登陆https://start.spring.io/ 生成一个jar包: data:image/s3,"s3://crabby-images/575dd/575dda06eccae7d20655f8f126f5080352e8902d" alt="image.png" 下载到本地上传到自己的gitlab仓库:https://gitlab.xxxx.com/devops/devops-maven-service: data:image/s3,"s3://crabby-images/ae4f7/ae4f7ba958568a126693516d781739369be100af" alt="image.png" 额外扔了一个jenkinsfile,当然了 也可以直接jenkins中Pipeline script
def buildTools = ["maven": "/usr/local/maven/",
"sonar" : "/data/ci/buildtools/sonar-scanner/"]
pipeline {
agent { label "build01" }
options {
skipDefaultCheckout true
}
stages {
stage("GetCode"){
steps{
script{
println("下载代码 --> 分支: ${env.branchName}")
checkout([$class: 'GitSCM', branches: [[name: "${env.branchName}"]],
extensions: [],
userRemoteConfigs: [[credentialsId: 'gitlab-admin-user',
url: "${env.gitHttpURL}"]]])
}
}
}
stage("Build"){
steps {
script {
//sh "/usr/local/maven/bin/mvn clean package"
sh "${buildTools["maven"]}/bin/mvn clean package"
}
}
}
stage("SonarScanForPlugin"){
steps{
script{
withSonarQubeEnv("sonarqube-1"){
def sonarDate = sh returnStdout: true, script: 'date +%Y%m%d%H%M%S'
sonarDate = sonarDate - "\n"
sh """
${buildTools["sonar"]}/bin/sonar-scanner \
-Dsonar.projectKey=${JOB_NAME} \
-Dsonar.projectName=${JOB_NAME} \
-Dsonar.projectVersion=${sonarDate} \
-Dsonar.ws.timeout=30 \
-Dsonar.projectDescription="my test project" \
-Dsonar.links.homepage=http://www.baidu.com \
-Dsonar.sources=src \
-Dsonar.sourceEncoding=UTF-8 \
-Dsonar.java.binaries=target/classes \
-Dsonar.java.test.binaries=target/test-classes \
-Dsonar.java.surefire.report=target/surefire-reports \
#echo \$PATH
"""
}
}
}
}
stage("UnitTest"){
steps{
script{
sh "${buildTools["maven"]}/bin/mvn test"
}
}
post {
success {
script{
junit 'target/surefire-reports/*.xml'
}
}
}
}
}
post {
always {
script{
echo "always......"
}
}
success {
script {
echo "success....."
}
}
}
}
关于jenkins job
jenkinsfile中用了参数化构建,先把这两个参数搞上了,另外新点的gitlab中分支都叫main了,不再是master了。也注意一下: data:image/s3,"s3://crabby-images/2e916/2e9166d364ec91adecb4f9d3385c28e6ad90a004" alt="image.png" data:image/s3,"s3://crabby-images/2affe/2affe164b8adaae608a6da4066cb4e11325e7b4b" alt="image.png"
构建任务
构建完成发现一个问题:jenkins配置sonarqube服务器的过程中我写的集群内的内网地址。然后这样sonar的连接点开都无法跳转,所以我将sonarqube的服务器配置最后设置为了公网地址: data:image/s3,"s3://crabby-images/ae06d/ae06d006e4ca79f9f5b9f3f04676c283944ed650" alt="image.png" ?
data:image/s3,"s3://crabby-images/b8543/b8543265b6227e6a27cf47df7cd3d2e319e16163" alt="image.png" data:image/s3,"s3://crabby-images/f086b/f086bcce9c33abf8789a7e86c438e619ef1ef1ae" alt="image.png" 空白demo没有什么太大看的就先跑通一下。后续再整合看看怎么优化,因为自己的项目也都是聚合项目要看一下怎么去玩一下!
php项目
我其他的项目大部分是php了也扫描一下试试吧!这个仓库比较坑下面有7-8个子项目,我平时做的是参数化构建的。这里就摘出来一个做测试 data:image/s3,"s3://crabby-images/985f3/985f397f0260d200833e4981fe6f5eb689df21bb" alt="image.png" data:image/s3,"s3://crabby-images/973ea/973ea1f824363c04afeaa691277bb7643b583808" alt="image.png"
def buildTools = ["maven": "/usr/local/maven/",
"sonar" : "/data/ci/buildtools/sonar-scanner/"]
pipeline {
agent { label "build01" }
stages {
stage("GetCode"){
agent { label "build01" }
steps{
script{
println("下载代码 --> 分支: ${env.branchName}")
checkout([$class: 'GitSCM', branches: [[name: "${env.branchName}"]],
doGenerateSubmoduleConfigurations: false,
extensions: [[$class: 'CloneOption', depth: 1, noTags: false, reference: '', shallow: true]],
submoduleCfg: [],
userRemoteConfigs: [[credentialsId: 'xxxxx',
url: "${env.gitHttpURL}"]]])
}
}
}
stage("SonarScanForPlugin"){
agent { label "build01" }
when {
environment name: 'xxxx', value: 'true'
}
steps{
script{
withSonarQubeEnv("sonarqube-1"){
def sonarDate = sh returnStdout: true, script: 'date +%Y%m%d%H%M%S'
sonarDate = sonarDate - "\n"
sh """ cd xxxx/html
${buildTools["sonar"]}/bin/sonar-scanner \
-Dsonar.projectKey=${JOB_NAME}-xxxxx \
-Dsonar.projectName=${JOB_NAME}-xxxx \
-Dsonar.projectVersion=${sonarDate} \
-Dsonar.ws.timeout=30 \
-Dsonar.language=php \
-Dsonar.projectDescription="my php project" \
-Dsonar.sources=. \
-Dsonar.sourceEncoding=UTF-8 \
#echo \$PATH
"""
}
}
}
}
stage('docker build laya-maker') {
agent { label "build01" }
when {
environment name: 'xxxx', value: 'true'
}
steps {
sh " cd laya-maker&&docker build -t ccr.ccs.tencentyun.com/xxxxx/xxxx:$data ."
withCredentials([usernamePassword(credentialsId: 'xxxxx', passwordVariable: 'dockerPassword', usernameVariable: 'dockerUser')]) {
sh "docker login -u ${dockerUser} -p ${dockerPassword} ccr.ccs.tencentyun.com"
sh "docker push ccr.ccs.tencentyun.com/xxxxx/xxxx:$data"
}
}
}
}
}
运行基本就是下面这个样子: data:image/s3,"s3://crabby-images/309ea/309ea43e5fa9ff9b8472d1a909189aaf8372f13c" alt="image.png" 有点懵逼哈哈哈。 data:image/s3,"s3://crabby-images/16e0f/16e0f83c90b4ac50148e1ed5d16a4d20551585c8" alt="image.png" 看了一眼漏洞这样的基本都可以忽略。有时间研究一下怎么深入使用! data:image/s3,"s3://crabby-images/2bce4/2bce4ce5e43a805817854ae46deb82d126216b1f" alt="image.png"
讲一下比较刺激的
扫了一下线上java仓库的代码,小伙伴都不加method = {RequestMethod.GET, RequestMethod.POST})这样的?,前段时间无聊看别人写的java代码 安全性来说 这不是规范吗…请原谅一下我们这些野生的…看不下去了… data:image/s3,"s3://crabby-images/2324f/2324f0ee6d18a28e1bc6a9a91ed13c85cc7f3245" alt="image.png"
总结:
本文着重于安装以及配置。实战要深入研究一下,也希望小伙伴能分享一下更多实战的例子让我学习一下… ?
|