Sonatype Nexus Repository Kurulum/Konfigürasyonu
Kurulum yaptığım makineye ait sistem konfigürasyon bilgileri;
data:image/s3,"s3://crabby-images/cf833/cf83304996027918a8e72adc66ed60ea01861b5f" alt=""
1-Update System Packages
sudo apt-get update
2- Install OpenJDK 1.8 on Ubuntu 20.04 LTS
sudo apt install openjdk-8-jre-headless
3-Download Nexus Repository Manager setup on Ubuntu 20.04 LTS
cd /opt sudo wget https://download.sonatype.com/nexus/3/latest-unix.tar.gz
data:image/s3,"s3://crabby-images/e8794/e879427ae277855cf10675ebc3cf6f2bd93ec946" alt=""
4-Install Nexus Repository on Ubuntu 20.04 LTS
sudo tar -zxvf latest-unix.tar.gz
data:image/s3,"s3://crabby-images/3d0ff/3d0ff2b5c1ae9e9ab738573c222fe9491c0891ae" alt=""
Rename the extracted Nexus setup folder to nexus
sudo mv /opt/nexus-3.54.1-01 /opt/nexus
Nexus root user ile çalıştırmamak için nexus adında bir user oluşturuyoruz.
sudo adduser nexus
Nexus kullanıcısı için parola ayarlamak için visudo açıyoruz. Ve aşağıdaki kodu yazıyoruz.
nexus ALL=(ALL) NOPASSWD: ALL
data:image/s3,"s3://crabby-images/20d6b/20d6b2cff92572209abc446e4e3ff65585dfe168" alt=""
Nexus kullanıcısına, dizinine, ve dosyalarına yetki veriyoruz.
sudo chown -R nexus:nexus /opt/nexus sudo chown -R nexus:nexus /opt/sonatype-work
Nexus’un boot açılışında servis olarak başlaması için aşağıdaki dosyada # işaretini kaldırıyoruz. /opt/nexus/bin/nexus.rc
run_as_user="nexus"
data:image/s3,"s3://crabby-images/6b882/6b882e65c7c7af064964e0af9cec39c3edb64bca" alt=""
5-Run Nexus as a service using Systemd
Nexus systemd servisi olarak çalıştırmak için aşağıdaki dizine kodları ekliyoruz.
sudo 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
data:image/s3,"s3://crabby-images/75d1e/75d1ef8e3358b6eb503e012abc0709161dd85fd9" alt=""
Nexus servisini başlatıyoruz.
sudo systemctl start nexus
Nexus servisini başlangıçta otomatik başlayacak şekilde ayarlıyoruz.
sudo systemctl enable nexus
Servisi kontrol ediyoruz
sudo systemctl status nexus
data:image/s3,"s3://crabby-images/b4c46/b4c46a508dd5b1dc6a23a6482453ad3f4a1095fe" alt=""
6- Access Nexus Repository Web Interface
Firewall kullanıyorsanız aşağıdaki komut çalıştırmalısınız.
ufw allow 8081/tcp
Uygulamamıza erişiyoruz
http://server_IP:8081
data:image/s3,"s3://crabby-images/d6e86/d6e86ea64702821a641ed989785b856342efa7f0" alt=""
Sign in tıkladıktan sonra username password isteyecektir. Aşağıdaki komut ile öğrenebilirsiniz.
sudo cat /opt/sonatype-work/nexus3/admin.password
data:image/s3,"s3://crabby-images/113a7/113a73622f1e5d75a07b8f7971f76bb90c44465f" alt=""
data:image/s3,"s3://crabby-images/07834/078346eb04087f8ccb9a1062c03989d0ce6eee60" alt=""
Kurulum tamamlandı.
7-Docker Repository Oluşturulması
Genel olarak nexus repository port atamamız aşağıdaki gibi olacak.
“nexusrepo1.eastus.cloudapp.azure.com:8081” < Nexus
“nexusrepo1.eastus.cloudapp.azure.com:8082” <Docker Hub Registry
“nexusrepo1.eastus.cloudapp.azure.com:8083” <Docker Registry
-Setting > Repositories > Create Repository > Docker Hosted
data:image/s3,"s3://crabby-images/60789/60789633c95018a0d8aa57205be5408ef1ce38f5" alt=""
–Aşağıdaki alanları dolduruyoruz.
Create Repository diyoruz.
data:image/s3,"s3://crabby-images/74bf2/74bf258a934386867d14ffe161b832d33bd29ae7" alt=""
-Repository oluşturduktan sonra Security > Realms > Active Realms menüsünde Docker Bearer Token sağ tarafa Active kısma kaydırıyoruz.
data:image/s3,"s3://crabby-images/565dd/565dd1d14c225d0b3afdea1e4b6bc91ea3a02747" alt=""
8-Upload Docker Image My Repository
-Docker kurulu bir makine üzerinde dockerfile build edip oluşturduğumuz image nexus repository’e push’layacağız.
Öncelikle kendi repomuza ait url veya ip bilgilerini docker kurulu makine üzerinde aşağıdaki dizine insecure-registries olarak tanıtmamız gerekiyor.sudo vi /etc/docker/daemon.json
data:image/s3,"s3://crabby-images/689ef/689ef146620f8ddb1c6b3886195f275e5d7c8218" alt=""
{
"insecure-registries": [
"nexusrepo1.eastus.cloudapp.azure.com:8081",
"nexusrepo1.eastus.cloudapp.azure.com:8082",
"nexusrepo1.eastus.cloudapp.azure.com:8083"
]
}
-Değişikliği tamamladıktan sonra aşağıdaki komut ile docker daemon restart ediyoruz.sudo systemctl restart docker
-Önce docker login -u admin http://nexusrepo1.eastus.cloudapp.azure.com:8083
komutu ile login oluyoruz.
data:image/s3,"s3://crabby-images/648b4/648b46d4329740d68c406867c643dc4e4e6a2dd6" alt=""
-Örnek bir projeyi github’dan download ediyoruz.
https://bitbucket.org/ananthkannan/mydockerrepo cd mydockerrepo/pythonApp
data:image/s3,"s3://crabby-images/cb4ab/cb4ab9e0c6740d1f638e8410356b048a3bfe013d" alt=""
-Builddocker build . -t nexusrepo1.eastus.cloudapp.azure.com:8083/dockerrepo
-Pushdocker push nexusrepo1.eastus.cloudapp.azure.com:8083/dockerrepo
–Verify
data:image/s3,"s3://crabby-images/532c8/532c886281b00dbff9ba9a401c5147a399948332" alt=""
-Docker Tag Kullanımı
docker tag 4993d1d61cae nexusrepo1.eastus.cloudapp.azure.com:8083/dockerrepo:61
docker push nexusrepo1.eastus.cloudapp.azure.com:8083/dockerrepo:61
data:image/s3,"s3://crabby-images/d1af9/d1af9ebe4a1c832a53fc060442dee666fe90d4f8" alt=""
-Docker Runsudo docker run -p 8081:5000 --rm --name myfirstApp1 your_docker_user_id/myphythonapp
data:image/s3,"s3://crabby-images/02838/02838c16e3dca27e03a9cc258dc4c5e864e00d84" alt=""