持續(xù)集成環(huán)境搭建(3)SonarQube搭建和使用

概述

SonarQube是管理代碼質(zhì)量一個開放平臺,可以快速的定位代碼中潛在的或者明顯的錯誤。

環(huán)境準備

mysql源碼編譯安裝

1. 解壓源碼包
[root@localhost ~]# tar -xvf mysql-5.7.24.tar
注: .tar.gz后綴的需要用參數(shù)-zxvf

2. 安裝依賴庫
[root@localhost ~]# yum -y install make cmake gcc gcc-c++ bison bison-devel ncurses ncurses-devel autoconf automake
[root@localhost ~]# useradd mysql
[root@localhost ~]# mkdir /home/mysql
[root@localhost ~]# cd /home/mysql/
[root@localhost mysql]# mkdir data logs temp
[root@localhost mysql]# chown -R mysql:mysql data logs temp

3. 安裝boost
[root@localhost ~]# mkdir /usr/local/boost
[root@localhost ~]# cd /usr/local/boost/
把下載的boost_1_59_0.tar.gz放于此目錄

4.執(zhí)行安裝命令
進入mysql源碼目錄
[root@localhost boost]# cd ~/mysql-5.7.24
執(zhí)行以下命令

cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/home/mysql/data \
-DMYSQL_USER=mysql \
-DMYSQL_TCP_PORT=3306 \
-DWITH_BOOST=/usr/local/boost

等待完成后赶撰,繼續(xù)執(zhí)行編譯
[root@localhost mysql-5.7.24]# make

執(zhí)行安裝
[root@localhost mysql-5.7.24]# make install

切換到/usr/local目錄
[root@localhost mysql-5.7.24]# cd /usr/local/

修改mysql的所屬用戶
[root@localhost local]# chown -R mysql:mysql mysql/

配置環(huán)境變量
[root@localhost local]# vi /etc/profile
把mysql加入path

export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$JAVA_HOME/bin:$MAVEN_HOME/bin:$PATH

使環(huán)境變量生效
[root@localhost local]# source /etc/profile

執(zhí)行初始化mysql命令
[root@localhost local]# mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/home/mysql/data

初始化mysql

可以看到最后有產(chǎn)生的密碼F;))m2Ou*2%e

刪除mysql默認的配置文件
[root@localhost local]# cd /etc/
[root@localhost etc]# rm -f my.cnf

復制mysql的服務(wù)腳本
[root@localhost etc]# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql

啟動mysql服務(wù)
[root@localhost etc]# service mysql start

設(shè)置開機啟動
[root@localhost etc]# chkconfig mysql on

登錄mysql
[root@localhost etc]# mysql -u root -p
Enter password:(前面生成的密碼)

修改密碼
mysql> SET PASSWORD = PASSWORD('qwe123');
Query OK, 0 rows affected, 1 warning (0.01 sec)

修改密碼從不過期
mysql> ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
Query OK, 0 rows affected (0.00 sec)

刷新權(quán)限
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

退出mysql
mysql> exit;
Bye

重新登錄mysql
[root@localhost etc]# mysql -u root -p
Enter password:qwe123

修改root賬戶可以遠程登錄
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'qwe123' WITH GRANT OPTION;
Query OK, 0 rows affected, 1 warning (0.01 sec)

再次刷新權(quán)限
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

退出mysql
mysql> exit;
Bye

開放防火墻端口3306
[root@localhost ~]# firewall-cmd --zone=public --add-port=3306/tcp --permanent
[root@localhost ~]# sudo systemctl reload firewalld

采用客戶端工具測試是否配置成功
連接信息

可以看到連接成功
連接成功

SonarQube安裝

安裝解壓工具unzip(已安裝的忽略此步驟)
[root@localhost ~]# yum -y install unzip

解壓
[root@localhost ~]# unzip sonarqube-6.7.6.zip

移動到/usr/local/目錄下
[root@localhost ~]# mv sonarqube-6.7.6 /usr/local/

登錄mysql
[root@localhost ~]# mysql -u root -p
Enter password:

創(chuàng)建數(shù)據(jù)庫
mysql> CREATE DATABASE sonar DEFAULT CHARACTER SET utf8;
Query OK, 1 row affected (0.05 sec)

mysql> use sonar;
Database changed
mysql> exit;
Bye

進入sonar的配置文件目錄
[root@localhost ~]# cd /usr/local/sonarqube-6.7.6/
[root@localhost sonarqube-6.7.6]# cd conf/

修改配置
[root@localhost conf]# vi sonar.properties

sonar.jdbc.username=root
sonar.jdbc.password=qwe123
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false
sonar.web.host=0.0.0.0

開放防火墻端口9000
[root@localhost ~]# firewall-cmd --zone=public --add-port=9000/tcp --permanent
[root@localhost ~]# sudo systemctl reload firewalld

添加sonar用戶鳞疲,且把sonar目錄的用戶修改為sonar
[root@localhost conf]# useradd sonar
[root@localhost conf]# cd ../..
[root@localhost local]# chown -R sonar:sonar sonarqube-6.7.6/

使用sonar用戶啟動程序
[root@localhost local]# su sonar
[sonar@localhost local]$ cd sonarqube-6.7.6/bin/
[sonar@localhost bin]$ cd linux-x86-64/
[sonar@localhost linux-x86-64]$ ./sonar.sh start

SonarQube使用

打開SonarQube
SonarQube

默認的登錄賬戶和密碼
admin / admin

首次登錄設(shè)置token
token

其中罪郊,復制這一段內(nèi)容

mvn sonar:sonar \
  -Dsonar.host.url=http://192.168.1.177:9000 \
  -Dsonar.login=d21685d0f6cdfcbcb78b0f3edf46ca0c3ba7d3a3

進入我們的本地maven項目
kongxiangxis-MacBook-Pro:~ kongxiangxi$ cd /Users/kongxiangxi/git/castle-microservices-platform
kongxiangxis-MacBook-Pro:castle-microservices-platform kongxiangxi$ mvn sonar:sonar \
> -Dsonar.host.url=http://192.168.1.177:9000 \
> -Dsonar.login=d21685d0f6cdfcbcb78b0f3edf46ca0c3ba7d3a3

刷新瀏覽器上的sonar頁面
SonarQube

進入項目

查看分析

分析詳情
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市尚洽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌靶累,老刑警劉巖腺毫,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異挣柬,居然都是意外死亡潮酒,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門邪蛔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來急黎,“玉大人,你說我怎么就攤上這事侧到〔蹋” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵匠抗,是天一觀的道長故源。 經(jīng)常有香客問我,道長汞贸,這世上最難降的妖魔是什么绳军? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任印机,我火速辦了婚禮,結(jié)果婚禮上门驾,老公的妹妹穿的比我還像新娘射赛。我一直安慰自己,他們只是感情好奶是,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布楣责。 她就那樣靜靜地躺著,像睡著了一般诫隅。 火紅的嫁衣襯著肌膚如雪腐魂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天逐纬,我揣著相機與錄音蛔屹,去河邊找鬼。 笑死豁生,一個胖子當著我的面吹牛兔毒,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播甸箱,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼育叁,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了芍殖?” 一聲冷哼從身側(cè)響起豪嗽,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎豌骏,沒想到半個月后龟梦,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡窃躲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年计贰,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蒂窒。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡躁倒,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出洒琢,到底是詐尸還是另有隱情秧秉,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布纬凤,位于F島的核電站福贞,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏停士。R本人自食惡果不足惜挖帘,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一完丽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧拇舀,春花似錦逻族、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至要拂,卻和暖如春抠璃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背脱惰。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工搏嗡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拉一。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓采盒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蔚润。 傳聞我的和親對象是個殘疾皇子磅氨,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容