Jak zainstalować SonarQube na CentOS 7

SonarQube to narzędzie typu open source do opracowywania systemu jakości. Jest napisany w Javie i obsługuje wiele baz danych. Zapewnia możliwości ciągłego sprawdzania kodu, pokazywania kondycji aplikacji i wyróżniania nowo wprowadzonych problemów. Zawiera analizatory kodu, które są przygotowane do wykrywania trudnych problemów. Łatwo integruje się również z DevOps.

W tym samouczku zainstalujemy najnowszą wersję SonarQube na CentOS 7.

Uwaga: ten dokument został zaktualizowany od czasu jego oryginalnej publikacji. Zobacz sekcję „Errata” w przypisach.

Wymagania wstępne

  • 64-bitowa instancja serwera Vultr CentOS 7 z co najmniej 2 GB pamięci RAM.
  • Użytkownik sudo .

Krok 1: Wykonaj aktualizację systemu

Przed zainstalowaniem jakichkolwiek pakietów na instancji serwera CentOS zaleca się aktualizację systemu. Zaloguj się przy użyciu użytkownika sudo i uruchom następujące polecenia, aby zaktualizować system.

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

Po ponownym uruchomieniu systemu zaloguj się ponownie jako użytkownik sudo i przejdź do następnego kroku.

Krok 2: Zainstaluj Javę

Pobierz pakiet Oracle SE JDK RPM, wpisując:

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"

Zainstaluj pobrany pakiet, wpisując:

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

Możesz teraz sprawdzić wersję Java, wpisując:

java -version

Krok 3: Zainstaluj i skonfiguruj PostgreSQL

Zainstaluj repozytorium PostgreSQL, wpisując:

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

Zainstaluj serwer bazy danych PostgreSQL, uruchamiając:

sudo yum -y install postgresql96-server postgresql96-contrib

Zainicjuj bazę danych:

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

Edytuj, /var/lib/pgsql/9.6/data/pg_hba.confaby włączyć uwierzytelnianie oparte na MD5.

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

Znajdź następujące wiersze i zmień peerna trusti 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 aktualizacji konfiguracja powinna wyglądać tak, jak pokazano poniżej.

# 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

Uruchom serwer PostgreSQL i włącz go, aby uruchamiał się automatycznie podczas uruchamiania, uruchamiając:

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

Zmień hasło dla domyślnego użytkownika PostgreSQL.

sudo passwd postgres

Przejdź do postgresużytkownika.

su - postgres

Utwórz nowego użytkownika, wpisując:

createuser sonar

Przejdź do powłoki PostgreSQL.

psql

Ustaw hasło dla nowo utworzonego użytkownika do bazy danych SonarQube.

ALTER USER sonar WITH ENCRYPTED password 'StrongPassword';

Utwórz nową bazę danych dla bazy danych PostgreSQL, uruchamiając:

CREATE DATABASE sonar OWNER sonar;

Wyjdź z psqlpowłoki:

\q

Wróć do użytkownika sudo, uruchamiając exitpolecenie.

Krok 4: Pobierz i skonfiguruj SonarQube

Pobierz archiwum plików instalatora SonarQube.

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

Zawsze możesz znaleźć link do najnowszej wersji aplikacji na stronie pobierania SonarQube .

Zainstaluj rozpakuj, uruchamiając:

sudo yum -y install unzip

Rozpakuj archiwum za pomocą następującego polecenia.

sudo unzip sonarqube-6.4.zip -d /opt

Zmień nazwę katalogu:

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

Otwórz plik konfiguracyjny SonarQube za pomocą ulubionego edytora tekstu.

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

Znajdź następujące linie.

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

Odkomentuj i podaj nazwę użytkownika PostgreSQL i hasło do bazy danych, którą wcześniej utworzyliśmy. Powinno to wyglądać następująco:

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

Następnie znajdź:

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

Usuń komentarz z wiersza, zapisz plik i wyjdź z edytora.

Krok 5: Skonfiguruj usługę Systemd

SonarQube można uruchomić bezpośrednio za pomocą skryptu uruchamiania dostarczonego w pakiecie instalatora. Dla wygody powinieneś skonfigurować plik jednostki Systemd dla SonarQube.

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

Wypełnij plik:

[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

Uruchom aplikację, uruchamiając:

sudo systemctl start sonar

Włącz usługę SonarQube, aby automatycznie uruchamiała się podczas rozruchu.

sudo systemctl enable sonar

Aby sprawdzić, czy usługa jest uruchomiona, uruchom:

sudo systemctl status sonar

Krok 5: Skonfiguruj zwrotny serwer proxy

Domyślnie SonarQube nasłuchuje localhost na porcie 9000. W tym samouczku użyjemy Apache jako odwrotnego proxy, aby aplikacja była dostępna przez standardowy port HTTP. Zainstaluj serwer WWW Apache, uruchamiając:

sudo yum -y install httpd

Utwórz nowy wirtualny host.

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

Wypełnij plik:

<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>

Uruchom Apache i włącz go, aby uruchamiał się automatycznie podczas uruchamiania:

sudo systemctl start httpd
sudo systemctl enable httpd

Krok 6: Skonfiguruj zaporę ogniową

Zezwól na wymagany port HTTP przez zaporę systemową.

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

Uruchom usługę SonarQube:

sudo systemctl start sonar

Musisz także wyłączyć SELinux:

sudo setenforce 0

SonarQube jest zainstalowany na twoim serwerze, dostęp do deski rozdzielczej pod następującym adresem.

http://sonar.yourdomain.com

Zaloguj się przy użyciu początkowego konta administratora admini admin. Możesz teraz używać SonarQube do ciągłej analizy napisanego kodu.


Errata

Jeśli instalujesz SonarQube 7.1 (lub nowszy), dokonaj zmian poniżej, ponieważ nowszych wersji Elasticsearch nie można uruchomić jako użytkownik root.

  • Aktualizuj uprawnienia: chown -R sonar:sonar /opt/sonarqube
  • Zmień /opt/sonarqube/bin/linux-x86-64/sonar.sh, zmień #RUNASna „ sonar”.
  • Zmodyfikuj /etc/systemd/system/sonar.service, zmień grupę użytkowników na „ sonar”.

Zostaw komentarz

Funkcjonalności warstw architektury referencyjnej Big Data

Funkcjonalności warstw architektury referencyjnej Big Data

Przeczytaj blog, aby w najprostszy sposób poznać różne warstwy w architekturze Big Data i ich funkcjonalności.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Rewolucyjne wynalazki Google, które ułatwią Twoje życie.

Chcesz zobaczyć rewolucyjne wynalazki Google i jak te wynalazki zmieniły życie każdego człowieka dzisiaj? Następnie czytaj na blogu, aby zobaczyć wynalazki Google.

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

13 komercyjnych narzędzi do ekstrakcji danych z Big Data

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Pozostań w kontakcie dzięki aplikacji WhatsApp na komputer 24*7

Whatsapp w końcu uruchomił aplikację Desktop dla użytkowników komputerów Mac i Windows. Teraz możesz łatwo uzyskać dostęp do Whatsapp z systemu Windows lub Mac. Dostępne dla Windows 8+ i Mac OS 10.9+

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

5 przykładów, które dowodzą, że energetyka jądrowa nie zawsze jest zła

Energia jądrowa jest zawsze pogardzana, nigdy jej nie szanujemy z powodu przeszłych wydarzeń, ale nie zawsze jest zła. Przeczytaj post, aby dowiedzieć się więcej na ten temat.

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Friday Essential: Co się stało z samochodami sterowanymi przez sztuczną inteligencję?

Koncepcja autonomicznych samochodów, które wyjadą na drogi za pomocą sztucznej inteligencji, to marzenie, które mamy już od jakiegoś czasu. Ale pomimo kilku obietnic nigdzie ich nie widać. Przeczytaj ten blog, aby dowiedzieć się więcej…

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

5 przydatnych narzędzi sztucznej inteligencji, które uproszczą Twoje życie

Sztuczna inteligencja nie jest dla ludzi nową nazwą. Ponieważ sztuczna inteligencja jest włączona do każdego strumienia, jednym z nich jest opracowywanie narzędzi zwiększających ludzką wydajność i dokładność. Skorzystaj z tych niesamowitych narzędzi uczenia maszynowego i uprość swoje codzienne zadania.

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Czy AI może walczyć z rosnącą liczbą ataków ransomware?

Wzrasta liczba ataków ransomware, ale czy sztuczna inteligencja może pomóc w radzeniu sobie z najnowszym wirusem komputerowym? Czy AI jest odpowiedzią? Przeczytaj tutaj, wiedz, że sztuczna inteligencja jest zmorą lub zgubą

Wgląd w 26 technik analizy Big Data: część 2

Wgląd w 26 technik analizy Big Data: część 2

Zawsze potrzebujemy Big Data Analytics do efektywnego zarządzania danymi. W tym artykule omówiliśmy kilka technik analizy Big Data. Sprawdź ten artykuł.

Ataki DDOS: krótki przegląd

Ataki DDOS: krótki przegląd

Czy jesteś również ofiarą ataków DDOS i nie masz pewności co do metod zapobiegania? Przeczytaj ten artykuł, aby rozwiązać swoje pytania.