docker搭建Maven私服

docker搭建Maven私服:

# 下載nexus3鏡像
docker pull sonatype/nexus3

# 運行
docker run -d -p 8081:8081 --name maven-nexus3 -v /home/pc/maven-nexus3:/sonatype-work --restart=always sonatype/nexus3

# 查看admin 密碼:
docker exec -it maven-nexus3 /bin/bash

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

登錄maven并創(chuàng)建賬戶:

瀏覽器輸入:ip地址:8081 后回車
進入網(wǎng)頁后點右上角的Sign in  ,輸入初始賬號:admin  密碼:上面有提到查看admin的方法。
登錄之后點擊頂部的設(shè)置圖標,點擊Security下方的Users,然后點擊添加賬號
之后輸入賬號名、密碼、等這些就行了,還有要注意的是需要給該賬號分配role,如果需要該新賬號能往廠庫里面推東西的話,則必須賦予 nx-admin 角色。全部設(shè)置完后點擊保存。

AndroidStudio Maven配置:

# 首先在項目根級的build.gradle文件中的 allprojects 下的 repositories 下新加我們自己的maven依賴,如:
allprojects {
    repositories {
        google()
        jcenter()
      
        //下面是我們自己的maven倉庫
        maven {
            setUrl("http://192.168.0.***:8081/repository/maven-snapshots/")
            allowInsecureProtocol = true
            //有的設(shè)置了必須要登錄才能拉取到依賴,則下面要提供賬號和密碼
            credentials {
                username = "dev-***"
                password = "dev-***"
            }
        }
    }
}
然后在你要發(fā)布maven依賴的module的 build.gradle文件中引入maven publish插件,和定義要發(fā)布的依賴,如下:
...
apply plugin: 'maven-publish'

// 將language發(fā)布到遠程maven倉庫
publishing {
    publications {
        // 定義一個名為 Production 的發(fā)布
        language(MavenPublication) {
            groupId = "com.***.***.***"
            artifactId = "***"
            version = "1.0.0-SNAPSHOT"
            afterEvaluate { artifact(tasks.getByName("bundleReleaseAar")) }
            pom.withXml {
                def dependenciesNode = asNode().appendNode('dependencies')
                configurations.implementation.allDependencies.each {
                    // 避免出現(xiàn)空節(jié)點或 artifactId=unspecified 的節(jié)點
                    if (it.group != null && (it.name != null && "unspecified" != it.name) && it.version != null) {
                        println it.toString()
                        def dependencyNode = dependenciesNode.appendNode('dependency')
                        dependencyNode.appendNode('groupId', it.group)
                        dependencyNode.appendNode('artifactId', it.name)
                        dependencyNode.appendNode('version', it.version)
                        dependencyNode.appendNode('scope', 'implementation')
                    }
                }
            }
        }
    }

    repositories {
        maven {
            // url是必須要配置的
            url = "http://192.168.0.***:8081/repository/maven-snapshots/"
            allowInsecureProtocol = true
            // 倉庫用戶名密碼
            credentials {
                username = "dev-account"
                password = "dev-account"
            }
        }
    }
}
可通過Gradle選項卡,找到對應(yīng)module下的Tasks下的publishing下的publish,點擊publish進行發(fā)布。依賴發(fā)布成功后,我們可以通過網(wǎng)頁瀏覽對應(yīng)倉庫的最新依賴:http://192.168.0.***:8081
我們可以在其他應(yīng)用中引入我們剛才發(fā)布的依賴:
需要分別在項目的build.gradle和對應(yīng)module的build.gradle文件中引入依賴:
其中項目的build.gradle如下(跟發(fā)布依賴的一致):
allprojects {
    repositories {
        google()
        jcenter()
      
        //下面是我們自己的maven倉庫
        maven {
            setUrl("http://192.168.0.***:8081/repository/maven-snapshots/")
            allowInsecureProtocol = true
            //有的設(shè)置了必須要登錄才能拉取到依賴,則下面要提供賬號和密碼
            credentials {
                username = "dev-account"
                password = "dev-account"
            }
        }
    }
}

要引入依賴的module的build.gradle文件如下:
dependencies {
    //在dependencies下引入依賴
    implementation 'com.***.***.***:***:1.0.0-SNAPSHOT'
}

//強制每次同步去獲取最新的依賴
configurations.all {
    resolutionStrategy.cacheChangingModulesFor 0, 'seconds'
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容