Ako nainštalovať SonarQube na CentOS 7

SonarQube je open source nástroj pre vývoj kvalitného systému. Je napísaný v jazyku Java a podporuje viacero databáz. Poskytuje možnosti na nepretržitú kontrolu kódu, zobrazenie stavu aplikácie a zvýrazňovanie nových problémov. Obsahuje analyzátory kódu, ktoré sú vybavené na detekciu zložitých problémov. Ľahko sa tiež integruje s DevOps.

V tomto návode nainštalujeme najnovšiu verziu SonarQube na CentOS 7.

Poznámka: Tento dokument bol od svojho pôvodného zverejnenia aktualizovaný. Pozrite si časť „Errata“ v poznámkach pod čiarou.

Predpoklady

Krok 1: Vykonajte aktualizáciu systému

Pred inštaláciou akýchkoľvek balíkov na inštanciu servera CentOS sa odporúča aktualizovať systém. Prihláste sa pomocou používateľa sudo a spustením nasledujúcich príkazov aktualizujte systém.

sudo yum -y install epel-release
sudo yum -y update
sudo shutdown -r now

Po dokončení reštartovania systému sa znova prihláste ako používateľ sudo a prejdite na ďalší krok.

Krok 2: Nainštalujte Java

Stiahnite si balík Oracle SE JDK RPM zadaním:

wget --no-cookies --no-check-certificate --header "Cookie:oraclelicense=accept-securebackup-cookie" "http://download.oracle.com/otn-pub/java/jdk/8u131-b11/d54c1d3a095b4ff2b6607d096fa80163/jdk-8u131-linux-x64.rpm"

Nainštalujte stiahnutý balík zadaním:

sudo yum -y localinstall jdk-8u131-linux-x64.rpm

Teraz môžete skontrolovať verziu Java zadaním:

java -version

Krok 3: Nainštalujte a nakonfigurujte PostgreSQL

Nainštalujte úložisko PostgreSQL zadaním:

sudo rpm -Uvh https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-7-x86_64/pgdg-centos96-9.6-3.noarch.rpm

Nainštalujte databázový server PostgreSQL spustením:

sudo yum -y install postgresql96-server postgresql96-contrib

Inicializujte databázu:

sudo /usr/pgsql-9.6/bin/postgresql96-setup initdb

Upravte, /var/lib/pgsql/9.6/data/pg_hba.confaby ste povolili autentifikáciu založenú na MD5.

sudo nano /var/lib/pgsql/9.6/data/pg_hba.conf

Nájdite nasledujúce riadky a zmeňte peerna trusta idnetna md5.

# TYPE  DATABASE        USER            ADDRESS                 METHOD

# "local" is for Unix domain socket connections only
local   all             all                                     peer
# IPv4 local connections:
host    all             all             127.0.0.1/32            ident
# IPv6 local connections:
host    all             all             ::1/128                 ident

Po aktualizácii by konfigurácia mala vyzerať ako tá, ktorá je uvedená nižšie.

# TYPE  DATABASE        USER            ADDRESS                 METHOD

# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            md5
# IPv6 local connections:
host    all             all             ::1/128                 md5

Spustite PostgreSQL server a povoľte jeho automatické spustenie pri štarte spustením:

sudo systemctl start postgresql-9.6
sudo systemctl enable postgresql-9.6

Zmeňte heslo pre predvoleného používateľa PostgreSQL.

sudo passwd postgres

Prepnúť na postgrespoužívateľa.

su - postgres

Vytvorte nového používateľa zadaním:

createuser sonar

Prepnite sa do prostredia PostgreSQL.

psql

Nastavte heslo pre novovytvoreného používateľa pre databázu SonarQube.

ALTER USER sonar WITH ENCRYPTED password 'StrongPassword';

Vytvorte novú databázu pre PostgreSQL databázu spustením:

CREATE DATABASE sonar OWNER sonar;

Výstup z psqlshellu:

\q

Spustením exitpríkazu prepnite späť na používateľa sudo .

Krok 4: Stiahnite si a nakonfigurujte SonarQube

Stiahnite si archív inštalačných súborov SonarQube.

wget https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-6.4.zip

Odkaz na najnovšiu verziu aplikácie môžete vždy vyhľadať na stránke sťahovania SonarQube .

Nainštalujte rozbalenie spustením:

sudo yum -y install unzip

Rozbaľte archív pomocou nasledujúceho príkazu.

sudo unzip sonarqube-6.4.zip -d /opt

Premenujte adresár:

sudo mv /opt/sonarqube-6.4 /opt/sonarqube

Otvorte konfiguračný súbor SonarQube pomocou vášho obľúbeného textového editora.

sudo nano /opt/sonarqube/conf/sonar.properties

Nájdite nasledujúce riadky.

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

Odkomentujte a uveďte používateľské meno a heslo PostgreSQL databázy, ktorú sme vytvorili predtým. Malo by to vyzerať takto:

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

Ďalej nájdite:

#sonar.jdbc.url=jdbc:postgresql://localhost/sonar

Odkomentujte riadok, uložte súbor a ukončite editor.

Krok 5: Nakonfigurujte službu Systemd

SonarQube je možné spustiť priamo pomocou spúšťacieho skriptu, ktorý je súčasťou inštalačného balíka. Z dôvodu pohodlia by ste mali nastaviť súbor jednotky Systemd pre SonarQube.

sudo nano /etc/systemd/system/sonar.service

Vyplňte súbor s:

[Unit]
Description=SonarQube service
After=syslog.target network.target

[Service]
Type=forking

ExecStart=/opt/sonarqube/bin/linux-x86-64/sonar.sh start
ExecStop=/opt/sonarqube/bin/linux-x86-64/sonar.sh stop

User=root
Group=root
Restart=always

[Install]
WantedBy=multi-user.target

Spustite aplikáciu spustením:

sudo systemctl start sonar

Povoľte automatické spustenie služby SonarQube v čase zavádzania.

sudo systemctl enable sonar

Ak chcete skontrolovať, či je služba spustená, spustite:

sudo systemctl status sonar

Krok 5: Nakonfigurujte reverzný proxy server

V predvolenom nastavení SonarQube počúva localhost na porte 9000. V tomto návode použijeme Apache ako reverzný proxy, takže k aplikácii je možné pristupovať cez štandardný HTTP port. Nainštalujte webový server Apache spustením:

sudo yum -y install httpd

Vytvorte nového virtuálneho hostiteľa.

sudo nano /etc/httpd/conf.d/sonar.yourdomain.com.conf

Vyplňte súbor s:

<VirtualHost *:80>  
    ServerName sonar.yourdomain.com
    ServerAdmin me@yourdomain.com
    ProxyPreserveHost On
    ProxyPass / http://localhost:9000/
    ProxyPassReverse / http://localhost:9000/
    TransferLog /var/log/httpd/sonar.yourdomain.com_access.log
    ErrorLog /var/log/httpd/sonar.yourdomain.com_error.log
</VirtualHost>

Spustite Apache a povoľte jeho automatické spustenie pri štarte:

sudo systemctl start httpd
sudo systemctl enable httpd

Krok 6: Nakonfigurujte bránu firewall

Povoľte požadovaný port HTTP cez systémovú bránu firewall.

sudo firewall-cmd --add-service=http --permanent
sudo firewall-cmd --reload

Spustite službu SonarQube:

sudo systemctl start sonar

Budete tiež musieť vypnúť SELinux:

sudo setenforce 0

SonarQube je nainštalovaný na vašom serveri, prejdite na dashboard na nasledujúcej adrese.

http://sonar.yourdomain.com

Prihláste sa pomocou počiatočného účtu správcu admina admin. Teraz môžete použiť SonarQube na nepretržitú analýzu kódu, ktorý ste napísali.


Errata

Ak inštalujete SonarQube 7.1 (alebo novší), vykonajte zmeny uvedené nižšie, pretože novšie verzie Elasticsearch nemožno spustiť ako užívateľ root.

  • Aktualizovať povolenia: chown -R sonar:sonar /opt/sonarqube
  • Upraviť /opt/sonarqube/bin/linux-x86-64/sonar.sh, zmeniť #RUNASna " sonar".
  • Upravte /etc/systemd/system/sonar.service, zmeňte skupinu používateľov na " sonar" .

Zanechať komentár

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.

Útoky DDOS: Stručný prehľad

Útoky DDOS: Stručný prehľad

Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.

Funkcionality vrstiev referenčnej architektúry veľkých dát

Funkcionality vrstiev referenčnej architektúry veľkých dát

Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.

Vývoj ukladania dát – Infografika

Vývoj ukladania dát – Infografika

Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac