Как да инсталирате SonarQube на CentOS 7

SonarQube е инструмент с отворен код за разработване на система за качество. Той е написан на Java и поддържа множество бази данни. Той предоставя възможности за непрекъсната проверка на кода, показване на здравето на приложение и подчертаване на нововъведени проблеми. Той съдържа анализатори на код, които са оборудвани за откриване на трудни проблеми. Освен това се интегрира лесно с DevOps.

В този урок ще инсталираме най-новата версия на SonarQube на CentOS 7.

Забележка: Този документ е актуализиран след първоначалната му публикация. Вижте раздела „Грешки“ в бележките под линия.

Предпоставки

Стъпка 1: Извършете актуализация на системата

Преди да инсталирате пакети на сървъра на CentOS, се препоръчва да актуализирате системата. Влезте с помощта на sudo потребителя и изпълнете следните команди, за да актуализирате системата.

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

След като системата приключи с рестартирането, влезте отново като потребител на sudo и преминете към следващата стъпка.

Стъпка 2: Инсталирайте Java

Изтеглете пакета Oracle SE JDK RPM, като напишете:

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"

Инсталирайте изтегления пакет, като напишете:

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

Вече можете да проверите версията на Java, като напишете:

java -version

Стъпка 3: Инсталирайте и конфигурирайте PostgreSQL

Инсталирайте хранилището на PostgreSQL, като напишете:

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

Инсталирайте сървъра на база данни PostgreSQL, като изпълните:

sudo yum -y install postgresql96-server postgresql96-contrib

Инициализирайте базата данни:

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

Редактирайте, за /var/lib/pgsql/9.6/data/pg_hba.confда активирате MD5-базирано удостоверяване.

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

Намерете следните редове и променете peerна trustи idnetна 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

След като бъде актуализирана, конфигурацията трябва да изглежда като тази, показана по-долу.

# 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

Стартирайте PostgreSQL сървъра и го активирайте да стартира автоматично при стартиране, като изпълните:

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

Променете паролата за потребителя на PostgreSQL по подразбиране.

sudo passwd postgres

Превключете към postgresпотребителя.

su - postgres

Създайте нов потребител, като напишете:

createuser sonar

Превключете към обвивката на PostgreSQL.

psql

Задайте парола за новосъздадения потребител за базата данни SonarQube.

ALTER USER sonar WITH ENCRYPTED password 'StrongPassword';

Създайте нова база данни за PostgreSQL база данни, като изпълните:

CREATE DATABASE sonar OWNER sonar;

Излезте от psqlобвивката:

\q

Превключете обратно към потребителя sudo, като изпълните exitкомандата.

Стъпка 4: Изтеглете и конфигурирайте SonarQube

Изтеглете архива с инсталационни файлове на SonarQube.

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

Винаги можете да потърсите връзката към най-новата версия на приложението на страницата за изтегляне на SonarQube .

Инсталирайте разархивирайте, като изпълните:

sudo yum -y install unzip

Разархивирайте архива, като използвате следната команда.

sudo unzip sonarqube-6.4.zip -d /opt

Преименувайте директорията:

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

Отворете конфигурационния файл на SonarQube, като използвате любимия си текстов редактор.

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

Намерете следните редове.

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

Разкоментирайте и предоставете потребителското име и паролата на PostgreSQL на базата данни, която създадохме по-рано. Трябва да изглежда така:

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

След това намерете:

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

Декоментирайте реда, запазете файла и излезте от редактора.

Стъпка 5: Конфигурирайте услугата Systemd

SonarQube може да се стартира директно с помощта на скрипта за стартиране, предоставен в инсталационния пакет. За удобство трябва да настроите файл Systemd за SonarQube.

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

Попълнете файла с:

[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

Стартирайте приложението, като стартирате:

sudo systemctl start sonar

Активирайте услугата SonarQube да стартира автоматично при стартиране.

sudo systemctl enable sonar

За да проверите дали услугата работи, изпълнете:

sudo systemctl status sonar

Стъпка 5: Конфигуриране на обратен прокси

По подразбиране SonarQube слуша localhost на порт 9000. В този урок ще използваме Apache като обратен прокси, така че приложението да може да бъде достъпно през стандартния HTTP порт. Инсталирайте уеб сървъра Apache, като изпълните:

sudo yum -y install httpd

Създайте нов виртуален хост.

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

Попълнете файла с:

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

Стартирайте Apache и го активирайте да стартира автоматично при стартиране:

sudo systemctl start httpd
sudo systemctl enable httpd

Стъпка 6: Конфигурирайте защитната стена

Разрешете необходимия HTTP порт през защитната стена на системата.

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

Стартирайте услугата SonarQube:

sudo systemctl start sonar

Ще трябва също да деактивирате SELinux:

sudo setenforce 0

SonarQube е инсталиран на вашия сървър, достъп до таблото за управление на следния адрес.

http://sonar.yourdomain.com

Влезте с първоначалния администраторски акаунт adminи admin. Вече можете да използвате SonarQube за непрекъснат анализ на кода, който сте написали.


Грешка

Ако инсталирате SonarQube 7.1 (или по-нова), направете промените по-долу, защото по-новите версии на Elasticsearch не могат да се изпълняват като root потребител.

  • Актуализиране на разрешенията: chown -R sonar:sonar /opt/sonarqube
  • Променете /opt/sonarqube/bin/linux-x86-64/sonar.sh, променете #RUNASда бъде " sonar".
  • Променете /etc/systemd/system/sonar.service, променете потребителската група да бъде " sonar".

Оставете коментар

Възходът на машините: Реални приложения на AI

Възходът на машините: Реални приложения на AI

Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.

DDOS атаки: кратък преглед

DDOS атаки: кратък преглед

Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.

Чудили ли сте се как хакерите печелят пари?

Чудили ли сте се как хакерите печелят пари?

Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.

Революционни изобретения на Google, които ще улеснят живота ви.

Революционни изобретения на Google, които ще улеснят живота ви.

Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.

Функционалности на референтните архитектурни слоеве за големи данни

Функционалности на референтните архитектурни слоеве за големи данни

Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.

Еволюция на съхранението на данни – инфографика

Еволюция на съхранението на данни – инфографика

Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече