Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

前端自动化部署 #60

Open
huangchucai opened this issue Dec 2, 2019 · 0 comments
Open

前端自动化部署 #60

huangchucai opened this issue Dec 2, 2019 · 0 comments

Comments

@huangchucai
Copy link
Owner

huangchucai commented Dec 2, 2019

前端自动化部署

由于本人最近在公司搭建Jenkins自动部署方面,特意总结一下关于前端自动化部署的使用,本文主要从4个方面来讲述整个流程

  1. docker的介绍
  2. 使用docker构建Jenkins
  3. Jenkins自动化发布
  4. Nginx反向代理

Docker

1. 基本概念:

Docker是一个开放源代码软件项目,让应用程序部署在软件货柜下的工作可以自动化进行,借此在Linux操作系统上,提供一个额外的软件抽象层,以及操作系统层虚拟化的自动管理机制[1]

2. 核心概率:

Docker中有2个核心镜像(image)和容器(container

镜像 : 是由一系列的只读的层构建,每一层对应DockerFile里面的声明构成。如果你有装过 Windows 操作系统,那么 Docker 镜像特别像“Win7纯净版.rar”文件

容器: 容器(container)的定义和镜像(image)几乎一模一样,也是一堆层的统一视角,唯一区别在于容器的最上面那一层是可读可写的。

要点:容器 = 镜像 + 读写层

image

3.服务器上安装docker
# 1. 更新软件库
yum update -y
# 2. 安装docker
yum install docker -y
# 3. 启动docker
service docker start
# 4. 停止docker服务
service docker stop
# 5. 重启docker
service docker restart  
4. 自己构建镜像和容器

简单的通过docker搭建一个Nginx静态服务器,首先我们需要一下步骤

  1. 通过Dockerfile来构建docker镜像 (类似于package.json一个声明文件)

    # 1. 创建目录和文件
    mkdir docker-nginx && cd docker-nginx 
    touch index.html && echo '<h1>hcc</h1>' >> index.html
    
    # 2. 创建一个Dockerfile 来构建镜像
    FROM nginx # 使用Nginx作为镜像
    COPY ./index.html /usr/share/nginx/html/index.html  # 将宿主机中的./index.html文件复制进容器里的/usr/share/nginx/html/index.html
    EXPOSE 80 # 容器对外暴露80端口
    .
    ├── Dockerfile
    └── index.html
    
    # 创建docker镜像
    docker image build ./ -t docker-nginx:1.0.0 
    
    **解释**:基于路径./(当前路径)打包一个镜像,镜像的名字是docker-nginx,版本号是1.0.0。该命令会自动寻找Dockerfile来打包出一个镜像

    运行成功的话,可以得出下面的输出

    Step 1/3 : FROM nginx
     ---> 540a289bab6c
    Step 2/3 : COPY ./index.html /usr/share/nginx/html/index.html
     ---> Using cache
     ---> 169392a59f9c
    Step 3/3 : EXPOSE 80
     ---> Using cache
     ---> f4c34e7f6973
    Successfully built f4c34e7f6973
    Successfully tagged docker-nginx:1.00

Tips: 可以通过docker image ls | docker images 查看本机的镜像

  1. 通过镜像来构建容器

     docker container create -p 9998:80 docker-nginx:1.0.0
  2. 启动容器搭建静态服务器

    docker container start xxx # xxx 为上一条命令运行得到的结果(容器ID)

通过上面一系列操作,我们可以打开127.0.0.1:9998访问,就可以看到刚刚index.html的内容了。

总结:

  • 在第二步中,我们使用docker container create来创建基于docker-nginx:1.0.0镜像的一个容器,使用-p来指定端口绑定-将容器中的80端口绑定在宿主机的2333端口。执行完该命令,会返回一个容器ID
  • 第三步就是启动这个容器,启动后,可以访问本机的9998端口来达到访问容器内80端口的效果

Tips: 使用docker container ls 查看当前运行的所以容器

拓展:

  • 我们可以使用docker run 来替换第二步构建容器和启动容器(docker run -p 9998:80 docker-nginx:1.0.0)

  • 可以映射Nginx的启动页面到本机的一个文件夹docker run -p 9999:80 -v /Users/huangchucai/temp/nginx-demo:/usr/share/nginx/html docker-nginx:1.0.0

    -v 是一个映射,把本机的某一个目录:容器的目录进行一个对应,然后访问本机的9999就会已本机的目录来启动容器

    我认为docker run命令类似于git pull命令。git pull命令就是git fetch 和 git merge两个命令的组合,同样的,docker run就是docker create和docker start两个命令的组合。但是docker run 会一直卡在当前进程,而docker start 会运行在宿主机后台,可以通过docker run -d参数

  • 容器运行后,我们可以通过-it(交互模式)进入容器内部,就相当于启动了容器内部的命令行(/bin/bash), 让我们可以和容器进行交互,就像远程连接SSH一样

    docker container exec -it xxx /bin/bash  # xxx 为容器ID
    # 然后我们可以查看刚刚创建的nginx的内容 /usr/share/nginx/html
5. Docker 总结
  1. 写一个Dockfile文件用于创建镜像
  2. 使用docker image build 来将Dockfile打包成镜像
  3. 使用docker container create 来根据镜像创建一个容器
  4. 使用docker container start来启动一个创建好的容器

image

Docker搭建Jenkins

1. 查询jenkins镜像 官方文档
docker search jenkins
# 通过官方文档介绍,jenkins镜像已经被废除,请使用jenkins/jenkins

image

2. 拉取最新的镜像
docker pull jenkins/jenkins:lts
3. 启动jenkins镜像
docker run -d -u 0 --privileged --name jenkins-node -p 49003:8080 -v /Users/huangchucai/temp/jenkins-data:/var/jenkins_home jenkins/jenkins:lts

#运行一个镜像为jenkins:latest的容器,命名为jenkins_node1,使用root账号覆盖容器中的账号,赋予最高权限,将容器的/var/jenkins_home映射到宿主机的/root/jenkins_node1目录下,映射容器中8080端口到宿主机49003端口

# -d: 后台运行docker容器
# -u: 为了让容器内部的用户可以访问主机的映射目录(-v)
# -v: 将docker容器内的目录/var/jenkins_home 映射到宿主机的/Users/huangchucai/temp/jenkins-data中
# -name: 容器的名字
# -p: 将容器的8080端口映射到宿主机的49003中
# --privileged  赋予最高权限
4. 访问jenkins

大于1分钟后,jenkins容器启动后,在浏览器输入localhost:49003查看jenkins的启动页面,初始化后,会要你输入一个密码来启动。

image

cat /Users/huangchucai/temp/jenkins-data/secrets/initialAdminPassword

输入密码后,点击继续会进入到插件安装页面,
image

然后点击安装
image

等待安装完成,进入到创建管理员账号界面
image

然后点击完成。回到首页。点击系统管理 => 插件管理
image

然后选择ssh插件(可选插件中),直接安装
image

安装完成后回到系统管理 -> 系统设置
image

�划到Publish over SSH,配置相关参数用户名,密码(服务器密码),服务器ip,,然后点击 Test Configuration,显示success就表示成功。
image

新建一个项目,然后输入项目名称
image

选择源码管理,使用git管理,输入github仓库地址,添加github用户
image

点击添加Jenkins凭证
image

这里可以选择账户名和密码,也可以选择ssh登陆,我这里选择了ssh登陆

#1. 在服务器的任意目录执行
ssh-keygen -t rsa -b 4096 -C "[email protected]"
#2. 然后就会在根目录下面的.ssh创建一个公钥和私钥
cd ~/.ssh
cat id_rsa.pub 
#3. 把输出的公钥放进github的ssh keys中
#4. 把生成的私钥放入下面的jenkins凭证中

image
image

可能的问题(如果没有遇到就跳过)
image

1. 这里是因为有的时候git clone或者ssh操作的时候,会弹出一个框,要求你确认主机的身份,让你输入yes?
2. SSH验证的关键一步是,你必须手动确认对方主机的身份
3. 所以要解决这个问题很简单,登陆到jenkins所在的服务器上,确保你手动运行报错截图里的那个命令不会弹出yes
# 如果是docker,就是用docker exec -it .... 进入容器内部运行git clone操作

# 输入yes ,然后查看一下~/.ssh/known_hosts 这个文件 

# 下次就会不会在要求输入yes了, 因为已经识别了github的host, 但是对容器的改动在容器重启后就会丢失,所以需要在~/.ssh/config 配置不需要检查host key
host *
  StrictHostKeyChecking no

image

完成源码配置后,选中构建环境
image

输入下面的代码

sudo docker stop nodeapp || true \
 && sudo docker rm nodeapp || true \
 && cd /root/jenkins_node1/workspace/node  \
 && sudo docker build --rm --no-cache=true  -t node  - < Dockerfile \
 && sudo docker run -d --privileged=true --name nodeapp -p 3000:3000 -v /root/jenkins_node1/workspace/node:/home/project node

保存后,点击立即构建

构建成功后,可以在宿主机的目录/root/jenkins_node1/workspace/node下看到你的项目文件了

在浏览器输入 docker服务器地址 localhost:3000 即可访问到页面信息

Tips: 构建失败,可以查看日志来判定失败原因 docker logs nodeapp

jenkins + github 自动部署

如果想本地代码提交push到github后,jenkins自动拉取最新代码重新部署

1. 回到首页,点击用户列表

image

2.点击左边栏的设置,然后show token

image

3. 复制API Token中的值
4. 返回到首页 -> node -> 配置 -> 构建触发器 粘贴到身份验证令牌 中

image

5. 登陆到你的github项目页面 打开 Setting -> Webhooks -> Add webhooks

image

6. 添加webhooks

image

7. 去掉Jenkins的安全策略

image

验证:
当我们push到仓库的时候,
image
image

至此,已完成 git push 后,jenkins 自动构建自动部署。参考webhook为什么要取消安全策略

Nginx反向代理

经过上面的一系列的配置,我们可以访问服务器的49003端口,就可以看到Jenkins页面,例如我的:http://122.51.225.116:49003/

但是我们想这个访问的时候,取消掉这个端口的设置,所以在服务器上配置一个Nginx静态服务器用于转换。

这里在服务器上启动一个Nginx,让他完全的占有服务器的80端口,然后它根据不同的域名进行分发
image

登录服务器,然后切换到Nginx配置文件
# 1. 切换目录
cd /etc/nginx/conf.d
# 2. 配置Nginx服务
touch nginx-docker.conf && vim nginx-docker.conf
# 3. 配置内容
server {
    listen 80;
    server_name www.huangchucai.cn;  // 不同的分发的域名

    location / {
        proxy_pass http://127.0.0.1:49003;  //本机的端口
    }
}
# 4. 重启Nginx服务
systemctl reload nginx.service

配置后,我们就可以访问http://www.huangchucai.cn/ 来访问我们刚刚启动的服务器了

参考链接

10张图带你深入理解Docker容器和镜像
从零搭建docker+jenkins+node.js自动化部署环境
写给前端的Docker实战教程

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant