自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

實戰(zhàn) | 手把手教你搭建一套大廠都在用的私服倉庫

開發(fā) 架構(gòu)
搭建Maven私服倉庫可以提高項目構(gòu)建和部署的效率、穩(wěn)定性和安全性,同時方便管理內(nèi)部開發(fā)的組件和私有庫,比較適用于企業(yè)內(nèi)部或者特定場景下的需求。

大家好,我是冰河~~

在研發(fā)的過程中,很多企業(yè)都會針對自身業(yè)務(wù)特點來定制研發(fā)一些工具類庫,但是這些工具類庫又不會對外公開,那如何在組織內(nèi)部共享這些類庫呢?一種很好的方式就是在公司內(nèi)部搭建一套Maven私服倉庫。

搭建Maven私服倉庫可以提高項目構(gòu)建和部署的效率、穩(wěn)定性和安全性,同時方便管理內(nèi)部開發(fā)的組件和私有庫,比較適用于企業(yè)內(nèi)部或者特定場景下的需求。

就拿我們星球的分布式IM即時通訊系統(tǒng)來說,對于后端服務(wù),我們將其劃分成了 多系統(tǒng)共用模型與工具、即時通訊后端服務(wù)、大后端平臺、即時通訊SDK、OpenAI大模型接入SDK 等。

其中,多系統(tǒng)共用模型與工具會被其他服務(wù)依賴,即時通訊SDK和OpenAI大模型接入SDK也會被其他服務(wù)依賴,并且多系統(tǒng)共用模型與工具、即時通訊SDK和OpenAI大模型接入SDK都是我們開發(fā)分布式IM即時通訊系統(tǒng)時的私有庫和組件,所以,在設(shè)計和研發(fā)分布式IM即時通訊系統(tǒng)的過程中,我們也需要搭建一套自己的Maven私服來統(tǒng)一管理這些私有庫和組件。

好了,那接下來,我們就一起搭建Maven私服倉庫吧。

二、環(huán)境說明

  • 服務(wù)器版本:CentOS7
  • 主機(jī)名:binghe102
  • IP地址:192.168.106.102
  • Maven私服鏡像:sonatype/nexus3

三、環(huán)境搭建

基于Docker搭建Maven私服的步驟如下所示。

3.1下載Nexus3鏡像

在服務(wù)器命令行輸入如下命令,下載Nexus3鏡像。

docker pull sonatype/nexus3

這里,視網(wǎng)絡(luò)情況,可能需要耐心等待一會兒。

3.2 查看Nexus3鏡像

在服務(wù)器命令行輸入如下命令,查看下載的Nexus3鏡像。

[root@binghe102 ~]# docker images
REPOSITORY        TAG       IMAGE ID       CREATED         SIZE
sonatype/nexus3   latest    589f7296a4a2   23 months ago   655MB

可以看到,已經(jīng)成功下載Nexus3鏡像。

3.3 創(chuàng)建Nexus3掛載文件夾

在服務(wù)器命令行輸入如下命令,創(chuàng)建nexus的掛載文件夾。

mkdir /usr/local/nexus-data && chown -R 200 /usr/local/nexus-data

3.4 啟動Nexus3容器

在服務(wù)器命令行輸入如下命令,啟動Nexus3容器。

docker run -d -p 8081:8081 --name nexus -v /usr/local/nexus-data:/nexus-data --restart=always sonatype/nexus3

可以看到,在上述啟動命令中,我們將Nexus3容器的/nexus-data目錄映射到了宿主機(jī)的/usr/local/nexus-data目錄。此時,Nexus3容器運行過程中,在/nexus-data目錄產(chǎn)生的文件和日志都會在宿主機(jī)的/usr/local/nexus-data目錄中查看到。

3.5 查看Nexus3容器啟動狀態(tài)

在服務(wù)器命令行輸入如下命令,查看Nexus3容器啟動狀態(tài)。

[root@binghe102 ~]# docker ps
CONTAINER ID   IMAGE             COMMAND                  CREATED         STATUS         PORTS                                       NAMES
59e27830bbaa   sonatype/nexus3   "sh -c ${SONATYPE_DI…"   2 minutes ago   Up 2 minutes   0.0.0.0:8081->8081/tcp, :::8081->8081/tcp   nexus

可以看到,Nexus3容器啟動成功,監(jiān)聽了8081端口。

四、Nexus3配置

搭建完Nexus3環(huán)境后,我們還需要對其進(jìn)行配置,具體配置的步驟如下所示。

4.1 打開Nexus3頁面

Nexus3容器啟動時監(jiān)聽的端口和宿主機(jī)端口都是8081,所以,我們在瀏覽器地址欄輸入http://192.168.106.102:8081打開Nexus3頁面,如圖1所示。

圖片圖片

4.2 登錄Nexus3

點擊Nexus3右上角的登錄,如圖2所示。

圖片圖片

點擊后會彈出如圖3所示的提示框。

圖片圖片

根據(jù)提示得知,初始密碼的存放位置為/nexus-data/admin.password,因為我們在啟動Nexus3容器時,將Nexus3容器的/nexus-data目錄映射到了宿主機(jī)的/usr/local/nexus-data目錄,所以,我們在宿主機(jī)的/usr/local/nexus-data目錄中也能夠查詢到admin.password文件。

所以,在宿主機(jī)中輸入如下命令即可查看到admin.password文件。

ll /usr/local/nexus-data

具體如圖4所示。

圖片圖片

輸入如下命令查看admin.password文件的內(nèi)容。

[root@binghe102 ~]# cat /usr/local/nexus-data/admin.password 
517842df-1a2d-49c9-b4c3-b9ad4cf0fe00

此時,我們就查看到登錄Nexus3的admin賬號的密碼為517842df-1a2d-49c9-b4c3-b9ad4cf0fe00,將admin賬號和對應(yīng)的密碼輸入到圖3所示的提示框中,即可登錄Nexus3,如圖5所示。

圖片圖片

登錄后的界面如圖6所示。

圖片圖片

可以看到,首次登錄后會自動彈出完成必要設(shè)置的提示框,點擊Next按鈕,設(shè)置新密碼,如圖7所示。

圖片圖片

這里,自行記錄新設(shè)置的密碼,用于后續(xù)登錄Nexus。

點擊Next按鈕,選擇nable anonymous access,如圖8所示。

圖片圖片

點擊Next按鈕,如圖9所示。

圖片圖片

點擊Finish按鈕,即可完成設(shè)置。

4.3 配置阿里云代理倉庫

Nexus默認(rèn)使用的遠(yuǎn)程倉庫為maven-central,從這個遠(yuǎn)程倉庫下載依賴很慢,經(jīng)常連不上,如圖10所示。

圖片圖片

鼠標(biāo)單機(jī)maven-central倉庫,查看maven-central倉庫配置的遠(yuǎn)程鏈接,如圖11所示。

可以看到,maven-central倉庫配置的遠(yuǎn)程鏈接為https://repo1.maven.org/maven2/,從這個遠(yuǎn)程倉庫下載依賴很慢,經(jīng)常連不上,所有我們需要配置阿里云遠(yuǎn)程代理倉庫。

回到圖10所示的頁面,點擊Create repository按鈕,如圖12所示。

點擊后進(jìn)入選擇倉庫類型的頁面,這里我們選擇maven2(proxy)類型,如圖13所示。

圖片圖片

點擊選則maven2(proxy)類型后,進(jìn)入配置遠(yuǎn)程代理倉庫的頁面,如圖14所示。

圖片圖片

其中,每個配置項如下所示。

  • Name:aliyun-central
  • Version policy:Release
  • Layout policy:Strict
  • Remote storage:http://maven.aliyun.com/nexus/content/groups/public

接下來,拖動3-14頁面右側(cè)的滾動條,滑到最下面,點擊Create repository按鈕,如圖15所示。

圖片圖片

點擊Create repository按鈕后,就可以在Repositories列表中看到新配置的阿里云代理倉庫了,如圖16所示。

并且Status顯示的是Online - Ready to connect,說明阿里云遠(yuǎn)程倉庫配置成功。

4.4 配置倉庫組

接下來,需要將aliyun-central配置到倉庫組,并且將aliyun-central排在maven-central上面。具體步驟如下所示。

在Repositories列表中,點擊maven-public,如圖17所示。

圖片圖片

點擊后進(jìn)入如圖18所示的頁面。

圖片圖片

下拉頁面右側(cè)的滾動條,找到如圖19所示的配置。

圖片圖片

將aliyun-central移動到右側(cè),并排在最上面,如圖20所示。

圖片圖片

點擊Save按鈕保存配置。

4.5 創(chuàng)建用戶

接下來,創(chuàng)建一個用于上傳Jar包到倉庫的用戶,具體步驟如下所示。

點擊Security菜單下的Users菜單,如圖21所示。

圖片圖片

點擊Users菜單后,點擊Create local user按鈕,如圖22所示。

圖片圖片

隨后,按照圖23所示設(shè)置用戶的基本信息。

圖片圖片

這里,自行記錄用戶的密碼,用于后續(xù)上傳jar文件使用,配置好之后,點擊底部的Create local user按鈕即可。點擊后在Security菜單下的Users菜單的用戶列表中,可以查看到新創(chuàng)建的本地用戶,如圖24所示。

圖片圖片

至此,Nexus3配置完畢。

五、配置本地Maven倉庫

配置完Nexus后,接下來,還需要對本地的Maven倉庫進(jìn)行配置,主要就是對Maven的的settings.xml文件進(jìn)行配置。

5.1 復(fù)制settings文件

復(fù)制setting.xml文件為setting-binghe.xml文件,如圖25所示。

圖片

5.2 配置servers節(jié)點

在settings-binghe.xml文件中,找到servers節(jié)點,在servers節(jié)點中,配置5.5節(jié)創(chuàng)建的用戶,如下所示。

<server>
    <id>binghe</id>
    <username>binghe</username>
    <password>binghe123</password>
</server>

5.3 配置mirrors節(jié)點

在settings-binghe.xml文件中,找到mirrors節(jié)點,在mirrors節(jié)點中,配置倉庫地址,如下所示。

<!--本地私服倉庫地址-->
<mirror>
    <id>central</id>
    <name>Local Repository</name>
    <url>http://192.168.106.102:8081/repository/maven-public</url>
    <mirrorOf>*</mirrorOf>
</mirror>
<!--阿里云倉庫地址-->
<mirror>
    <id>nexus-aliyun</id>
    <mirrorOf>*</mirrorOf>
    <name>Nexus aliyun</name>
    <url>http://maven.aliyun.com/nexus/content/groups/public</url>
</mirror>

5.4 配置profiles節(jié)點

在settings-binghe.xml文件中,找到profiles節(jié)點,在profiles節(jié)點中,配置倉庫信息,如下所示。

<profile>
    <id>maven-public</id>
    <activation>
        <activeByDefault>true</activeByDefault>
        <jdk>1.8</jdk>
    </activation>
    <properties>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
        <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
    </properties>
    <repositories>
        <repository>
            <id>nexus-public</id>
            <url>http://192.168.106.102:8081/repository/maven-public/</url>
            <releases>
                <enabled>true</enabled>
                <updatePolicy>always</updatePolicy>
            </releases>
            <snapshots>
                <enabled>true</enabled>
                <updatePolicy>always</updatePolicy>
            </snapshots>
        </repository>
    </repositories>
</profile>

至此,Maven私服倉庫搭建完畢,并且本地Maven也已經(jīng)配置完畢。

后續(xù)使用Maven構(gòu)建項目時,指定使用binghe-settings.xml文件即可將依賴的Jar文件和生成的Jar文件上傳到Maven私服倉庫,如果使用IDEA編譯項目,也需要在IDEA中,將Maven的配置文件指定為settings-binghe.xml。

注意:我已經(jīng)將settings-binghe.xml文件上傳到本節(jié)對應(yīng)源碼分支的environment/maven目錄下,大家自行獲取即可。

六、項目pom.xml配置

搭建完Maven私服倉庫,配置好本地Maven倉庫后,還需要在項目的pom.xml文件中進(jìn)行相應(yīng)的配置,具體如下所示。

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.1</version>
            <configuration>
                <source>${java.version}</source>
                <target>${java.version}</target>
                <encoding>${project.build.sourceEncoding}</encoding>
            </configuration>
        </plugin>
        <!--發(fā)布代碼Jar插件 -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-deploy-plugin</artifactId>
            <version>2.8.2</version>
        </plugin>
        <!--發(fā)布源碼插件 -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-source-plugin</artifactId>
            <version>3.0.0</version>
            <executions>
                <execution>
                    <phase>install</phase>
                    <goals>
                        <goal>jar-no-fork</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

<distributionManagement>
    <repository>
        <!--這里的id與settings.xml中的servers節(jié)點配置的用戶ID一直,這樣才能使用配置的用戶去上傳到maven私有倉庫 -->
        <!--此倉庫對應(yīng)的為RELEASE版本的jar-->
        <id>binghe</id>
        <url>http://192.168.106.102:8081/repository/maven-releases/</url>
    </repository>
    <snapshotRepository>
        <!--這里的id與settings.xml中的servers節(jié)點配置的用戶ID一直,這樣才能使用配置的用戶去上傳到maven私有倉庫 -->
        <!--此倉庫對應(yīng)的為SNAPSHOT版本的jar-->
        <id>binghe</id>
        <url>http://192.168.106.102:8081/repository/maven-snapshots/</url>
    </snapshotRepository>
</distributionManagement>

是不是很簡單?你照著文章一步步實操,就可以基于Docker搭建屬于自己的Maven私服倉庫了。

責(zé)任編輯:武曉燕 來源: 冰河技術(shù)
相關(guān)推薦

2022-08-25 14:41:51

集群搭建

2021-12-02 11:39:28

Git服務(wù)器Linux

2018-03-05 11:10:12

2022-07-14 07:34:26

windowsmysqlcentos

2022-03-14 14:47:21

HarmonyOS操作系統(tǒng)鴻蒙

2021-09-30 18:27:38

數(shù)據(jù)倉庫ETL

2023-12-21 09:10:13

2023-03-14 07:34:47

代碼生成器開發(fā)

2011-03-25 12:45:49

Oracle SOA

2022-01-04 08:52:14

博客網(wǎng)站Linux 系統(tǒng)開源

2010-07-06 09:38:51

搭建私有云

2010-07-06 09:43:57

搭建私有云

2021-07-14 09:00:00

JavaFX開發(fā)應(yīng)用

2011-01-10 14:41:26

2011-05-03 15:59:00

黑盒打印機(jī)

2010-01-20 10:44:01

linux DHCP服務(wù)器

2019-08-26 09:25:23

RedisJavaLinux

2025-02-26 07:40:25

運營分析體系運營策略

2018-05-16 15:46:06

Python網(wǎng)絡(luò)爬蟲PhantomJS

2021-09-26 16:08:23

CC++clang_forma
點贊
收藏

51CTO技術(shù)棧公眾號