Dockerfile打包部署

Dockerfile打包

先找到打包完的目录下创建一个Dockerfile文件

复制代码
touch Dockerfile

进去文件内编写

复制代码
vim Dockerfile

基础镜像

FROM openjdk:8

author

MAINTAINER yxh

挂载目录

VOLUME /home/project

创建目录

RUN mkdir -p /home/project

指定路径

WORKDIR /home/project

复制jar文件到路径

COPY medical-gateway.jar /home/project/medical-gateway.jar

启动认证服务

ENTRYPOINT ["java","-jar","/home/project/medical-gateway.jar"]

保存并退出

复制代码
:wq!

构建镜像(my-task -> 取一个镜像名字,构建镜像后面是有一个**'.'**的)

复制代码
docker build -t my-task .

启动镜像

复制代码
docker run -d -p 18080:18080 --name task my-task

-d 容器在后台运行

-p 将宿主机的 8080 端口映射到容器的 8080 端口。

--name 取一个容器名

最后面的my-task指的是刚才打包的镜像名

jar部署

判断是否有openjdk有的话可以跳过

拉取openjdk镜像 如果拉不下来就切换镜像

复制代码
docker pull openjdk

cd /usr

mkdir project

cd project

将jar包拖入目录中

复制代码
touch Dockerfile

vim Dockerfile

基础镜像

FROM openjdk:8

author

MAINTAINER yxh

挂载目录

VOLUME /home/project

创建目录

RUN mkdir -p /home/project

指定路径

WORKDIR /home/project

复制jar文件到路径

COPY medical-gateway.jar /home/project/medical-gateway.jar

启动认证服务

ENTRYPOINT ["java","-jar","/home/project/medical-gateway.jar"]

保存并退出

复制代码
:wq!

构建镜像

复制代码
docker build -t my-gateway .

启动镜像

复制代码
docker run -d -p 18080:18080 --name gateway my-gateway

如果发现端口号被占用

netstat -anp |grep 18080//查看18080端口的占用情况

查看端口号占用进程

复制代码
lsof -i :18080

关闭进程

复制代码
kill -9 18080

再次启动镜像

复制代码
docker run -d -p 18080:18080 --name gateway my-gateway

nginx打包部署

我那vue举例

先通过命令将前端工程打包

复制代码
vue-cli-service build

打完包有个dist

现在去服务器上

复制代码
cd /opt

创建nginx目录

复制代码
mkdir nginx

cd nginx

把dist拉到该目录下

先检查一下是否有nginx镜像

复制代码
docker pull nginx

创建nginx配置

复制代码
touch nginx.conf

vim nginx.conf

server {
    listen 80;
    server_name your_name;


    root /usr/share/nginx/html;
    index index.html;


    location / {
        try_files $uri $uri/ /index.html;
    }


    # 处理API请求
    location /prod-api/ {
        #存放jar网关部署的服务器IP和端口号
        proxy_pass http://IP:端口/;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

保存并退出

复制代码
:wq!

创建default.conf

复制代码
touch default.conf

server {
    listen       80;
    server_name  124.70.138.156;
 
    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;
 
    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }
 
    #error_page  404              /404.html;
 
    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   html;
    }
 
    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}
 
    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}
 
    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

保存并退出

复制代码
:wq!

在该目录下创建Dockerfile

复制代码
touch Dockerfile

vim Dockerfile

使用nginx镜像

FROM nginx

作者

MAINTAINER yxh

删除nginx 默认配置

RUN rm /etc/nginx/conf.d/default.conf

添加我们自己的配置 default.conf 在下面

ADD default.conf /etc/nginx/conf.d/

把刚才生成dist文件夹下的文件copy到nginx下面去

COPY dist/ /usr/share/nginx/html/

保存并退出

复制代码
:wq!

构建镜像

复制代码
docker build -t my-vue-app .

启动镜像

复制代码
docker run -d -p 80:80 --name vue-app my-vue-app

快去访问一下你的网站吧

相关推荐
明月(Alioo)24 分钟前
给 AI Agent 装上“大脑“:Java语言中Code Interpreter 的设计与实现
java·ai·agent
QuZero26 分钟前
StampedLock Mechanism
java·算法
Javatutouhouduan29 分钟前
Java小白如何快速玩转Redis?
java·数据库·redis·分布式锁·java面试·后端开发·java程序员
xuhaoyu_cpp_java30 分钟前
Spring学习(一)
java·经验分享·笔记·学习·spring
kybs19911 小时前
springboot视频推荐系统--附源码72953
java·spring boot·python·eclipse·asp.net·php·idea
无限进步_1 小时前
C++ 多态机制完全解析:从虚函数重写到动态绑定原理
java·c语言·jvm·数据结构·c++·windows·后端
数智顾问1 小时前
(123页PPT)华为流程管理体系精髓提炼(附下载方式)
运维·华为
知识汲取者2 小时前
巨量引擎 Marketing API Java SDK 介绍
java·开发语言
182******20832 小时前
2026年40岁自学java还能找到工作吗
java·开发语言
yuzhiboyouye2 小时前
java线程池
java·开发语言·firefox