欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

docker部署java項(xiàng)目的詳細(xì)步驟

 更新時間:2025年03月21日 10:04:15   作者:java阿杜  
這篇文章主要介紹了docker部署java項(xiàng)目的詳細(xì)步驟,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

docker部署java項(xiàng)目步驟

在平常的開發(fā)工作中,我們經(jīng)常需要部署項(xiàng)目,開發(fā)測試完成后,最關(guān)鍵的一步就是部署。

今天我們以若依項(xiàng)目為例,總結(jié)下部署項(xiàng)目的整體流程。

簡單來說:

  • 第一步:安裝項(xiàng)目所需的中間件;
  • 第二步:將項(xiàng)目打包成 jar 包;
  • 第三步:編寫 Dockerfile 文件,構(gòu)建鏡像;
  • 第四步:編寫 docker-compose.yml 文件;
  • 第五步:編寫 nginx.conf 文件;
  • 第六步:啟動項(xiàng)目,進(jìn)行測試;

1:安裝項(xiàng)目所需中間件

項(xiàng)目部署依賴的中間件,如數(shù)據(jù)庫 mysql 、緩存 redis、負(fù)載均衡 nginx 等,這些中間件的安裝就不在這兒一 一贅述了。如果有不清楚的小伙伴,可以看我之前寫的幾篇文章,如下:

2:將項(xiàng)目打成 jar 包

部署不同的環(huán)境,需要選擇不同的配置文件,部署測試環(huán)境一般選擇 application-test.yml 文件打包,部署生產(chǎn)環(huán)境一般選擇 application-prod.yml 文件。

打 jar 包時一定注意本地修改不需要提交的配置,先回滾,然后拉取最新的代碼,點(diǎn)擊 maven clean,然后點(diǎn)擊 package 打包,打包完后在 target 目錄。將 jar 包上傳到服務(wù)器指定的目錄。

注意:

比如在服務(wù)器上新建一個 /docker/ruoyi/ 的目錄,那么 jar 包放在這個目錄下,在這個目錄下再新建 Dockerfile 文件 和 docker-compose.yml 文件

如下所示:

3:編寫 Dockerfile 文件,構(gòu)建鏡像

Dockerfile文件示例:

# 使用OpenJDK 17基礎(chǔ)鏡像
FROM openjdk:17
# 創(chuàng)建一個名為/ruoyi/logs的目錄
RUN mkdir -p /ruoyi/logs
# 切換工作目錄
WORKDIR /ruoyi
# 配置環(huán)境變量
ENV SERVER_PORT=8008 \
    LANG=C.UTF-8 \
    LC_ALL=C.UTF-8

# 暴露應(yīng)用端口
EXPOSE 8008

# 添加應(yīng)用Jar包到容器中
ADD ruoyi-admin.jar ./app.jar

# 設(shè)置啟動命令
ENTRYPOINT ["java", \
           "-Dserver.port=${SERVER_PORT}", \
           "-Xlog:gc*:time,tags,level", \
           "-XX:+UseZGC", \
           "-jar", "app.jar"]

Dockerfile文件內(nèi)容釋義

1):FROM openjdk:17: 使用OpenJDK 17基礎(chǔ)鏡像

2):RUN mkdir -p /ruoyi/logs:創(chuàng)建一個名為/ruoyi/logs的目錄,即日志目錄

3):WORKDIR /ruoyi:切換工作目錄

4):ENV SERVER_PORT=8008 \

LANG=C.UTF-8 \
LC_ALL=C.UTF-8

配置環(huán)境變量,Docker 鏡像構(gòu)建時設(shè)置了三個環(huán)境變量,分別是服務(wù)端口和字符編碼相關(guān)的環(huán)境變量,LANG=C.UTF-8 和 LC_ALL=C.UTF-8:這兩個環(huán)境變量用于設(shè)置字符編碼和語言環(huán)境,\ 末尾的反斜杠 \ 是行延續(xù)符,表示下一行是當(dāng)前命令的延續(xù)

5):EXPOSE 8008:暴露8008端口

6):ADD ruoyi-admin.jar ./app.jar:

添加應(yīng)用Jar包到容器中,ADD:這是 Dockerfile 里用于復(fù)制文件和目錄的指令,ruoyi-admin.jar:這是位于宿主機(jī)上的源文件路徑,./app.jar:這是目標(biāo)路徑,指定將源文件復(fù)制到 Docker 鏡像中的位置和文件名。./ 表示鏡像中的當(dāng)前 # 工作目錄,將源文件 ruoyi-admin.jar 復(fù)制到鏡像的當(dāng)前工作目錄下,并命名為 app.jar

7):

ENTRYPOINT ["java", \
"-Dserver.port=${SERVER_PORT}", \
"-Xlog:gc*:time,tags,level", \
"-XX:+UseZGC", \
"-jar", "app.jar"]
  • a:ENTRYPOINT 關(guān)鍵字:這是 Dockerfile 里用來定義容器啟動命令的指令。
  • b:"java":表明要執(zhí)行的是 Java 虛擬機(jī)。
  • c:"-Dserver.port=${SERVER_PORT}":設(shè)置 Java 虛擬機(jī)的系統(tǒng)屬性。server.port 通常用于指定 Spring Boot 應(yīng)用程序監(jiān)聽的端口,#${SERVER_PORT} 是一個環(huán)境變量引用,其值在之前的 ENV 指令中設(shè)置為 8008,這意味著應(yīng)用程序會監(jiān)聽 8008 端口。
  • d:"-Xlog:gc*:time,tags,level":開啟 Java 垃圾回收(GC)日志記錄功能。gc* 表示記錄所有與垃圾回# 收相關(guān)的事件,time,tags,level 表示日志中要包含時間、事件標(biāo)簽和日志級別等信息。
  • e:"-XX:+UseZGC":啟用 Z Garbage Collector(ZGC),這是 Java 11 及以上版本引入的一種可擴(kuò)展的低# 延遲垃圾回收器,能顯著減少垃圾回收停頓時間。
  • f:"-jar":告訴 Java 虛擬機(jī)要執(zhí)行一個 JAR 包,"app.jar":指定要執(zhí)行的 JAR 包名稱,這個 JAR 包是之前使用 ADD 或 COPY 指令復(fù)制到鏡像中的。

編寫完 Dockerfile 文件后,這個時候就可以構(gòu)建鏡像了,命令:docker build -t 鏡像名稱:鏡像版本 . ,如 docker build -t ruoyi:v1.0 . 注意版本后面有個 空格 點(diǎn)。使用點(diǎn) . :表示使用當(dāng)前目錄下的 Dockerfile,如果不加這個點(diǎn),Docker 不會知道從哪里獲取 Dockerfile。鏡像構(gòu)建完成后,可以使用 docker images 查看生成的鏡像:

4:編寫 docker-compose.yml 文件

docker-compose.yml 文件示例:

services:
  ruoyi-admin:
    image: ruoyi-admin:v1.0
    container_name : ruoyi-admin
    environment:
      - SERVER_PORT=8008
	  # 可選,Java 啟動參數(shù)
      - JAVA_OPTS="-Xmx2g -Xms2g" 
      - TZ=Asia/Shanghai
    restart: always
    network_mode: "host"

docker-compose.yml 文件內(nèi)容釋義

1):image: ruoyi-admin:v1.0:服務(wù)會使用ruoyi-admin:v1.0鏡像來創(chuàng)建容器

2):container_name:容器名稱

3):SERVER_PORT=8008:定義環(huán)境變量

4):- JAVA_OPTS="-Xmx2g -Xms2g":可選參數(shù),-Xmx用來設(shè)定 JVM 堆內(nèi)存的最大使用量;-Xms用于設(shè)置 JVM 堆內(nèi)存的初始使用量。JAVA_OPTS="-Xmx2g -Xms2g" 把 JVM 堆內(nèi)存的初始大小和最大大小都設(shè)置為 2GB。這么做可以避免在應(yīng)用程序運(yùn)行過程中頻繁進(jìn)行堆內(nèi)存的擴(kuò)容和縮容操作,從而提升性能。不過,設(shè)置時要依據(jù)應(yīng)用程序的實(shí)際內(nèi)存需求和服務(wù)器的可用內(nèi)存來合理調(diào)整,防止出現(xiàn)內(nèi)存不足或者浪費(fèi)的情況。

5):- TZ=Asia/Shanghai:把容器內(nèi)的時區(qū)指定為 Asia/Shanghai(即上海所在的時區(qū),也就是中國標(biāo)準(zhǔn)時間,UTC+8)。這樣容器內(nèi)運(yùn)行的應(yīng)用程序所顯示和處理的時間會UTC+8時區(qū)處理。

6):restart: always:為容器指定了一種重啟策略,確保容器在各種情況下都能盡可能保持運(yùn)行狀態(tài)。當(dāng)容器由于各種原因(如正常退出、異常崩潰、宿主機(jī)重啟等)停止運(yùn)行時,Docker 會依據(jù)此策略自動嘗試重啟容器。除了always,還有其他幾種重啟策略:

  • no:默認(rèn)策略,容器停止后不會自動重啟。
  • on-failure:只有當(dāng)容器以非零退出碼退出時,Docker 才會嘗試重啟它??梢酝ㄟ^ on-failure: N 的形式指定最多重啟 N 次。
  • unless-stopped:容器停止后,除非手動停止(如使用 docker stop 命令),否則 Docker 會在 Docker 守護(hù)進(jìn)程重啟或宿主機(jī)重啟后自動重啟容器。

7):network_mode: "host":指定容器使用宿主機(jī)的網(wǎng)絡(luò),即容器直接使用宿主機(jī)的網(wǎng)絡(luò)接口,而非創(chuàng)建獨(dú)立的 Docker 網(wǎng)絡(luò)。

5:配置 nginx.conf

nginx.conf 文件示例:

user  nginx;
worker_processes  auto;

pid        /var/run/nginx.pid;

events {
    worker_connections  1024;
}

http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    sendfile        on;

    keepalive_timeout  60;

	server {
        listen 80;
        server_name localhost;
        
	    charset utf-8;

        location / {
           proxy_pass  http://localhost:8008;
           proxy_set_header Host $host;
           proxy_set_header X-Real-IP $remote_addr;
           proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }
}

6:啟動項(xiàng)目,測試

1):進(jìn)入 /doker/ruoyi/ 目錄下,即 docker-compose.yml 文件目錄,使用 docker compose up -d 命令啟動容器,啟動完成后可以使用 docker ps 命令查看啟動的容器,信息如下:

使用 docker logs -f 容器id 查看啟動日志,啟動成功:

2):訪問系統(tǒng),nginx 配置監(jiān)聽 80 端口,所以訪問地址為:http:ip地址:80,訪問成功,頁面如下:

可能會遇到的問題:項(xiàng)目啟動成功,訪問失敗,可以查看項(xiàng)目端口是否因沒開防火墻導(dǎo)致無法訪問。如果是,解決步驟如下:

1):查看防火墻開的端口:firewall-cmd --zone=public --list-ports

2):若端口未開,則添加,比如開放 8008 端口:firewall-cmd --zone=public --add-port=8008/tcp --permanent

3):修改完成后,重啟防火墻:firewall-cmd --reload

以上為 docker 部署項(xiàng)目的基本步驟。

主要是Dockerfile文件的編寫,第一次構(gòu)建鏡像比較慢,因?yàn)橐螺d依賴的基礎(chǔ)鏡像,只需耐心等待即可。

Dockerfile文件有問題,會導(dǎo)致構(gòu)建鏡像失敗。構(gòu)建完成后,可以使用 docker images 查看構(gòu)建的鏡像。

啟動容器可以直接使用 docker run 命令后面跟啟動參數(shù)啟動,這樣做不好的地方每次啟動項(xiàng)目,都要輸入一 長串命令,不便于使用,在docker-compose.yml文件里面編寫啟動命令,可以更好的管理啟動命令,所以推薦使用docker-compose.yml文件方式。

在項(xiàng)目目錄使用 docker compose up -d 命令啟動就可以,docker compose up -d,帶上 -d 是非阻塞的,不阻塞當(dāng)前的命令窗口。使用 docker logs -f 容器id 或者 容器名稱 可以查看啟動日志。

總結(jié)

僅為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Docker如何解決tomcat容器啟動成功,無法訪問的問題

    Docker如何解決tomcat容器啟動成功,無法訪問的問題

    這篇文章主要介紹了Docker如何解決tomcat容器啟動成功,無法訪問的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 如何使用Docker和cpolar在Linux服務(wù)器上搭建DashDot監(jiān)控面板

    如何使用Docker和cpolar在Linux服務(wù)器上搭建DashDot監(jiān)控面板

    本文主要介紹如何在Linux服務(wù)器上使用Docker和cpolar技術(shù)搭建DashDot監(jiān)控面板,實(shí)現(xiàn)實(shí)時服務(wù)器監(jiān)控,DashDot提供直觀的監(jiān)控界面和豐富的指標(biāo),通過cpolar可以實(shí)現(xiàn)公網(wǎng)訪問,方便用戶隨時了解服務(wù)器狀態(tài),文章詳細(xì)說明了環(huán)境準(zhǔn)備、安裝Docker、配置DashDot和cpolar的步驟
    2024-09-09
  • Docker搭建MySQL雙主復(fù)制詳細(xì)教程

    Docker搭建MySQL雙主復(fù)制詳細(xì)教程

    Docker MySQL 雙主復(fù)制是一種數(shù)據(jù)庫高可用和數(shù)據(jù)冗余的技術(shù),它利用 Docker 容器化的優(yōu)勢,在兩個或多臺MySQL服務(wù)器上同時運(yùn)行并維護(hù)數(shù)據(jù)庫副本,這兩個主服務(wù)器可以互相同步數(shù)據(jù)更新,本文給大家介紹了Docker搭建MySQL雙主復(fù)制詳細(xì)教程,需要的朋友可以參考下
    2024-07-07
  • docker如何修改容器ip范圍

    docker如何修改容器ip范圍

    這篇文章主要介紹了docker如何修改容器ip范圍問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 如何使用docker創(chuàng)建minio鏡像并上傳文件并提供demo

    如何使用docker創(chuàng)建minio鏡像并上傳文件并提供demo

    這篇文章主要介紹了使用docker創(chuàng)建minio鏡像并上傳文件,提供demo,minio還是很方便的,從部署到使用,都可以非??焖俚拇罱?而且比較穩(wěn)定,需要的朋友可以參考下
    2023-09-09
  • -bash:?docker-compose未找到命令的解決方案

    -bash:?docker-compose未找到命令的解決方案

    這篇文章主要介紹了-bash:?docker-compose:?未找到命令,需要的朋友可以參考下
    2023-12-12
  • Docker?容器跨主機(jī)通信?overlay的詳細(xì)步驟

    Docker?容器跨主機(jī)通信?overlay的詳細(xì)步驟

    Overlay網(wǎng)絡(luò)通過VXLAN技術(shù)創(chuàng)建虛擬網(wǎng)絡(luò),實(shí)現(xiàn)不同主機(jī)上容器的邏輯連接,支持跨主機(jī)通信,具有擴(kuò)展性、隔離性和靈活性,適用于大規(guī)模容器化部署
    2024-10-10
  • Docker desktop安裝mysql過程

    Docker desktop安裝mysql過程

    文章介紹了如何在本地已有的Docker環(huán)境中拉取并啟動MySQL容器,并詳細(xì)說明了常用的環(huán)境變量參數(shù),此外,還討論了如何通過掛接本地磁盤來持久化MySQL數(shù)據(jù),從而避免數(shù)據(jù)丟失
    2024-12-12
  • Docker自定義JDK鏡像并拉取至阿里云鏡像倉庫超詳細(xì)攻略

    Docker自定義JDK鏡像并拉取至阿里云鏡像倉庫超詳細(xì)攻略

    Docker倉庫是集中存放鏡像的地方,分為公共倉庫和私有倉庫,這篇文章主要給大家介紹了關(guān)于Docker自定義JDK鏡像并拉取至阿里云鏡像倉庫的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08
  • docker-compose安裝yml文件配置方式

    docker-compose安裝yml文件配置方式

    這篇文章主要介紹了docker-compose安裝,yml文件配置,離線安裝及在線安裝的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12

最新評論