CentOS 7에 SonarQube를 설치하는 방법

SonarQube는 품질 시스템 개발을위한 오픈 소스 도구입니다. Java로 작성되었으며 여러 데이터베이스를 지원합니다. 지속적으로 코드를 검사하고 응용 프로그램의 상태를 보여 주며 새로 도입 된 문제를 강조하는 기능을 제공합니다. 까다로운 문제를 감지 할 수있는 코드 분석기가 포함되어 있습니다. 또한 DevOps와 쉽게 통합됩니다.

이 튜토리얼에서는 CentOS 7에 최신 버전의 SonarQube를 설치합니다.

참고 : 이 문서는 최초 발행 이후 업데이트되었습니다. 각주의 "Errata"섹션을 참조하십시오.

전제 조건

  • RAM이 2GB 이상인 Vultr 64 비트 CentOS 7 서버 인스턴스
  • sudo는 사용자 .

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.confMD5 기반 인증을 활성화 하려면 을 편집하십시오 .

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

다음 줄을 변경 찾기 peertrustidnet에를 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

exit명령 을 실행하여 sudo 사용자로 다시 전환하십시오 .

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 단계 : 시스템 서비스 구성

SonarQube는 설치 프로그램 패키지에 제공된 시작 스크립트를 사용하여 직접 시작할 수 있습니다. 편의상 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는 기본적으로 포트 9000에서 localhost를 청취합니다.이 학습서에서는 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를 루트 사용자로 실행할 수 없으므로 아래에서 변경하십시오.

  • 업데이트 권한 : chown -R sonar:sonar /opt/sonarqube
  • 수정 /opt/sonarqube/bin/linux-x86-64/sonar.sh하고 #RUNAS" sonar"(으)로 변경하십시오 .
  • 수정 /etc/systemd/system/sonar.service하고 사용자 그룹을 " sonar" 로 변경하십시오 .


Leave a Comment

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 Vultr 시스템과 호환되는 Windows 사용자 지정 ISO를 만드는 방법을 단계별로 설명합니다. 최신 드라이버와 업데이트 통합을 포함한 완벽 가이드.

Vultr에서 BGP 구성

Vultr에서 BGP 구성

Vultr BGP 설정을 위한 단계별 튜토리얼. ASN 할당부터 IP 라우팅 구성, BIRD 데몬 설정, FreeBSD 특이사항 및 실전 문제 해결 팁 7가지 포함한 최종 가이드

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WebDAV (Web Distributed Authoring and Versioning)를 이용한 원격 파일 작성을 위한 프레임워크로, WsgiDAV 설치 및 구성 방법을 안내합니다.

데비안 7에 Mailcow 설치

데비안 7에 Mailcow 설치

Mailcow는 DoveCot, Postfix 및 기타 여러 오픈 소스 패키지를 기반으로 하는 경량 메일 서버입니다. 데비안에서 Mailcow 설치 방법을 안내합니다.

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

랜섬웨어 공격이 증가하고 있지만 AI가 최신 컴퓨터 바이러스를 처리하는 데 도움이 될 수 있습니까? AI가 답인가? AI boone 또는 bane인지 여기에서 읽으십시오.

ReactOS: 이것이 Windows의 미래입니까?

ReactOS: 이것이 Windows의 미래입니까?

오픈 소스이자 무료 운영 체제인 ReactOS가 최신 버전과 함께 제공됩니다. 현대 Windows 사용자의 요구 사항을 충족하고 Microsoft를 무너뜨릴 수 있습니까? 이 구식이지만 더 새로운 OS 환경에 대해 자세히 알아보겠습니다.

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

Whatsapp은 마침내 Mac 및 Windows 사용자용 데스크톱 앱을 출시했습니다. 이제 Windows 또는 Mac에서 Whatsapp에 쉽게 액세스할 수 있습니다. Windows 8 이상 및 Mac OS 10.9 이상에서 사용 가능

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

인공 지능이 소규모 회사에서 어떻게 인기를 얻고 있으며 어떻게 인공 지능이 성장할 가능성을 높이고 경쟁자가 우위를 점할 수 있는지 알아보려면 이 기사를 읽으십시오.

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

최근 Apple은 문제를 해결하기 위해 macOS Catalina 10.15.4 추가 업데이트를 출시했지만 이 업데이트로 인해 Mac 컴퓨터의 브릭킹으로 이어지는 더 많은 문제가 발생하는 것 같습니다. 자세히 알아보려면 이 기사를 읽어보세요.

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구