基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins( 二 )


+ compose- docker-compose.yml// docker-compose执行文件+ nginx + conf.d- nginx.conf// Nginx配置+ jenkins- jenkins_home// Jenkins挂载卷+ webserver -static//存放前端打包后的dist文件Web server目录属于后期生成暂不讨论,需要手动创建的是Compose,Nginx和Jenkins目录及其下属文件,其中最主要的是docker-compose.yml文件和nginx.conf文件的配置 。以上文件夹建议放在根目录下面,可以放在home文件夹之下也可以单独创建一个新的文件夹 。
 
docker-compose.yml文件配置version: '3'services:# 集合docker_jenkins:user: root# 为了避免一些权限问题 在这我使用了rootrestart: always# 重启方式image: jenkins/jenkins:lts# 指定服务所使用的镜像 在这里我选择了 LTS (长期支持)container_name: jenkins# 容器名称ports:# 对外暴露的端口定义- 8080:8080- 50000:50000volumes:# 卷挂载路径- /home/jenkins/jenkins_home/:/var/jenkins_home# 这是我们一开始创建的目录挂载到容器内的jenkins_home目录- /var/run/docker.sock:/var/run/docker.sock- /usr/bin/docker:/usr/bin/docker# 这是为了我们可以在容器内使用docker命令- /usr/local/bin/docker-compose:/usr/local/bin/docker-composedocker_nginx:restart: alwaysimage: nginxcontainer_name: nginxports:- 8090:80- 80:80- 433:433volumes:- /home/nginx/conf.d/:/etc/nginx/conf.d- /home/webserver/static/jenkins/dist/dist:/usr/share/nginx/html 
nginx.conf文件配置server{listen80;root /usr/share/nginx/html;index index.html index.htm;} 上述两个文件配置完成之后,需要进入/home/compose目录下面输入以下命令,进行环境的启动:
docker-compose up -d输入docker ps -a 查看容器的情况:

基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


状态显示up,后面的端口号显示如上为正常状态 。在浏览器输入你云服务器的公网IP加上8080的端口号就可以显示如下页面:
基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


注意点:
  • 在此步骤之前,切记一定要开放云服务器的80端口安全组(可以参考提供的一键开通功能),但是除此之外建议手动添加8080端口的安全组 。
  • 80端口:是为HTTP(HyperText Transport Protocol)即超文本传输协议开放的端口 。
  • 8080端口:是被用于WWW代理服务的,可以实现网页浏览 。
上图所需要的密码在docker-compose.yml中的volumes中的/home/jenkins/jenkins_home/secrets/initAdminPassword中 。可以通过以下命令获得:
cat /home/jenkins/jenkins_home/secrets/initialAdminPassword 
安装Jenkins插件进入页面之后,选择推荐安装 。
基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


安装完成之后,选择左侧Manage Jenkins选项 。如下图所示:
基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


 Jenkins中Manage Plugins搜索以下插件GitLab、Publish Over SSH、Nodejs并安装 。
基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


安装完成后配置Nodejs环境和SSH参数 在首页选择global tool Configuration>NodeJS选择自动安装和对应的Nodejs版本号,选择成功后点击保存 。
基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins



基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


配置SSH信息,Manage Jenkins>configure System填写服务器的相关信息:
基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins



基于Docker、Nginx和Jenkins实现前端自动化部署,前端服务器自动化部署Docker、Nginx和Jenkins


 
关联Jenkins和GitLab 
生成密钥在根目录下执行一下命令:

推荐阅读