Поиск по сайту:

Как установить и настроить Nexus Repository Manager в Ubuntu 20.04


Это руководство существует для этих версий ОС

  • Ubuntu 22.04 (Jammy Jellyfish)
  • Ubuntu 20.04 (Focal Fossa)

На этой странице

  1. Предпосылки
  2. Начало работы
  3. Установить Java
  4. Установить Nexus
  5. Создание служебного файла Systemd для Nexus
  6. Настройка Nginx в качестве обратного прокси-сервера для Nexus
  7. Доступ к веб-интерфейсу Nexus
  8. Заключение

Nexus — это управляемый репозиторий, предоставляющий платформу, защищающую весь жизненный цикл разработки программного обеспечения. Он позволяет собирать зависимости и управлять ими, а также упрощает распространение программного обеспечения. Это единый источник всех компонентов, двоичных файлов и артефактов сборки. Он обеспечивает поддержку Gradle, Ant, Maven и Ivy и позволяет разработчикам управлять компонентами с помощью двоичных файлов, контейнеров, сборок и готовой продукции. Вы также можете интегрировать Nexus с вашими существующими системами пользователей и аутентификации, такими как LDAP и Atlassian Crowd.

В этом руководстве мы покажем вам, как установить менеджер репозитория Nexus в Ubuntu 20.04.

Предпосылки

  • Сервер под управлением Ubuntu 20.04.
  • Пароль root настраивается на сервере.

Начиная

Перед запуском вам необходимо обновить системные пакеты до последней версии. Вы можете обновить их с помощью следующей команды:

apt-get update -y

Как только ваш сервер будет обновлен, вы можете перейти к следующему шагу.

Установить Java

Nexus основан на Java, поэтому вам необходимо установить Java версии 8 в вашей системе. Вы можете установить его с помощью следующей команды:

apt-get install openjdk-8-jdk -y

После установки Java вы можете проверить установленную версию Java с помощью следующей команды:

java -version

Вы должны получить следующий результат:

openjdk version "1.8.0_282"
OpenJDK Runtime Environment (build 1.8.0_282-8u282-b08-0ubuntu1~20.04-b08)
OpenJDK 64-Bit Server VM (build 25.282-b08, mixed mode)

После установки Java вы можете перейти к следующему шагу.

Установить Нексус

Перед запуском вам нужно будет создать отдельного пользователя для запуска Nexus. Вы можете создать его, выполнив следующую команду:

useradd -M -d /opt/nexus -s /bin/bash -r nexus

Затем позволяет пользователю nexus запускать всех пользователей с помощью sudo без пароля. Вы можете сделать это, выполнив следующую команду:

echo "nexus ALL=(ALL) NOPASSWD: ALL" > /etc/sudoers.d/nexus

Затем создайте каталог для Nexus и загрузите последнюю версию Nexus с помощью следующей команды:

mkdir /opt/nexus
wget https://sonatype-download.global.ssl.fastly.net/repository/downloads-prod-group/3/nexus-3.29.2-02-unix.tar.gz

После завершения загрузки извлеките загруженный файл в каталог /opt/nexus, выполнив следующую команду:

tar xzf nexus-3.29.2-02-unix.tar.gz -C /opt/nexus --strip-components=1

Затем установите правильное право собственности на каталог nexus, выполнив следующую команду:

chown -R nexus:nexus /opt/nexus

Затем отредактируйте файл конфигурации nexus.vmoptions и укажите максимальный размер памяти:

nano /opt/nexus/bin/nexus.vmoptions

Установите максимальный размер памяти Java и замените \../sonatype-work\ на \./sonatype-work\:

-Xms1024m
-Xmx1024m
-XX:MaxDirectMemorySize=1024m

-XX:LogFile=./sonatype-work/nexus3/log/jvm.log
-XX:-OmitStackTraceInFastThrow
-Djava.net.preferIPv4Stack=true
-Dkaraf.home=.
-Dkaraf.base=.
-Dkaraf.etc=etc/karaf
-Djava.util.logging.config.file=/etc/karaf/java.util.logging.properties
-Dkaraf.data=./sonatype-work/nexus3
-Dkaraf.log=./sonatype-work/nexus3/log
-Djava.io.tmpdir=./sonatype-work/nexus3/tmp

Сохраните и закройте файл, затем отредактируйте файл nexus.rc и определите запуск от имени пользователя:

nano /opt/nexus/bin/nexus.rc

Раскомментируйте и измените следующую строку с пользователем nexus:

run_as_user="nexus"

Сохраните и закройте файл, затем запустите службу Nexxus с помощью следующей команды:

sudo -u nexus /opt/nexus/bin/nexus start

Затем проверьте Nexus с помощью следующей команды:

tail -f /opt/nexus/sonatype-work/nexus3/log/nexus.log

Вы должны получить следующий результат:

2021-02-23 12:20:51,839+0000 INFO  [jetty-main-1]  *SYSTEM com.softwarementors.extjs.djn.servlet.DirectJNgineServlet - Servlet GLOBAL configuration: registryConfiguratorClass=
2021-02-23 12:20:51,853+0000 INFO  [jetty-main-1]  *SYSTEM com.softwarementors.extjs.djn.jscodegen.CodeFileGenerator - Creating source files for APIs...
2021-02-23 12:20:52,582+0000 INFO  [jetty-main-1]  *SYSTEM org.sonatype.nexus.siesta.SiestaServlet - JAX-RS RuntimeDelegate: org.sona649a69ca
2021-02-23 12:20:52,611+0000 INFO  [jetty-main-1]  *SYSTEM org.jboss.resteasy.plugins.validation.i18n - RESTEASY008550: Unable to find CDI supporting ValidatorFactory. Using default ValidatorFactory
2021-02-23 12:20:53,811+0000 INFO  [jetty-main-1]  *SYSTEM org.sonatype.nexus.siesta.SiestaServlet - Initialized
2021-02-23 12:20:53,817+0000 INFO  [jetty-main-1]  *SYSTEM org.sonatype.nexus.repository.httpbridge.internal.ViewServlet - Initialized
2021-02-23 12:20:53,852+0000 INFO  [jetty-main-1]  *SYSTEM org.eclipse.jetty.server.handler.ContextHandler - Started {Sonatype Nexus,/,file:///opt/nexus/public/,AVAILABLE}
2021-02-23 12:20:53,883+0000 INFO  [jetty-main-1]  *SYSTEM org.eclipse.jetty.server.AbstractConnector - Started {HTTP/1.1, (http/1.1)}{0.0.0.0:8081}
2021-02-23 12:20:53,884+0000 INFO  [jetty-main-1]  *SYSTEM org.eclipse.jetty.server.Server - Started @37529ms
2021-02-23 12:20:53,884+0000 INFO  [jetty-main-1]  *SYSTEM org.sonatype.nexus.bootstrap.jetty.JettyServer - 
-------------------------------------------------

Started Sonatype Nexus OSS 3.29.2-02

-------------------------------------------------

На данный момент Nexus запущен и прослушивает порт 8081. Вы можете проверить это с помощью следующей команды:

ss -altnp | grep 8081

Вы должны получить следующий результат:

LISTEN    0         50                 0.0.0.0:8081             0.0.0.0:*        users:(("java",pid=5548,fd=795)) 

Затем остановите службу Nexus с помощью следующей команды:

/opt/nexus/bin/nexus stop

Создайте служебный файл Systemd для Nexus

Далее вам нужно будет создать файл службы systemd для управления службой Nexus. Вы можете создать его с помощью следующей команды:

nano /etc/systemd/system/nexus.service

Добавьте следующие строки:

[Unit]
Description=nexus service
After=network.target

[Service]
Type=forking
LimitNOFILE=65536
ExecStart=/opt/nexus/bin/nexus start
ExecStop=/opt/nexus/bin/nexus stop
User=nexus
Restart=on-abort

[Install]
WantedBy=multi-user.target

Сохраните и закройте файл, затем перезагрузите демон systemd с помощью следующей команды:

systemctl daemon-reload

Затем запустите службу Nexus и включите ее запуск при перезагрузке системы с помощью следующей команды:

systemctl start nexus
systemctl enable nexus

Вы также можете проверить статус службы Nexus, используя следующую команду:

systemctl status nexus

Вы должны получить следующий результат:

? nexus.service - nexus service
     Loaded: loaded (/etc/systemd/system/nexus.service; disabled; vendor preset: enabled)
     Active: active (running) since Tue 2021-02-23 12:22:49 UTC; 15s ago
    Process: 6181 ExecStart=/opt/nexus/bin/nexus start (code=exited, status=0/SUCCESS)
   Main PID: 6368 (java)
      Tasks: 40 (limit: 4691)
     Memory: 642.9M
     CGroup: /system.slice/nexus.service
             ??6368 /usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java -server -Dinstall4j.jvmDir=/usr/lib/jvm/java-8-openjdk-amd64/jre -Dexe4j.mo>

Feb 23 12:22:49 ubunt4 systemd[1]: Starting nexus service...
Feb 23 12:22:49 ubunt4 nexus[6181]: Starting nexus
Feb 23 12:22:49 ubunt4 systemd[1]: Started nexus service.
lines 1-13/13 (END)

Как только вы закончите, вы можете перейти к следующему шагу.

Настройте Nginx в качестве обратного прокси для Nexus

Далее вам нужно будет установить Nginx и настроить Nginx в качестве обратного прокси. Сначала установите пакеты Nginx с помощью следующей команды:

apt-get install nginx -y

После установки Nginx создайте файл конфигурации виртуального хоста Nginx с помощью следующей команды:

nano /etc/nginx/conf.d/nexus.conf

Добавьте следующие строки:

upstream backend {
  server 127.0.0.1:8081;
}

server {
    listen 80;
    server_name nexus.example.com;

    location / {
        proxy_pass http://backend/;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $http_host;

        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forward-Proto http;
        proxy_set_header X-Nginx-Proxy true;

        proxy_redirect off;
    }
}

Сохраните и закройте файл, затем проверьте файл конфигурации Nginx с помощью следующей команды:

nginx -t

Вы должны получить следующий результат:

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

Наконец, перезапустите службу Nginx, чтобы применить изменения:

systemctl restart nginx

Вы также можете проверить статус Nginx с помощью следующей команды:

systemctl status nginx

Вы должны получить следующий результат:

? nginx.service - A high performance web server and a reverse proxy server
     Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
     Active: active (running) since Tue 2021-02-23 12:24:57 UTC; 4s ago
       Docs: man:nginx(8)
    Process: 7106 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
    Process: 7107 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
   Main PID: 7123 (nginx)
      Tasks: 3 (limit: 4691)
     Memory: 3.5M
     CGroup: /system.slice/nginx.service
             ??7123 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
             ??7124 nginx: worker process
             ??7125 nginx: worker process

Feb 23 12:24:57 ubunt4 systemd[1]: Starting A high performance web server and a reverse proxy server...
Feb 23 12:24:57 ubunt4 systemd[1]: Started A high performance web server and a reverse proxy server.

Доступ к веб-интерфейсу Nexus

Перед доступом к веб-интерфейсу Nexus введите пароль администратора Nexus с помощью следующей команды:

cat /opt/nexus/sonatype-work/nexus3/admin.password

Вы должны получить следующий результат:

b7c899cf-c6d3-4d11-a4cb-9a44e5d1787e

Теперь откройте веб-браузер и войдите в веб-интерфейс Nexus, используя URL-адрес http://nexus.example.com. Вы будете перенаправлены на следующую страницу:

Теперь нажмите на кнопку Войти. Вы будете перенаправлены на страницу входа в Nexus:

Укажите имя пользователя и пароль администратора и нажмите кнопку «Войти». Вы должны увидеть страницу настройки Nexus:

Нажмите кнопку Далее, чтобы продолжить. Вы должны увидеть следующую страницу:

Установите новый пароль и нажмите кнопку «Далее». Вы должны увидеть следующую страницу:

Выберите параметр «Включить анонимный доступ» и нажмите кнопку «Далее». Вы должны увидеть следующую страницу:

Нажмите кнопку «Готово», чтобы завершить настройку, и нажмите значок «Настройка шестеренки». Вы должны увидеть панель управления репозиторием Nexus:

Заключение

Поздравляем! вы успешно установили менеджер репозитория Nexus с Nginx в качестве обратного прокси-сервера на сервере Ubuntu 20.04. Не стесняйтесь спрашивать меня, если у вас есть какие-либо вопросы.