当前位置: 首页 > 工具软件 > Sonar > 使用案例 >

docker 安装 sonar

诸葛皓
2023-12-01

说明 文章参考
https://www.cnblogs.com/shenh/p/13428029.html

里面有几个地方照抄会出现问题注意

数据库拉取名字有问题
映射端口号主机 5432 禁用 使用较大的54321

postgresql
1.拉取 postgresql 镜像

docker pull postgre:latest

2.创建工作目录,为接下来的挂载自定义映射路径做准备

mkdir -p /home/sonar/postgres/postgresql
mkdir -p /home/sonar/postgres/data

3.创建网络

docker network create build-net

4.创建容器并运行

复制代码
docker run --name postgres -d -p 54321:5432 --net build-net
-v /home/sonar/postgres/postgresql:/var/lib/postgresql
-v /home/sonar/postgres/data:/var/lib/postgresql/data
-v /etc/localtime:/etc/localtime:ro
-e POSTGRES_USER=sonar
-e POSTGRES_PASSWORD=sonar
-e POSTGRES_DB=sonar
-e TZ=Asia/Shanghai
–restart always
–privileged=true
–network-alias postgres
postgres:latest
复制代码
-p 5432:5432:将容器 5432 映射到宿主机端口 5432
-v /home/sonar/postgres/postgresql:/var/lib/postgresql:将容器下的 /var/lib/postgresql 挂载到宿主机 /home/sonar/postgres/postgresql
-v /etc/localtime:/etc/localtime:ro:设置容器与宿主机时间一致
–e POSTGRES_USER=sonar:设置数据库用户名
-e POSTGRES_PASSWORD=sonar:设置数据库密码
-e POSTGRES_DB=sonar:新建db
-e TZ=Asia/Shanghai:设置时区
–restart always:容器退出时总是重启
–privileged=true:挂载主机目录Docker访问出现Permission denied的解决办法
–net sonarqube-tier:容器接入自定义网络
–network-alias mysql:给容器起个网络别名

二、安装 sonarQube
1.拉取镜像,我这里拉取的是 tag 是 7.4-community(7.6及以上的版本与 jenkins 的 sonar-scanner 插件暂时不兼容,以后官方会解决兼容问题)

docker pull sonarqube:7.4-community

2.创建工作目录

mkdir -p /data/sonarqube

3.修改系统参数

echo “vm.max_map_count=262144” > /etc/sysctl.conf
sysctl -p

4.运行一个test容器

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/

5.创建容器并运行

sonarQube + mysql
复制代码
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
复制代码

sonarQube + postgresql
方法一

复制代码
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:postgresql://postgres:54321/sonar”
–net sonarqube-tier
–privileged=true
–restart always
-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
复制代码
若这种方式出现连不上数据库 postgres 的问题,可参照第二种方法

方法二

1)找到 /data/sonarqube/conf/ 路径下的文件 sonar.properties,修改如下并保存

复制代码

找到如下配置去掉注释。并赋值 username,password

sonar.jdbc.username=sonar
sonar.jdbc.password=sonar

去掉 sonar.jdbc.url 注释,配置url

#----- PostgreSQL 9.3 or greater

sonar.jdbc.url=jdbc:postgresql://postgres:54321/sonar
复制代码
2)使用docker命令创建容器

复制代码
docker run -d --name sonar -p 9090:9000
–net build-net
–privileged=true
–restart always
-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
复制代码

6.浏览器输入http://ip:9090,开始初始化数据库,这个时间过程比较长,大概几分钟。初始化成功后进入登录界面,账号:admin 密码:admin

 类似资料: