Как установить и настроить Nexus Repository Manager в Ubuntu 20.04
Это руководство существует для этих версий ОС
- Ubuntu 22.04 (Jammy Jellyfish)
- Ubuntu 20.04 (Focal Fossa)
На этой странице
- Предпосылки
- Начало работы
- Установить Java
- Установить Nexus
- Создание служебного файла Systemd для Nexus
- Настройка Nginx в качестве обратного прокси-сервера для Nexus
- Доступ к веб-интерфейсу Nexus
- Заключение
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. Не стесняйтесь спрашивать меня, если у вас есть какие-либо вопросы.