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

快去访问一下你的网站吧

相关推荐
ytadpole8 分钟前
揭秘设计模式:命令模式-告别混乱,打造优雅可扩展的代码
java·设计模式
sinat_6020353612 分钟前
模块与包的导入
运维·服务器·开发语言·python
用户37215742613514 分钟前
Java 教程:轻松实现 Excel 与 CSV 互转 (含批量转换)
java
2301_8101545516 分钟前
VM中CentOS 7密码重置
linux·运维·centos
网硕互联的小客服32 分钟前
408 Request Timeout:请求超时,服务器等待客户端发送请求的时间过长。
运维·服务器
王伯安呢35 分钟前
告别线缆束缚!AirDroid Cast 多端投屏,让分享更自由
运维·服务器·教程·投屏·airdroid cast·多端互投
逍遥浪子~39 分钟前
搭建本地gitea服务器
运维·服务器·gitea
叫我阿柒啊42 分钟前
Java全栈开发实战:从基础到微服务的深度解析
java·微服务·kafka·vue3·springboot·jwt·前端开发
喜欢你,还有大家1 小时前
FTP文件传输服务
linux·运维·服务器·前端
凯尔萨厮1 小时前
Java学习笔记三(封装)
java·笔记·学习