نحوه نصب SonarQube در CentOS 7

SonarQube یک ابزار منبع باز برای توسعه سیستم با کیفیت است. در جاوا نوشته شده است و چندین پایگاه داده را پشتیبانی می کند. این امکان را برای بازرسی مداوم از کد ، نشان دادن سلامت برنامه و برجسته کردن موضوعات تازه معرفی شده فراهم می کند. این شامل آنالایزرهای کد است که برای تشخیص مشکلات حیله گر مجهز هستند. همچنین به راحتی با DevOps ادغام می شود.

در این آموزش آخرین نسخه SonarQube را در CentOS 7 نصب خواهیم کرد.

توجه: این مقاله از زمان انتشار اولیه به روز شده است. بخش "Errata" را در پاورقی ها ببینید.

پیش نیازها

مرحله 1: بروزرسانی سیستم را انجام دهید

قبل از نصب هر بسته در نمونه سرور CentOS ، توصیه می شود سیستم را به روز کنید. با استفاده از کاربر sudo وارد شوید و دستورالعمل های زیر را برای بروزرسانی سیستم اجرا کنید.

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

پس از اتمام راه اندازی مجدد سیستم ، دوباره به عنوان کاربر sudo وارد شوید و به مرحله بعدی بروید.

مرحله 2: جاوا را نصب کنید

بسته 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 -version

مرحله 3: PostgreSQL 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

با اجرای exitدستور به کاربر sudo برگردید .

مرحله 4: SonarQube را بارگیری و پیکربندی کنید

بایگانی پرونده های نصب SonarQube را بارگیری کنید.

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

همیشه می توانید در صفحه بارگیری SonarQube به دنبال جدیدترین نسخه برنامه بروید .

با اجرای برنامه unzip را نصب کنید:

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 از درگاه 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

مرحله ششم: دیوار آتش را پیکربندی کنید

درگاه 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" شود.


نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

تنظیم RethinkDB Cluster On CentOS 7

تنظیم RethinkDB Cluster On CentOS 7

مقدمه RethinkDB یک پایگاه داده NoSQL است که داده ها را به عنوان اسناد JSON ذخیره می کند. این یک زبان پرس و جو بسیار بصری است و از ویژگی های آن معمولا در دسترس است

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

Vtiger CRM یک نرم افزار محبوب مدیریت ارتباط با مشتری است که می تواند به بنگاهها در رشد فروش ، ارائه خدمات به مشتری و افزایش سود کمک کند. من

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

با استفاده از یک سیستم متفاوت؟ Couch CMS یک سیستم مدیریت محتوای منبع ساده و انعطاف پذیر ، آزاد و منبع باز (CMS) است که به طراحان وب اجازه می دهد تا طراحی کنند.

نصب Netdata در CentOS 7

نصب Netdata در CentOS 7

با استفاده از یک سیستم متفاوت؟ Netdata یک ستاره در حال افزایش در زمینه نظارت بر معیارهای سیستم در زمان واقعی است. در مقایسه با سایر ابزارهای مشابه ، Netdata:

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

نحوه فعال سازی پشتیبانی HTTP / 2 در DirectAdmin (CentOS)

HTTP / 2 جدیدترین نسخه پروتکل HTTP است که از SPDY مستقر است. توسعه آن توسط Google آغاز شده است و HTTP / 2 تا حد زیادی بر اساس پایگاه کد است

نحوه نصب سرور Starbound در CentOS 7

نحوه نصب سرور Starbound در CentOS 7

با استفاده از یک سیستم متفاوت؟ در این آموزش ، Ill در مورد نحوه راه اندازی یک سرور Starbound در CentOS 7 توضیح می دهد. پیش نیازها: شما باید این بازی را روی خود داشته باشید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

یک سرور چند نفره SA-MP San Andreas را در CentOS 6 تنظیم کنید

به یکی دیگر از آموزش های Vultr خوش آمدید. در اینجا ، نحوه نصب و اجرای سرور SAMP را یاد خواهید گرفت. این راهنما برای CentOS 6 نوشته شده است. پیش نیازهای مورد نیاز شما

Elgg را روی CentOS 7 نصب کنید

Elgg را روی CentOS 7 نصب کنید

با استفاده از یک سیستم متفاوت؟ Elgg یک موتور شبکه ای منبع باز است که امکان ایجاد محیط های اجتماعی از جمله شبکه های اجتماعی دانشگاه را فراهم می کند

نحوه نصب سرور RStudio در CentOS 7

نحوه نصب سرور RStudio در CentOS 7

RStudio Server نسخه وب RStudio است که مجموعه ای از ابزارهایی است که برای تسهیل کار برنامه نویسی با استفاده از زبان برنامه نویسی R طراحی شده است. در سه

نصب Bolt CMS در CentOS 7

نصب Bolt CMS در CentOS 7

Bolt یک CMS منبع باز است که به زبان PHP نوشته شده است. کد منبع Bolts در GitHub میزبانی شده است. این راهنما نحوه نصب Bolt CMS را در CentOS 7 Vult تازه نشان می دهد

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

نحوه نصب Elasticsearch در سرور Vultr CentOS 7

Elasticsearch یک موتور جستجوی کامل و متن تحلیلی متن کامل است. به لطف تطبیق پذیری ، مقیاس پذیری و سهولت استفاده ، Elasticsearch گسترده تر است

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

Kubernetes With Kubeadm را در CentOS 7 مستقر کنید

بررسی اجمالی این مقاله به شما کمک می کند تا در هر زمان خوشه ای از Kubernetes را جمع کنید و با kubeadm در حال اجرا باشید. در این راهنما از دو سرور استفاده می شود

راه اندازی Sails.js برای توسعه در CentOS 7

راه اندازی Sails.js برای توسعه در CentOS 7

با استفاده از یک سیستم متفاوت؟ مقدمه Sails.js یک چارچوب MVC ��رای Node.js است ، شبیه به Ruby on Rails. این امر برای ایجاد برنامه های مدرن ver

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

پیکربندی BGP با استفاده از Quagga در Vultr (CentOS 7)

Vultrs عملکرد IP فضای شما را امکان پذیر می سازد تا آزادی بی سابقه ای در اختصاص منابع IP شخصی شما به سرورهای cloud Vultr داشته باشید. ما کلی

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

نحوه نصب PufferPanel (کنترل پنل کنکوری رایگان) در CentOS 7

مقدمه در این آموزش ، PufferPanel را در Vultr VPS ما نصب کنید. PufferPanel یک پانل کنترل با منبع آزاد و بصورت رایگان برای مدیریت شما است

ابزارهای نظارت بهتر برای اوبونتو و CentOS

ابزارهای نظارت بهتر برای اوبونتو و CentOS

معرفی سیستم های لینوکس به طور پیش فرض مانند top ، df و du با ابزارهای نظارتی ارسال می شوند که به نظارت بر فرایندها و فضای دیسک کمک می کنند. با این حال ، اغلب اوقات ، آنها به صورت طاقت فرسا هستند

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

دستگاه های خود را با استفاده از LibreNMS در CentOS 7 نظارت کنید

با استفاده از یک سیستم متفاوت؟ LibreNMS یک سیستم نظارت بر شبکه منبع باز کاملاً برجسته است. از SNMP برای به دست آوردن داده ها از دستگاه های مختلف استفاده می کند. یک نوع

نحوه نصب Gitea در CentOS 7

نحوه نصب Gitea در CentOS 7

با استفاده از یک سیستم متفاوت؟ Gitea یک منبع کنترل جایگزین متن باز و خود میزبان است که توسط Git ساخته شده است. Gitea در Golang نوشته شده و هست

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد