使用sonarQube可以帮助我们分析自己代码上的一些问题,能够及时发现解决问题。
一、搭建环境:
centos7.9 + docker + sonar7.6 + mysql5.7 + jdk1.8 + IEDA
1.1 docker安装可以参考我之前的文章:centos7 安装docker_震旦小读者的博客-CSDN博客
1.2 docker下安装mysql5.7
# 拉取镜像,指定mysql版本
docker pull mysql:5.7.36
# 运行容器
docker run -d -p 3306:3306 \
--privileged=true \
-v /app/mysql/log:/var/log/mysql \
-v /app/mysql/data:/var/lib/mysql \
-v /app/mysql/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=root \
--name mysql \
mysql:5.7.36
# 在/app/mysql/conf下新建 my.cnf,通过容器卷同步给mysql实例,解决中文乱码问题:
[client]
default_character_set=utf8
[mysqld]
collation_server = utf8_general_ci
character_set_server = utf8
# 重启mysql
docker restart mysql
1.3 docker安装sonarQube7.6
# 拉取sonarQube1.6社区版镜像
docker pull sonarqube:7.6-community
# 进入mysql容器并创建用户账户密码均为sonar
docker exec -it mysql bash
mysql -u root -p
create database sonar;
CREATE USER 'sonar'@'%' IDENTIFIED WITH mysql_native_password BY 'sonar';
GRANT ALL PRIVILEGES ON *.* TO 'sonar'@'%';
exit;
# 运行sonarQube容器
docker run -d --name sonarqube -p 9000:9000 -p 9092:9092 \
--link=mysql:mysql \
-e SONARQUBE_JDBC_USERNAME=sonar \
-e SONARQUBE_JDBC_PASSWORD=sonar \
-e SONARQUBE_JDBC_URL="jdbc:mysql://mysql:3306/sonar?
useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false" \
sonarqube:7.6-community
注意SONARQUBE_JDBC_URL的参数:jdbc:mysql://mysql:3306/sonar ,这里mysql替换了具体的ip,是在docker容器中,mysql容器的名字为mysql。否则,如果配了ip或者其他都会报连接不上mysql数据库的错误。
Please check connectivity and settings (see the properties prefixed by 'sonar.jdbc.').
1.4 sonarQube汉化
github上下载对应的汉化包:
https://github.com/xuhuisheng/sonar-l10n-zh/tree/sonar-l10n-zh-plugin-1.26
# 进入sonarQube容器
docker exec -it sonarqube bash
# 查看SONARQUBE_HOME配置
echo $SONARQUBE_HOME
结果: /opt/sonarqube
# 将jar包上传到 /opt/sonarqube/extensions/plugins/
# 退出docker容器模式,直接命令
docker cp /root/sonar-l10n-zh-plugin-1.26.jar sonarqube:/opt/sonarqube/extensions/plugins/
# 重启sonarQube容器
docker restart 容器ID
1.5 IEDA配置sonarLint及sonarQube
下载安装sonarLint插件
配置sonarQube服务器
maven项目配置sonar
org.sonarsource.scanner.maven
sonar-maven-plugin
3.6.0.1398
sonar
true
http://192.168.0.106:9000
maven下执行sonar:sonar等待执行结果。
二、进入ip:9000访问查看结果
三、IEDA自己的sonarLint检测
在IEDA中右键项目执行sonarLint分析,报错(暂时无解)
四、在之前我其实是已经在win10上尝试过安装sonarqube,但是真的是坑。
第一点:win版本关系sonar还必须进入任务管理器把三个java进程删掉才能再一次启动。
第二点:sonar7.8并不支持mysql8,可能我mysql版本8.0.**,比8.0大,配置mysql数据库后一致报mysql版本不适配的错误,直接闪退。
第三点:网上的资料参差不齐,不知道是不是真的有自己实践过的,总是有点问题,还是需要自己切身实践才行。