卸载docker及其镜像方法+docker搭建代码质量检测平台sonarqube+maven方式扫描java代码...

本文主要是介绍卸载docker及其镜像方法+docker搭建代码质量检测平台sonarqube+maven方式扫描java代码...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  Sonar 是一个用于代码质量管理的开源平台,用于管理源代码的质量 通过插件形式,可以支持包括 java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy 等等。sonar服务搭建有很多种方式,本文介绍通过docker方式安装sonar服务器的流程,以供参考。

  1、本次所使用的服务器相关信息简单罗列

    服务器使用CenterOS 7(需连接互联网,本文使用yum方式安装,方便快捷),

    JDK版本为JDK11(sonar对JDK的支持从7.7之后均为JDK11)

  2、docker安装,依次执行如下命令

  • sudo yum install -y yum-utils \device-mapper-persistent-data \lvm2
    
  • sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo
    
  • sudo yum-config-manager --enable docker-ce-nightly  
    
  • sudo yum install docker-ce docker-ce-cli containerd.io
    

  3、安装docker-compose,依次执行如下命令

  • sudo curl -L "https://github.com/docker/compose/releases/download/1.26.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
    
    
  • sudo chmod +x /usr/local/bin/docker-compose
    

  4、安装sonar(本文使用版本为8.2,sonar定期对docker镜像文件进行更新,如需获取更多版本访问sonar镜像)

  安装前需启动docker服务

systemctl daemon-reloadsystemctl restart docker.service

  常用命令集合

启动 docker
systemctl start docker拉取 postgres 镜像
docker pull postgres拉取 sonarqube 镜像
docker pull sonarqube查看下载的镜像
docker images  

  然后使用命令docker-compose -f docker-compose.yml up

常用命令集合

构建并后台启动容器 docker-compose up -d查看运行容器 docker-compose ps 或 docker ps动态查看日志 docker-compose logs -f 或 docker logs -f sonar重启 docker-compose restart

  docker-compose.yml文件存放在服务器执行命令当前目录,该文件内容如下

version: "2"services:sonarqube:image: sonarqube:8.2-communitydepends_on:- dbports:- "9000:9000"networks:- sonarnetenvironment:SONAR_JDBC_URL: jdbc:postgresql://db:5432/sonarSONAR_JDBC_USERNAME: sonarSONAR_JDBC_PASSWORD: sonarvolumes:- sonarqube_data:/opt/sonarqube/data- sonarqube_extensions:/opt/sonarqube/extensions- sonarqube_logs:/opt/sonarqube/logs- sonarqube_temp:/opt/sonarqube/tempdb:image: postgresnetworks:- sonarnetenvironment:POSTGRES_USER: sonarPOSTGRES_PASSWORD: sonarvolumes:- postgresql:/var/lib/postgresql# This needs explicit mapping due to https://github.com/docker-library/postgres/blob/4e48e3228a30763913ece952c611e5e9b95c8759/Dockerfile.template#L52- postgresql_data:/var/lib/postgresql/datanetworks:sonarnet:driver: bridgevolumes:sonarqube_data:sonarqube_extensions:sonarqube_logs:sonarqube_temp:postgresql:postgresql_data:

  5、访问sonar及使用maven进行检查

    登录使用http://x.x.x.x:9000/
    用户名/密码:admin/admin

  maven检查可配置settings.xml文件,配置内容如下 

    <profile><id>sonar</id><activation><activeByDefault>true</activeByDefault></activation><properties><sonar.login>admin</sonar.login><sonar.password>admin</sonar.password><sonar.host.url>http://x.x.x.x:9000</sonar.host.url><sonar.inclusions>**/*.java</sonar.inclusions></properties>   </profile> <activeProfiles><activeProfile>sonar</activeProfile></activeProfiles>

  cmd到需要扫描工程目录下,首先需要所扫描工程通过maven编译,然后执行sonar扫描,依次执行如下命令

  • mvn clean install 
    // BUILD SUCCESS之后执行下条命令
  • mvn sonar:sonar
    // BUILD SUCCESS之后,浏览器访问sonar服务,扫描结果可能需要后台分析一会才会呈现出来。

  6、部分报错问题解决

  在安装及启动sonar服务的过程中,使用命令docker-compose -f docker-compose.yml up可查看后台打印信息,报错信息截取片段中存在如max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]

 临时解决方案

#当前为root用户可以使用命令解决
sysctl -w vm.max_map_count=262144
#如果不是root用户应该使用
sudo sysctl -w vm.max_map_count=262144

 终极解决方案

vim /etc/sysctl.conf
#添加配置
vm.max_map_count=262144
#使用命令使该设置生效
sysctl -p

  7、卸载docker

  1、查询docker安装过的包:

yum list installed | grep docker

       

  2、删除安装包:

yum remove docker-ce.x86_64 ddocker-ce-cli.x86_64 -y

  3、删除镜像/容器等

rm -rf /var/lib/docker

到此,docker安装sonar及maven扫描java代码就完成了,希望能对你有所帮助,感谢看官阅读,觉得有帮助留个赞哦。

这篇关于卸载docker及其镜像方法+docker搭建代码质量检测平台sonarqube+maven方式扫描java代码...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128153

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2