您好,登錄后才能下訂單哦!
Docker中怎么搭建一個(gè)java運(yùn)行環(huán)境,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
首先還是要打好自己的jar包而后編寫(xiě)dockerfile文件:
FROM openjdk:8-jdk-alpine ENV LANG C.UTF-8 RUN apk --update add ttf-dejavu && \ rm -rf /var/cache/apk/* MAINTAINER "haolin#189.cn" LABEL description="jarrunner" WORKDIR app ADD admin.jar /app/app.jar EXPOSE 8081 CMD java -jar /app/app.jar
主要是添加字體庫(kù)。
完成之后執(zhí)行docker build -t 用戶名/鏡像名:1.01 . 就可以完成鏡像封裝了
通過(guò)docker image ls查看鏡像就能看到打好的鏡像包。
而后構(gòu)建docker-compose文件,通過(guò)設(shè)置映射目錄將運(yùn)行目錄下的app目錄映射到docker中,jar包改名為app.jar即可。
volumes:
- ./app:/app
本人還是建議docker和mysql打包到一起:
version: '3' services: app: container_name: XXXX_app image: haol666/XXXX:1.01 network_mode: "service:mysql" volumes: - ./app:/app depends_on: - mysql mysql: container_name: xxxx_mysql image: mysql:5.7 command: --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci --explicit_defaults_for_timestamp=true --lower_case_table_names=1 --max_allowed_packet=128M --sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO" environment: TZ: Asia/Shanghai MYSQL_DATABASE: XXXX MYSQL_ROOT_PASSWORD: XXXX MYSQL_USER: 'XXXX' MYSQL_PASS: 'XXXX' MYSQL_HOST: '%' volumes: - ./data:/var/lib/mysql ports: - "8080:443" expose: - "8080"
配置完成之后通過(guò):
docker-compose up創(chuàng)建鏡像
通過(guò)docker-compose start啟動(dòng)鏡像
通過(guò)docker-compose stop停止鏡像
docker-compose down刪除鏡像。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。