Как да инсталирате 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 [email protected]
    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".

Инсталирайте Plesk на CentOS 7

Инсталирайте Plesk на CentOS 7

Използване на различна система? Plesk е собствен контролен панел за уеб хост, който позволява на потребителите да администрират своите лични и/или клиентски уебсайтове, бази данни

Как да инсталирате Squid Proxy на CentOS

Как да инсталирате Squid Proxy на CentOS

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

Как да инсталирате Lighttpd (LLMP стек) на CentOS 6

Как да инсталирате Lighttpd (LLMP стек) на CentOS 6

Въведение Lighttpd е форк на Apache, чиято цел е да бъде много по-малко ресурсоемка. Той е лек, откъдето идва и името му, и е доста лесен за използване. Инсталирайте

Конфигуриране на статична мрежа и IPv6 на CentOS 7

Конфигуриране на статична мрежа и IPv6 на CentOS 7

VULTR наскоро направи промени от своя страна и вече всичко трябва да работи добре от кутията с активиран NetworkManager. Ако желаете да деактивирате

Промяна на Icinga2 за използване на модел главен/клиент на CentOS 6 или CentOS 7

Промяна на Icinga2 за използване на модел главен/клиент на CentOS 6 или CentOS 7

Icinga2 е мощна система за наблюдение и когато се използва в модел главен-клиент, тя може да замени необходимостта от проверки на базата на NRPE. Главният клиент

Как да инсталирате Apache Cassandra 3.11.x на CentOS 7

Как да инсталирате Apache Cassandra 3.11.x на CentOS 7

Използване на различна система? Apache Cassandra е безплатна система за управление на база данни NoSQL с отворен код, която е проектирана да осигури мащабируемост, висока

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

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

Използване на различна система? Microweber е CMS и онлайн магазин с отворен код за плъзгане и пускане. Изходният код на Microweber се хоства на GitHub. Това ръководство ще ви покаже

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

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

Използване на различна система? Mattermost е самостоятелно хоствана алтернатива с отворен код на Slack SAAS услугата за съобщения. С други думи, с Mattermost, вие ca

Създаване на мрежа от сървъри на Minecraft с BungeeCord на Debian 8, Debian 9 или CentOS 7

Създаване на мрежа от сървъри на Minecraft с BungeeCord на Debian 8, Debian 9 или CentOS 7

Какво ви трябва Vultr VPS с поне 1 GB RAM. SSH достъп (с root/административни привилегии). Стъпка 1: Инсталиране на BungeeCord На първо място

Lets Encrypt на Plesk

Lets Encrypt на Plesk

Контролният панел на Plesk разполага с много приятна интеграция за Lets Encrypt. Lets Encrypt е един от единствените доставчици на SSL, които предоставят пълно сертификати

Позволява криптиране на cPanel

Позволява криптиране на cPanel

Lets Encrypt е сертифициращ орган, посветен на предоставянето на SSL сертификати безплатно. cPanel изгради чиста интеграция, така че вие ​​и вашият клиент

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

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

Използване на различна система? Concrete5 е CMS с отворен код, който предлага много отличителни и полезни функции за подпомагане на редакторите при лесното създаване на съдържание и

Как да инсталирате табло за преглед на CentOS 7

Как да инсталирате табло за преглед на CentOS 7

Използване на различна система? Review Board е безплатен инструмент с отворен код за преглед на изходен код, документация, изображения и много други. Това е уеб базиран софтуер

Настройте HTTP удостоверяване с Nginx на CentOS 7

Настройте HTTP удостоверяване с Nginx на CentOS 7

В това ръководство ще научите как да настроите HTTP удостоверяване за уеб сървър на Nginx, работещ на CentOS 7. Изисквания За да започнете, ще ви трябва

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

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

YOURLS (Your Own URL Shortener) е приложение за съкращаване на URL адреси и анализ на данни с отворен код. В тази статия ще разгледаме процеса на инсталиране

Как да инсталирате и конфигурирате ArangoDB на CentOS 7

Как да инсталирате и конфигурирате ArangoDB на CentOS 7

Използване на различна система? Въведение ArangoDB е NoSQL база данни с отворен код с гъвкав модел на данни за документи, графики и ключ-стойности. то е

Използване на Etckeeper за контрол на версиите на /etc

Използване на Etckeeper за контрол на версиите на /etc

Въведение Директорията /etc/ играе критична роля в начина, по който функционира една Linux система. Причината за това е, че почти всяка системна конфигурация

Защо трябва да използвате SSHFS? Как да монтирате отдалечена файлова система със SSHFS на CentOS 6

Защо трябва да използвате SSHFS? Как да монтирате отдалечена файлова система със SSHFS на CentOS 6

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

Настройване на сървър на Half Life 2 на CentOS 6

Настройване на сървър на Half Life 2 на CentOS 6

Този урок ще обхване процеса на инсталиране на сървър за игри Half Life 2 на CentOS 6 System. Стъпка 1: Инсталиране на предпоставките За да настроите ou

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

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

Laravel GitScrum или GitScrum е инструмент за производителност с отворен код, предназначен да помогне на екипите за разработка да внедрят методологията на Scrum по подобен начин.

Възходът на машините: Реални приложения на 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 машини. Прочетете тази статия, за да научите повече