12-Docker-部署SonarQube


前言

  • 本篇来学习使用docker部署代码检测工具–SonarQube

简介

  • SonarQube: 是一款开源代码检测工具。本篇介绍通过 docker 来安装。大概的一个运作流程是这样的,先通过 sonar-scanner 插件扫描代码,把数据存储到数据库,sonarQube 读取数据库,将数据库展现在 web 平台。

安装MySQL

1. 拉取mysql 镜像
  • (sonarqube:7.4 不支持 mysql:5.7 以上)
docker pull mysql:5.7
2. 创建网络
docker network create sonarqube-tier
3. 创建并运行容器
  • 创建挂载目录
mkdir /usr/mysql
cd mysql
mkdir conf logs data
  • 执行下面命令启动容器
docker run --name mysql -d -p 3306:3306 --net sonarqube-tier -v /usr/mysql/conf:/etc/my.cnf.d -v /usr/mysql/logs:/logs -v /usr/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
--restart always \
--privileged=true \
--network-alias mysql \
mysql:5.7

参数说明

-p 3306:3306:将容器 3306 映射到宿主机端口 3306
-v /usr/mysql/conf:/etc/my.cof.d:将容器下的 /etc/my.cof.d 挂载到宿主机 /usr/mysql/conf
-e MYSQL_ROOT_PASSWORD=123456:设置 root 密码 123456
--restart always:容器退出时总是重启
--privileged=true:挂载主机目录Docker访问出现Permission denied的解决办法
--net sonarqube-tier:容器接入自定义网络
--network-alias mysql:给容器起个网络别名
  • 查是否正常运行:docker ps
4. 允许外网访问
  • 进入容器
docker exec -it mysql /bin/bash
  • 设置mysql访问权限
mysql -uroot -p  # 密码 123456
GRANT ALL ON *.* TO 'root'@'%';  #所有网络都可访问
create database sonar;     #创建 sonarqube 数据库

# 添加远程登录用户:sonar ,并授予权限。
CREATE USER 'sonar'@'%' IDENTIFIED WITH mysql_native_password BY 'sonar';  
GRANT ALL PRIVILEGES ON *.* TO 'sonar'@'%';

flush privileges;    # 刷新权限

安装SonarQube

1.拉取镜像
  • 7.6及以上的版本与 jenkins 的 sonar-scanner 插件暂时不兼容,我这里拉取的是7.4-community
docker pull sonarqube:7.4-community
2. 创建工作目录
mkdir -p /data/sonarqube
3.运行容器
docker run -d --name sonartest sonarqube:7.4-community
  • 复制容器内重要文件到宿主机
docker cp sonartest:/opt/sonarqube/conf /data/sonarqube
docker cp sonartest:/opt/sonarqube/data /data/sonarqube
docker cp sonartest:/opt/sonarqube/logs /data/sonarqube
docker cp sonartest:/opt/sonarqube/extensions /data/sonarqube
  • 删除容器
docker rm sonartest
  • 修改文件夹权限
chmod -R 777 /data/sonarqube/
4.创建容器并运行
docker run -d --name sonar -p 9090:9000 \
 -e ALLOW_EMPTY_PASSWORD=yes \
 -e SONARQUBE_DATABASE_USER=sonar \
 -e SONARQUBE_DATABASE_NAME=sonar \
 -e SONARQUBE_DATABASE_PASSWORD=sonar \
 -e SONARQUBE_JDBC_URL="jdbc:mysql://mysql:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false" \
 --net sonarqube-tier \
 --privileged=true \
 -v /data/sonarqube/logs:/opt/sonarqube/logs \
 -v /data/sonarqube/conf:/opt/sonarqube/conf \
 -v /data/sonarqube/data:/opt/sonarqube/data \
 -v /data/sonarqube/extensions:/opt/sonarqube/extensions\
 sonarqube:7.4-community
5.打开SonarQube页面
  • 浏览输入http://宿主机ip:9090
  • 初始账号和密码是admin
     在这里插入图片描述
6.安装中文插件
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱学习de测试小白

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值