Centos 7 docker 安装代码检测工具Sonarqube和Cppcheck

2023-10-10 08:59

本文主要是介绍Centos 7 docker 安装代码检测工具Sonarqube和Cppcheck,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

各位朋友,下面我Centos 7 docker 安装代码检测工具Sonarqube和cppcheck等过程放在这里,供大家参考。

首先安装CentOs 7

docker pull Jenkins/jenkins:lts

mkdir  /home/jenkins

修改目录执行权限

chown -R 1000:1000 jenkins/    uid1000的权限

ls -nd jenkins/                  查看文件权限

 

docker设定执行权限

docker run -itd -p 9090:8080 -p 50000:50000 --name jenkins --privileged=true  -v /home/jenkins:/var/jenkins_home jenkins:latest

 

浏览器输入  http://你的ip地址:8080 即可访问Jenkins

通过浏览器端可以重新启动jenkins

http://localhost:8080/restart/exit/reload

通过服务启动/停止/重启  Jenkins

service Jenkins start/stop/restart

首次启动Jenkins后,需要一个安全密码设定

安装过程中,密码放在了下面路径中,使用cat查看密码,拷贝出密码到上面界面中。

进入之后需要输入密码,在命令行使用如下命令获取密码

cat /home/jenkins/secrets/initialAdminPassword        查看密码

即可进入下面页面:

为Jenkins创新一个用户

配置访问url

祝贺你,如看到下面界面,你现在可以开启Jenkins体验之旅

在Jenkins提供的可选安装的插件中,先安装cppcheck插件,主要进行代码进行分析,单击直接安装即可。

笔者感觉cppcheck基本上检测不出有价值的代码缺陷。

直接安装SonarQube Scanner

安装SonarQube Scanner代码扫描插件。

安装过程中,可选择安装支持中文

配置语言

系统管理-->系统设置-->Locale

补充一下docker中启动Jenkins服务的命令:

启动docker jenkins服务:

service docker start

docker ps

 

直接启动jenkins:

Docker start  容器名称

停止:

Docker stop 容器名称

 

Docker  run  接参数

参数:

docker run -itd -p 8080:8080 -p 50000:50000 --name jenkins --privileged=true  -v /home/hzq/jenkins:/var/jenkins_home jenkins

 

解释上述指令:

-p 8080:8080 -p 50000:50000 进行端口映射

--privileged=true 在CentOS7中的安全模块selinux把权限禁掉了,参数给容器加特权。

-v /home/hzq/jenkins:/var/jenkins_home 磁盘挂载

 

 

下面再把安装Git过程列出:

 

1.先从yum安装git,使用yum直接安装git是最方便的

yum –y install git

 

2.在本机某个路径创建一个空仓库(最后以.git结尾)

cd /usr/local

mkdir git

cd git

git init --bare sjs.git

 

3.创建一个git用户并赋予密码

useradd git

passwd git

 

4.赋予git用户权限

chown -R git:git sjs.git

5.禁用git用户shell登录(一定要禁用)

vi /etc/passwd

git用户修改为如下(一般在最后一行)

git:x:1001:1001::/home/git:/usr/bin/git-shell

其他的不用改。服务端完成。

 

安装上面的git服务端后,再下载G’it客户端进行安装:

在https://git-scm.com/  网址下载

首先要去下载一个git工具,win下载地址:https://git-scm.com/download/win,如果是其它的平台的,下载地址:https://git-scm.com/downloads,它支持windods,Mac OS X ,linux Solaris

 

在客户端的bash

git config --global user.name [你的用户名]   “cxz”

git config --global user.email [你的邮箱]    “manok@tom.com

git config --global user.name

出现刚才配置的用户名,表示配置成功

最近在接触laravel,开始用了git,安装了windows for git,往github执行push操作时验证不通过,原来是没有为github账户添加ssh,“ssh-add pathName”时候出现如下信息:

https://images2015.cnblogs.com/blog/1118942/201703/1118942-20170306133917859-1359232141.png

【解决方法】:需要ssh-agent启动bash,或者说把bash挂到ssh-agent下面。

 

way@DESKTOP-8CTQ9EA MINGW64 /d/XAMpp/htdocs/gitwork (master)

$ ssh-agent bash --login -i

 

way@DESKTOP-8CTQ9EA MINGW64 /d/XAMpp/htdocs/gitwork (master)

$ ssh-add

Identity added: /c/Users/way/.ssh/id_rsa (/c/Users/way/.ssh/id_rsa)

再执行: ssh-add  ~/.ssh/ld_rsa

添加短语:123456

Git 库地址

git  clone git@192.168.0.124:/usr/local/git/demo.git

向远程服务器传文件:

$ git remote add  orgin /linux0.0.1

$ git commit -m "my commit"

$ git pull orgin master

$ git push -u origin   master

 

git库路径:/usr/local/git/sjs.git

 

 

下面再列一下,安装mysql 5.7:

查询是否已经安装:rpm -qa | grep mysql  或  yum list installed | grep mysql

如果安装,则卸载。Yum -y remove mysql-libs.x86_64

Yum -y install mysql-server

设置开机启动:chkconfig mysqld on

启动mysql:sevice mysql start  或  systemctl start mysql.service

登录:root,通过下面找到初始密码

Mysql密码为:root/Test123#

如果想在测试机使用,可降低密码安全策略。

修正密码强度校验规则(用于测试环境使用),高版本的mysql在修改密码时会限制简单密码的创建,如果单单是为了测试使用,可以将他的密码检测策略修改下:

修改:密码最小长度策略

mysql> set global validate_password_length=0;

修改:密码强度检查等级策略,0/LOW、1/MEDIUM、2/STRONG

mysql> set global validate_password_policy=0;

 

开启mysql的root用户远程连接服务(%号即远程连接,IDENTIFIED BY后面跟的密码)

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root123' WITH GRANT OPTION;

 

在执行刷新

mysql> flush privileges;

 

开启mysql端口服务

/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT

 

启动网络服务

service network restart


 

下面讲解安装Sonarqube过程:

下载 wget  https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-7.4.zip  //笔者当当初最新版本为7.4版本

 # unzip  sonarqube-7.4.zip -d /opt/    //这里解压到/opt目录下

 # useradd sonar    //新建个普通用户,后面以该普通用户身份起动sonarqube服务

# chown  -R  sonar  /opt/sonarqube-7.4/

 

发现Centos没有安装zip,先安装unzip和zip

Yum install -y unzip zip

 

修改参数文件:

vim conf/sonar.properties

创建数据库sonar

mysql user: sonar/Sonar123@

 

以sonar用户启动(不能使用root账号启动,切记,切记,切记!):

sonarqube-6.7]# su sonar ./bin/linux-x86-64/sonar.sh start

 

启动后,可以下面的界面:

 

SonarQube默认登录用户名密码:admin/admin

登录后,再进行一些参数配置工作:

先是提供一个token,邮箱即可。

为了显示中文,安装中文插件Chinese park。

如果要检测C/C++语言,则安装C、C++语言插件,安装过程如下:

 

再下载并安装扫描器:

https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-cli-3.2.0.1227-linux.zip

解压到/usr目录

unzip -d  /usr   sonar-scanner-cli-3.2.0.1227-linux.zip

修改文件夹名称

mv sonar-scanner-cli-3.2.0.1227-linux  sonar-scnner

 

设置环境变量

# vi /etc/profile

增加和修改下面内容

export SONAR_HOME=/opt/sonarqube-7.4

export SONAR_SCANNER_HOME=/usr/sonar-scanner

export PATH=$PATH:$SONAR_HOME:$SONAR_SCANNER_HOME/bin

使环境变量生效

# source /etc/profile

启动Sonar

#cd /opt/sonarqube-7.4/bin/linux-x86-64

#./sonar.sh start

另外,启动/停止/重启命令如下: 
#./sonar.sh start   启动服务 
#./sonar.sh stop    停止服务 
#./sonar.sh restart 重启服务

 

为了能够开机启动,可以添加到启动服务中:

$ sudo ln -s /opt/sonarqube-7.4/bin/Linux-x86-64/sonar.sh /usr/bin/sonar

$ sudo chmod 755 /etc/init.d/sonar

$ sudo chkconfig -add sonar

 

1、创建服务

vi /etc/init.d/sonar

内容如下,其中标红内容为服务绝对路径:

#!/bin/sh  

#  

# rc file for SonarQube  

# chkconfig: 345 96 10  

# description:SonarQube system (www.sonarsource.org)  

#  

### BEGIN INIT INFO  

# Provides: sonar  

# Required-Start:$network  

# Required-Stop:$network  

# Default-Start: 3 4 5  

# Default-Stop: 0 1 2 6  

# Short-Description:SonarQube system (www.sonarsource.org)  

# Description:SonarQube system (www.sonarsource.org)  

### END INIT INFO  

/opt/sonarqube/bin/linux-x86-32/sonar.sh $* 

 

2、增加执行权限

chmod +x /etc/init.d/sonar

3、添加服务

chkconfig --add sonar

4、配置服务启动时依赖的jdk

vi /opt/sonarqube/conf/wrapper.conf

修改wrapper.java.command=java,配置为jdk中java命令的绝对路径

wrapper.java.command= /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.191.b12-0.el7_5.x86_64/jre/bin/java

如果你不知道Jdk安装哪里了,下面可以找java安装路径

  1. 先看java 版本: java –vesion
  2. 查看环境变量:echo $JAVA_HOME
  3. 如果2步没有,  则 which java,找到路径是否是映射位置
  4. 再使用ls -lrt /usr/bin/java称查找到真实位置

5、启动服务

service sonar start

 

重要提示:如果不小心使用root启动了,需要做下面处理,重新把执行权限赋值给sonar账号

chown -R sonar.sonar sonarqube-7.4

chmod 777 -R sonarqube-7.4

现在是开机自动启动了。

因为有时候需要对C/C++进行编译,则需要安装gcc,使用yum安装最方便:

yum install gcc 
yum install gcc-c++

准备一个C语言代码案例,检验一下检测效果

生产者和消费者c例子,编译命令:gcc -pthread -o dd.out dd.c

在代码文件夹的根目录下新建Sonar-scanner的配置文件sonar-project.properties

sonar.projectKey=demo

sonar.projectName=cdemo

sonar.projectVersion=1.0

sonar.sources=/home/demo/c

sonar.java.binaried=/home/demo/c

sonar.language=c

sonar.source.Encoding=UTF-8

然后当前项目路径执行

#sonar-scanner

控制台会打印分析过程,当出现SUCCESS时,分析成功!

Jenkins插件中安装cpplint,由于不支持该插件,所以需要通过warning插件安装。

如果想单独安装cppcheck,则可以通过下面过程安装,单独使用cppcheck检测:

下载http://cppcheck.sourceforge.net/

 

tar -xzvf  cppcheck-1.85.tar.gz

sudo make SRCDIR=build CFGDIR=/usr/share/cppcheck/

sudo make install CFGDIR=/usr/share/cppcheck/

验证

[root@localhost cppcheck-1.85]# cppcheck --version

Cppcheck 1.85

但是很遗憾,cppcheck没有描述那么强大,基本上检测不出有价值的bad smell

(完)

这篇关于Centos 7 docker 安装代码检测工具Sonarqube和Cppcheck的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java进行日期解析与格式化的实现代码

《Java进行日期解析与格式化的实现代码》使用Java搭配ApacheCommonsLang3和Natty库,可以实现灵活高效的日期解析与格式化,本文将通过相关示例为大家讲讲具体的实践操作,需要的可以... 目录一、背景二、依赖介绍1. Apache Commons Lang32. Natty三、核心实现代

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg

ubuntu如何部署Dify以及安装Docker? Dify安装部署指南

《ubuntu如何部署Dify以及安装Docker?Dify安装部署指南》Dify是一个开源的大模型应用开发平台,允许用户快速构建和部署基于大语言模型的应用,ubuntu如何部署Dify呢?详细请... Dify是个不错的开源LLM应用开发平台,提供从 Agent 构建到 AI workflow 编排、RA

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

如何在Ubuntu上安装NVIDIA显卡驱动? Ubuntu安装英伟达显卡驱动教程

《如何在Ubuntu上安装NVIDIA显卡驱动?Ubuntu安装英伟达显卡驱动教程》Windows系统不同,Linux系统通常不会自动安装专有显卡驱动,今天我们就来看看Ubuntu系统安装英伟达显卡... 对于使用NVIDIA显卡的Ubuntu用户来说,正确安装显卡驱动是获得最佳图形性能的关键。与Windo

ubuntu16.04如何部署dify? 在Linux上安装部署Dify的技巧

《ubuntu16.04如何部署dify?在Linux上安装部署Dify的技巧》随着云计算和容器技术的快速发展,Docker已经成为现代软件开发和部署的重要工具之一,Dify作为一款优秀的云原生应用... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启

debian12安装docker的实现步骤

《debian12安装docker的实现步骤》本文主要介绍了debian12安装docker的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录步骤 1:更新你的系统步骤 2:安装依赖项步骤 3:添加 docker 的官方 GPG 密钥步骤

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装