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并创建账户:

浏览器输入:ip地址:8081 后回车
进入网页后点右上角的Sign in  ,输入初始账号:admin  密码:上面有提到查看admin的方法。
登录之后点击顶部的设置图标,点击Security下方的Users,然后点击添加账号
之后输入账号名、密码、等这些就行了,还有要注意的是需要给该账号分配role,如果需要该新账号能往厂库里面推东西的话,则必须赋予 nx-admin 角色。全部设置完后点击保存。

AndroidStudio Maven配置:

# 首先在项目根级的build.gradle文件中的 allprojects 下的 repositories 下新加我们自己的maven依赖,如:
allprojects {
    repositories {
        google()
        jcenter()
      
        //下面是我们自己的maven仓库
        maven {
            setUrl("http://192.168.0.***:8081/repository/maven-snapshots/")
            allowInsecureProtocol = true
            //有的设置了必须要登录才能拉取到依赖,则下面要提供账号和密码
            credentials {
                username = "dev-***"
                password = "dev-***"
            }
        }
    }
}
然后在你要发布maven依赖的module的 build.gradle文件中引入maven publish插件,和定义要发布的依赖,如下:
...
apply plugin: 'maven-publish'

// 将language发布到远程maven仓库
publishing {
    publications {
        // 定义一个名为 Production 的发布
        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 {
                    // 避免出现空节点或 artifactId=unspecified 的节点
                    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选项卡,找到对应module下的Tasks下的publishing下的publish,点击publish进行发布。依赖发布成功后,我们可以通过网页浏览对应仓库的最新依赖:http://192.168.0.***:8081
我们可以在其他应用中引入我们刚才发布的依赖:
需要分别在项目的build.gradle和对应module的build.gradle文件中引入依赖:
其中项目的build.gradle如下(跟发布依赖的一致):
allprojects {
    repositories {
        google()
        jcenter()
      
        //下面是我们自己的maven仓库
        maven {
            setUrl("http://192.168.0.***:8081/repository/maven-snapshots/")
            allowInsecureProtocol = true
            //有的设置了必须要登录才能拉取到依赖,则下面要提供账号和密码
            credentials {
                username = "dev-account"
                password = "dev-account"
            }
        }
    }
}

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

//强制每次同步去获取最新的依赖
configurations.all {
    resolutionStrategy.cacheChangingModulesFor 0, 'seconds'
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容