准备前端文件目录
使用 npm run build 命令将vue项目打包,生成dist目录。
将文件夹放到服务器上,我们这里是放到了服务器的 /usr/local 目录下
编写构建脚本
1.在当前目录新建Dockfile文件
Dockerfile
# 指定基础镜像,必须为第一个命令 # 可以使用镜像ID或者镜像名称 例如 nginx:1.14 FROM bb52fc3d3709 # 维护者信息 MAINTAINER su # 将本地文件添加到容器中 # 将dist文件中的内容复制到 /usr/local/nginx/html/ 这个目录下面,该路径是nginx容器生成的一个虚拟路径,你的项目会存在这里。 COPY dist/ /usr/local/nginx/html/ COPY nginx.conf /etc/nginx/nginx.conf # 构建镜像时执行的命令 RUN echo 'echo init ok!!'
注:如果指定的基础镜像没有找到的话,会自动从仓库中pull对应的镜像。这里还有一种情况,如果是内网情况并且镜像仓库中没有所需要的镜像。可以在有这个镜像的服务器上先导出镜像,然后再复制到当前服务器进行导入即可。
# nginx.tar是导出tar包的文件名, # nginx:1.14是仓库中的镜像名称,这里也可以直接使用镜像ID # 导出镜像 docker save -o nginx.tar nginx:1.14 # 导入镜像,nginx.tar就是刚才导出的包 docker load -i nginx.tar
2.在当前目录新建nginx配置文件 nginx.conf (注:nginx代理目录就是刚才在Dockerfile文件中配置的虚拟目录 /usr/local/nginx/html/ )
nginx.conf
worker_processes auto; #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' # '$status $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; client_max_body_size 20m; server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root /usr/local/nginx/html; index index.html index.htm; try_files $uri $uri/ /index.html; } #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; #} } # another virtual host using mix of IP-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} }
构建镜像
命令(注意最后的 . 不可省略)
docker build -t test-vue:V1.0.0 .
5c238751e488就是构建完成后生成的镜像ID
启动镜像
# run: 创建一个新的容器并运行一个命令 # -d: 后台运行容器,并返回容器ID # -p: 端口映射,格式为:主机(宿主)端口:容器端口 # --name="npmcs-test": 为容器指定一个名称 docker run -p 8181:80 -d --name npmcs-test 5c238751e488
使用docker ps查看运行状态,可以发现已经成功启动该镜像。
测试
访问http://ip:8181进行测试
部署完毕后可以删除 /usr/local/dist 目录,不会影响镜像的运行。
EOF