jenkins + gitflow流程 实现一键自动发布

jenkins + gitflow流程 实现一键自动发布(服务器的知识)
先配置dev2的免密登陆和跳转(对应jenkins上的 例如:wangateway )
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
以上两个是home/dev2 下 dev的脚本命令,jenkins实际执行的就是这个

以下几个是开发人员登陆到服务器看的,脚本差不多一样

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

nginx的docker启动:

docker run \
        --name=nginx \
        --hostname=iZ8vbbq5i0f69sglswx8ddZ \
        --env=PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin \
        --env=NGINX_VERSION=1.19.2 \
        --env=NJS_VERSION=0.4.3 \
        --env='PKG_RELEASE=1~buster' \
        --volume=/opt/dockervols/nginx/ssl:/etc/nginx/ssl \
        --volume=/opt/dockervols/nginx/logs:/var/log/nginx \
        --volume=/opt/dockervols/nginx/nginx.conf:/etc/nginx/nginx.conf \
        --volume=/opt/dockervols/nginx/html:/usr/share/nginx/html \
        --volume=/opt/dockervols/nginx/conf.d:/etc/nginx/conf.d \
        --network=host \
        --expose=80/tcp \
        --restart=always \
        --label='maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>' \
        --log-opt max-size=100m \
        --log-opt max-file=3 \
        --detach=true \
        nginx:1.19 \
        nginx -g 'daemon off;'

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
conf.d/default.conf 文件内容

#正式环境-微信端
server {
    listen 80;
    server_name www.dr2dr.cn;
    rewrite ^(.*) https://$server_name$1 permanent;
}
server {
    listen       443 ssl;
    server_name  www.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;

    access_log  /var/log/nginx/www.access.log  main;

    location / {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         http://127.0.0.1:30080;

        #root   /usr/share/nginx/html/www/;
    }
}


#正式环境-管理后台
server {
    listen 80;
    server_name admin.dr2dr.cn;
    rewrite ^(.*) https://$server_name$1 permanent;
}
server {
    listen       443 ssl;
    server_name  admin.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;

    access_log  /var/log/nginx/admin.access.log  main;

    location / {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        rewrite ^(.*) https://www.dr2dr.cn/admin permanent;
        #root   /usr/share/nginx/html/admin/;
    }
}


#正式环境-api接口
server {
    listen       80;
    listen       443 ssl;
    server_name  apiprod.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    location ~^/bt/ {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         https://127.0.0.1:38088;
        #proxy_ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
        #proxy_ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    }
}
#即将关闭
server {
    listen       8088 ssl;
    server_name  api.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    location ~^/bt/ {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
            proxy_set_header X-Forwarded-Host $host;
            proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         https://127.0.0.1:38088;
        #proxy_ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
        #proxy_ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    }
}

#测试环境-api接口
server {
    listen       80;
    listen       443 ssl;
    server_name  apifrank.dr2dr.cn apitest.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    location ~^/bt/ {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         http://127.0.0.1:38085;
    }
}


#开发环境-api接口
server {
    listen       80;
    listen       443 ssl;
    server_name  apidev.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    location ~^/bt/ {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         http://127.0.0.1:38086;
    }
}



#郑小伟临时测试用api
server {
    listen       443 ssl;
    server_name  apitest1.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    location ~^/bt/ {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         https://127.0.0.1:38087;
        #proxy_ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
        #proxy_ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;
    }
}

#jenkins自动发布api
server {
    listen 80;
    listen       443 ssl;

    server_name  apiautotest.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;

    location ~^/bt/ {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         http://127.0.0.1:38089;
    }
}



#可道云
server {
    listen       80;
    server_name  ftp.dr2dr.cn;

    access_log  /var/log/nginx/ftp.access.log  main;

    location / {
         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
         proxy_set_header X-Forwarded-Proto $scheme;
         proxy_set_header X-Forwarded-Host $host;
         proxy_set_header X-Forwarded-Port $server_port;
         proxy_set_header X-Real-Ip $remote_addr;
         proxy_pass http://127.0.0.1:38082/kodexplorer/;
    }
}


#禅道,不这样会有问题
server {
    listen 80;
    server_name zentao.dr2dr.cn;
    rewrite ^(.*) https://$server_name/zentao$1 permanent;
}
server {
    listen       443 ssl;
    server_name  zentao.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;

    location /zentao {
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Forwarded-Port $server_port;
        proxy_pass         http://127.0.0.1:38081/zentao;
    }
}

#测试环境-静态页面,使用二级目录
server {
    listen 80;
    listen 443 ssl;
    server_name test.dr2dr.cn;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;

    proxy_intercept_errors on;
    error_page 400 401 402 403 404 405 408 410 412 413 414 415 500 501 502 503 504 506 /50x.html;
    location = /50x.html {
        root  /usr/share/nginx/html;
    }

    location / {
        access_log  /var/log/nginx/frank.access.log  main;
        root   /usr/share/nginx/html/frank/;
    }

    location ^~/frankadmin {
        access_log  /var/log/nginx/frankadmin.access.log  main;
        root   /usr/share/nginx/html/;
    }

    location ^~/frank {
        access_log  /var/log/nginx/frank.access.log  main;
        root   /usr/share/nginx/html/;
    }

    location ^~/devadmin {
        access_log  /var/log/nginx/devadmin.access.log  main;
        root   /usr/share/nginx/html/;
    }

    location ^~/dev {
        access_log  /var/log/nginx/dev.access.log  main;
        root   /usr/share/nginx/html/;
    }

    location ^~/autotestadmin {
        access_log  /var/log/nginx/autotestadmin.access.log  main;
        root   /usr/share/nginx/html/;
    }

    location ^~/autotest {
        access_log  /var/log/nginx/autotest.access.log  main;
        root   /usr/share/nginx/html/;
    }
}


#默认返回403
server {
    listen 80 default_server;
    listen 443 ssl default_server;
    server_name _;
    ssl_certificate   /etc/nginx/ssl/4313816__dr2dr.cn.pem;
    ssl_certificate_key   /etc/nginx/ssl/4313816__dr2dr.cn.key;

    return 403;
}

vue静态文件 最终在这,对应环境的文件夹下面
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Jenkins是一个开源的持续集成工具,可实现自动化构建、测试和部署。Spring Boot是一个基于Spring框架的轻量级Web应用开发框架,提供了快速构建Web应用的开发环境。Maven是一个基于项目对象模型(POM)的项目管理工具,可用于构建、依赖管理和部署。SVN是一种源代码管理工具,可用于协作开发和版本控制。 将这些工具组合起来,可实现一键打包发布。首先,在Jenkins中创建一个新的构建项目,并选择Maven项目类型。然后,配置SVN源代码管理,在构建触发器中设置定时执行构建任务。接着,在Maven构建中设置pom.xml文件路径和构建命令,确保能够成功构建Spring Boot应用程序。最后,将打包后的应用程序上传到远程服务器,并启动应用程序部署脚本。 通过这个过程,我们可以实现自动化构建、测试和部署,简化部署流程并提高生产效率。同时,通过与Jenkins、Spring Boot、Maven和SVN的结合,可以实现更完整的持续集成和持续交付过程。 ### 回答2: Jenkins、Spring Boot、Maven 和 SVN 都是非常流行的开发工具和框架。其中,Jenkins 是一个开放源代码的自动化部署工具,它可以自动构建、测试和部署软件。Maven 是一个对象中心的开发工具,它可以自动编译、测试和部署软件。Spring Boot 是一个开发框架,它可以轻松地构建和部署 Web 应用程序。而 SVN 则是一个用于版本控制的工具,它可以帮助开发人员协同工作,追踪历史记录等。 对于这种情况,我们可以使用 Jenkins 进行自动化部署和打包发布。下面是该过程的步骤: 1. 安装 Jenkins:首先,你需要安装 Jenkins。可以通过下载 Jenkins 的最新版本来安装它。 2. 配置 Maven:在 Jenkins 中,你需要配置 Maven。在 Jenkins 主页的“Manage Jenkins”选项中,可以找到“Global Tool Configuration”菜单。你需要在这里配置 Maven,包括指定 Maven 的路径和版本。 3. 配置构建步骤:在 Jenkins 中,你可以配置构建步骤。在此处你可以通过选择“构建一个 Maven 项目”选项并指定相关的 Maven 工程,然后再指定命令执行变量等。 4. 编写脚本:Jenkins 支持脚本编写,你可以通过写 shell 脚本或者 Windows 批处理来执行构建和部署操作,指定 Maven 打包的相关参数,自动化编译打包、部署到服务器等操作。 5. 配置 SVN:Jenkins 配置 SVN 的方式也非常简单,在 Jenkins 主页中,你可以通过创建装载 SVN 仓库的插件来配置 SVN。 6. 执行自动化部署:最后,你需要执行自动化部署。你可以在 Jenkins 中添加定时任务或在被检测到有 SVN 代码提交后进行自动化的部署。 总之,使用 Jenkins 自动化部署的好处在于,它可以大大提高开发效率,减少手动操作,降低出错率,并且它可以随时进行监控和定位问题,有效的提高项目的质量,降低运维成本。 ### 回答3: Jenkins是一个开源的自动化部署工具,可以非常方便地实现一键打包、构建和发布。在使用Jenkins进行springboot maven svn部署时,需要进行如下几个步骤: 1. 安装Jenkins 首先需要在服务器上安装JenkinsJenkins支持多种操作系统,可以根据具体情况进行选择安装方法。 2. 安装必要的插件 需要在Jenkins中安装必要的插件,主要包括Maven Integration plugin、Subversion plugin、Deploy plugin等,这些插件将帮助我们实现源代码的管理、打包构建以及自动部署。 3. 配置JenkinsJenkins中配置SVN、Maven的信息,包括源代码地址、Maven路径等。 4. 编写自动化脚本 根据实际需求,编写自动化脚本来实现构建、测试、打包以及部署,这些脚本可以使用Jenkins提供的Pipeline语法或者其他脚本语言来编写。 5. 执行构建任务 在Jenkins界面上,选择需要构建的项目,点击构建即可,Jenkins将根据自动化脚本执行编译、测试、打包和部署。 6. 验证部署结果 在Jenkins上查看构建结果,如果成功,则可以上线进行测试。如果失败,则需要查看详情并进行修复,以便下次构建成功。 总之,使用Jenkins进行springboot maven svn部署,可以大大提高开发效率,减少手动部署的工作量,不仅在测试、集成和部署等方面提供了更好的支持,还有利于提高应用程序的质量和性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值