1
0
DavidZhang73.github.io/jenkins-update-solution-inside-gfw/index.html

478 lines
21 KiB
HTML
Raw Normal View History

2020-02-21 16:28:53 +08:00
<!DOCTYPE html>
<html lang="zh-CN" class="loading">
<head>
<!-- hexo-inject:begin --><!-- hexo-inject:end --><meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no">
<title>墙内 Jenkins 插件下载的一种解决方案 - Blog</title>
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
<meta name="google" content="notranslate" />
<meta name="keywords" content="Developer, Python, C++, JavaScript, Java,">
2020-02-22 14:53:35 +08:00
<meta name="description" content="DavidZ&#39;s Blog,
原创发表于 DavidZ Blog遵循 CC 4.0 BY-NC-SA 版权协议,转载请附上原文出处链接及本声明。
¶前言
闲来无聊,在家折腾 DevOps第一步当然是部署一个 Jenkin,">
2020-02-21 16:28:53 +08:00
<meta name="author" content="DavidZ">
<link rel="alternative" href="atom.xml" title="Blog" type="application/atom+xml">
<link rel="icon" href="/img/favicon.png">
<link rel="stylesheet" href="//at.alicdn.com/t/font_1429596_nzgqgvnmkjb.css">
<link rel="stylesheet" href="//cdn.bootcss.com/animate.css/3.7.2/animate.min.css">
<link rel="stylesheet" href="//cdn.bootcss.com/social-share.js/1.0.16/css/share.min.css">
<link rel="stylesheet" href="//cdn.bootcss.com/codemirror/5.48.4/codemirror.min.css">
<link rel="stylesheet" href="//cdn.bootcss.com/codemirror/5.48.4/theme/dracula.css">
<link rel="stylesheet" href="/css/obsidian.css">
<link rel="stylesheet" href="/css/ball-atom.min.css">
2021-01-22 17:50:40 +08:00
2020-02-21 16:28:53 +08:00
<meta name="generator" content="Hexo 4.2.0"><!-- hexo-inject:begin --><!-- hexo-inject:end --></head>
<body class="loading">
<!-- hexo-inject:begin --><!-- hexo-inject:end --><div class="loader">
<div class="la-ball-atom la-2x">
<div></div>
<div></div>
<div></div>
<div></div>
</div>
</div>
<span id="config-title" style="display:none">Blog</span>
<div id="loader"></div>
<div id="single">
<div class="scrollbar gradient-bg-rev"></div>
<div id="top" style="display: block;">
<div class="bar" style="width: 0;"></div>
<div class="navigation animated fadeIn fast delay-1s">
<img id="home-icon" class="icon-home" src="/img/favicon.png" alt="" data-url="https://blog.davidz.cn">
<div id="play-icon" title="Play/Pause" class="iconfont icon-play"></div>
<h3 class="subtitle">墙内 Jenkins 插件下载的一种解决方案</h3>
<div class="social">
<!-- <div class="like-icon">-->
<!-- <a href="javascript:;" class="likeThis active"><span class="icon-like"></span><span class="count">76</span></a>-->
<!-- </div>-->
<div>
<div class="share">
<a href="javascript:;" class="iconfont icon-share1"></a>
<div class="share-component-cc" data-disabled="facebook,douban,linkedin,diandian,tencent,google"></div>
</div>
</div>
</div>
</div>
</div>
<div class="section">
<div class=article-header-wrapper>
<div class="article-header">
<div class="article-cover animated fadeIn" style="
animation-delay: 600ms;
animation-duration: 1.2s;
background-image:
radial-gradient(ellipse closest-side, rgba(0, 0, 0, 0.65), #100e17),
2020-09-07 21:52:27 +08:00
url(https://davidz-blog.oss-cn-beijing.aliyuncs.com/img/下载超时-1599485061.png) ">
2020-02-21 16:28:53 +08:00
</div>
<div class="else">
<p class="animated fadeInDown">
<a href="/categories/DevOps"><b>
</b>DEVOPS<b></b></a>
二月 21, 2020
</p>
<h3 class="post-title animated fadeInDown"><a href="/jenkins-update-solution-inside-gfw/" title="墙内 Jenkins 插件下载的一种解决方案" class="">墙内 Jenkins 插件下载的一种解决方案</a>
</h3>
<p class="post-count animated fadeInDown">
<span>
<b class="iconfont icon-text2"></b> <i>文章字数</i>
2020-02-22 14:53:35 +08:00
2.8k
2020-02-21 16:28:53 +08:00
</span>
<span>
<b class="iconfont icon-timer__s"></b> <i>阅读约需</i>
2020-02-22 14:53:35 +08:00
3 mins.
2020-02-21 16:28:53 +08:00
</span>
<span id="busuanzi_container_page_pv">
<b class="iconfont icon-read"></b> <i>阅读次数</i>
<span id="busuanzi_value_page_pv">0</span>
</span>
</p>
<ul class="animated fadeInDown post-tags-list" itemprop="keywords"><li class="animated fadeInDown post-tags-list-item"><a class="animated fadeInDown post-tags-list-link" href="/tags/Linux/" rel="tag">Linux</a></li></ul>
</div>
</div>
</div>
<div class="screen-gradient-after">
<div class="screen-gradient-content">
<div class="screen-gradient-content-inside">
<div class="bold-underline-links screen-gradient-sponsor">
<p>
<span class="animated fadeIn delay-1s"></span>
</p>
</div>
</div>
</div>
</div>
<div class="article">
<div class='main'>
<div class="content markdown animated fadeIn">
2020-02-22 14:53:35 +08:00
<blockquote>
<p>原创发表于 <a href="https://blog.davidz.cn">DavidZ Blog</a>,遵循 <a href="https://creativecommons.org/licenses/by-nc-sa/4.0/legalcode" target="_blank" rel="noopener">CC 4.0 BY-NC-SA</a> 版权协议,转载请附上原文出处链接及本声明。</p>
</blockquote>
<h2 id="前言"><a class="header-anchor" href="#前言"></a>前言</h2>
2020-02-21 16:28:53 +08:00
<p>闲来无聊,在家折腾 DevOps第一步当然是部署一个 Jenkins 啦,然而一顿操作猛如虎,插件一个都下载不下来,总不能给 Jenkins 加个代理吧,所以有了下面这一通折腾。</p>
<h2 id="原因"><a class="header-anchor" href="#原因"></a>原因</h2>
2020-09-07 21:52:27 +08:00
<p><img src="https://davidz-blog.oss-cn-beijing.aliyuncs.com/img/%E4%B8%8B%E8%BD%BD%E8%B6%85%E6%97%B6-1599485061.png" alt="下载超时"></p>
2020-02-21 19:21:10 +08:00
<p>根据经验,国外这些软件下载失败基本上都是因为链接不上服务器,换个源就好了。所以简单百度,找到大量相关教程,换了<a href="https://mirrors.tuna.tsinghua.edu.cn/" target="_blank" rel="noopener">清华源</a>在内的四五个镜像源,均无效。</p>
2020-02-21 16:28:53 +08:00
<p>这就非常奇怪了,所以我打开了清华源的<a href="https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json" target="_blank" rel="noopener">update-center.json</a>,仔细看了看,发现了蹊跷之处。原来,这个文件里面基本上所有插件的链接都指向了官网链接<code>http://updates.jenkins-ci.org/download/plugins/</code>。所以我们使用<code>https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json</code>只加速了下载这个文件的过程,而并没有加速下载插件的过程。</p>
<h2 id="解决方案"><a class="header-anchor" href="#解决方案"></a>解决方案</h2>
<p>那么解决方案就很简单了,我们只需要把<code>/var/jenkins_home/updates/default.json</code>这个文件中的所有</p>
<pre><code class="language-htmlmixed">http://updates.jenkins-ci.org/download/plugins/
</code></pre>
<p>替换成,</p>
<pre><code class="language-htmlmixed">https://mirrors.tuna.tsinghua.edu.cn/jenkins/plugins/
</code></pre>
<p>这样就好啦,但是总不能每次都自己手动替换吧,所以有下面这两个稍微复杂一点的自动化解决方案。</p>
<h3 id="方案-1-使用-nginx-重定向"><a class="header-anchor" href="#方案-1-使用-nginx-重定向"></a>方案 1 使用 nginx 重定向</h3>
<p>这个方法是参考的<a href="https://my.oschina.net/VASKS/blog/3106314" target="_blank" rel="noopener">jenkins 插件下载加速最终方案</a></p>
<p>具体我没有试,但是我之前写过 Nginx 的重定向,简单来讲就是遇到官方的地址,就重定向到清华源,配置起来稍微复杂一点。</p>
<h3 id="方案-2-自己搭建-Jenkins-Update-Center"><a class="header-anchor" href="#方案-2-自己搭建-Jenkins-Update-Center"></a>方案 2 自己搭建 Jenkins Update Center</h3>
<p>这个是我自己尝试出来的,原理就是我在服务器上定时(每小时)从清华源下载<code>update-center.json</code>,然后再把里面的 URL 替换成正确的地址,然后对外提供服务。</p>
<p>但是 Jenkins 对于<code>update-center.json</code>的地址有验证,<a href="https://github.com/jenkins-zh/mirror-adapter" target="_blank" rel="noopener">具体验证方法</a>不清楚(<s>我实在是懒的研究了</s>)。</p>
<blockquote>
<p>山重水复疑无路,柳暗花明又一村</p>
</blockquote>
<p>我在 Jenkins 的 Issue 里面找到一个<a href="https://issues.jenkins-ci.org/browse/JENKINS-11598?focusedCommentId=212431&amp;page=com.atlassian.jira.plugin.system.issuetabpanels%3Acomment-tabpanel#comment-212431" target="_blank" rel="noopener">老哥</a>说验证这个功能可以通过属性参数关闭,于是,这个问题就很简单啦。</p>
<pre><code class="language-shell">hudson.model.DownloadService.noSignatureCheck=true
</code></pre>
<p>加上这个属性就好啦。</p>
<p><a href="https://jenkins-update.davidz.cn/" target="_blank" rel="noopener">具体教程</a></p>
<p>哈,插件全秒!😄</p>
<!--[if lt IE 9]><script>document.createElement('audio');</script><![endif]-->
<audio id="audio" loop="1" preload="auto" controls="controls"
data-autoplay="false">
2020-09-07 21:52:27 +08:00
<source type="audio/mpeg" src="https://davidz-blog.oss-cn-beijing.aliyuncs.com/music/陈奕迅 - 红玫瑰.mp3">
2020-02-21 16:28:53 +08:00
</audio>
2021-03-18 13:07:04 +08:00
<div class="post-nav">
<hr>
<div class="post-nav-item">上一篇:<a href="/rattle-change-language/" rel="prev"
title="技巧速记:更改 Rattle 的语言">技巧速记:更改 Rattle 的语言
</a></div>
<div class="post-nav-item">下一篇:<a href="/write-latex-report-with-markdown/" rel="next"
title="使用 Markdown 编写基于 Latex 的报告">使用 Markdown 编写基于 Latex 的报告</a></div>
</div>
2020-02-21 16:28:53 +08:00
<div id='gitalk-container' class="comment link"
data-ae='true'
data-ci='489076c5dd3f5ba13f67'
data-cs='d6e3b245787b0b74d0dbe2639ef87f452a401194'
data-r='blog.davidz.cn'
data-o='DavidZhang73'
data-a='DavidZhang73'
data-d=''
>留言</div>
</div>
<div class="sidebar">
<div class="box animated fadeInRight">
<div class="subbox">
2020-09-07 21:52:27 +08:00
<img src="https://davidz-blog.oss-cn-beijing.aliyuncs.com/img/2019-1599483796.jpg" height=300 width=300></img>
2020-02-21 16:28:53 +08:00
<p>DavidZ</p>
<span>凡事都要留几分</span>
<dl>
<dd><a href="https://github.com/DavidZhang73" target="_blank"><span
class=" iconfont icon-github"></span></a></dd>
<dd><a href="https://twitter.com/david731998" target="_blank"><span
class=" iconfont icon-twitter"></span></a></dd>
<dd><a href="https://stackoverflow.com/users/12693553/davidz" target="_blank"><span
class=" iconfont icon-stack-overflow"></span></a></dd>
</dl>
</div>
<ul>
2020-10-09 14:46:16 +08:00
<li><a href="/">15 <p>文章</p></a></li>
2020-10-09 10:48:26 +08:00
<li><a href="/categories">8 <p>分类</p></a></li>
2020-10-09 14:46:16 +08:00
<li><a href="/tags">15 <p>标签</p></a></li>
2020-02-21 16:28:53 +08:00
</ul>
</div>
<div class="box sticky animated fadeInRight faster">
<div id="toc" class="subbox">
<h4>目录</h4>
<ol class="toc"><li class="toc-item toc-level-2"><a class="toc-link" href="#前言"><span class="toc-number">1.</span> <span class="toc-text">¶前言</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#原因"><span class="toc-number">2.</span> <span class="toc-text">¶原因</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#解决方案"><span class="toc-number">3.</span> <span class="toc-text">¶解决方案</span></a><ol class="toc-child"><li class="toc-item toc-level-3"><a class="toc-link" href="#方案-1-使用-nginx-重定向"><span class="toc-number">3.1.</span> <span class="toc-text">¶方案 1 使用 nginx 重定向</span></a></li><li class="toc-item toc-level-3"><a class="toc-link" href="#方案-2-自己搭建-Jenkins-Update-Center"><span class="toc-number">3.2.</span> <span class="toc-text">¶方案 2 自己搭建 Jenkins Update Center</span></a></li></ol></li></ol>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div id="back-to-top" class="animated fadeIn faster">
<div class="flow"></div>
<span class="percentage animated fadeIn faster">0%</span>
<span class="iconfont icon-top02 animated fadeIn faster"></span>
</div><!-- hexo-inject:begin --><!-- hexo-inject:end -->
</body>
<footer>
<p class="copyright" id="copyright">
2021-01-22 17:50:40 +08:00
&copy; 2021
2020-02-21 16:28:53 +08:00
<span class="gradient-text">
DavidZ
</span>.
Powered by <a href="http://hexo.io/" title="Hexo" target="_blank" rel="noopener">Hexo</a>
Theme
<span class="gradient-text">
<a href="https://github.com/TriDiamond/hexo-theme-obsidian" title="Obsidian" target="_blank" rel="noopener">Obsidian</a>
</span>
2021-03-18 13:07:04 +08:00
<small><a href="https://github.com/TriDiamond/hexo-theme-obsidian/blob/master/CHANGELOG.md" title="v1.4.5" target="_blank" rel="noopener">v1.4.5</a></small>
2020-02-21 16:28:53 +08:00
</p>
</footer>
2020-06-05 12:12:10 +08:00
<script type="text/javascript" src="https://cdn.bootcss.com/mathjax/2.7.7/MathJax.js?config=TeX-AMS-MML_HTMLorMML">
2020-02-21 16:28:53 +08:00
</script>
<script>
MathJax.Hub.Config({
"HTML-CSS": {
preferredFont: "TeX",
availableFonts: ["STIX", "TeX"],
linebreaks: {
automatic: true
},
EqnChunk: (MathJax.Hub.Browser.isMobile ? 10 : 50)
},
tex2jax: {
inlineMath: [
["$", "$"],
["\\(", "\\)"]
],
processEscapes: true,
ignoreClass: "tex2jax_ignore|dno",
skipTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code']
},
TeX: {
noUndefined: {
attributes: {
mathcolor: "red",
mathbackground: "#FFEEEE",
mathsize: "90%"
}
},
Macros: {
href: "{}"
}
},
messageStyle: "none"
});
</script>
<script>
function initialMathJax() {
MathJax.Hub.Queue(function () {
var all = MathJax.Hub.getAllJax(),
i;
// console.log(all);
for (i = 0; i < all.length; i += 1) {
all[i].SourceElement().parentNode.className += ' has-jax';
}
});
}
function reprocessMathJax() {
if (typeof MathJax !== 'undefined') {
MathJax.Hub.Queue(["Typeset", MathJax.Hub]);
}
}
</script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<link rel="stylesheet" href="//cdn.bootcss.com/gitalk/1.6.2/gitalk.min.css">
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/gitalk/1.6.2/gitalk.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-02-21 16:28:53 +08:00
<script src="//cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
<script src="/js/plugin.js"></script>
<script src="/js/obsidian.js"></script>
<script src="/js/jquery.truncate.js"></script>
<script src="/js/search.js"></script>
2020-07-17 11:27:08 +08:00
2020-02-21 16:28:53 +08:00
<script src="//cdn.bootcss.com/typed.js/2.0.10/typed.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-02-21 16:28:53 +08:00
<script src="//cdn.bootcss.com/blueimp-md5/2.12.0/js/md5.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-02-21 16:28:53 +08:00
<script src="//cdn.bootcss.com/social-share.js/1.0.16/js/social-share.min.js"></script>
2020-06-05 12:12:10 +08:00
<script src="https://cdn.bootcss.com/codemirror/5.54.0/codemirror.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/javascript/javascript.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/css/css.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/xml/xml.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/htmlmixed/htmlmixed.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/clike/clike.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/php/php.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/shell/shell.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/python/python.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/cmake/cmake.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/powershell/powershell.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-06-05 12:12:10 +08:00
<script src="//cdn.bootcss.com/codemirror/5.54.0/mode/yaml/yaml.min.js"></script>
2020-07-17 11:27:08 +08:00
2020-02-21 16:28:53 +08:00
<script src="/js/busuanzi.min.js"></script>
2020-07-17 11:27:08 +08:00
<script>
$(document).ready(function () {
if ($('span[id^="busuanzi_"]').length) {
initialBusuanzi();
}
});
</script>
2020-02-21 16:28:53 +08:00
<link rel="stylesheet" href="//cdn.bootcss.com/photoswipe/4.1.3/photoswipe.min.css">
<link rel="stylesheet" href="//cdn.bootcss.com/photoswipe/4.1.3/default-skin/default-skin.min.css">
<script src="//cdn.bootcss.com/photoswipe/4.1.3/photoswipe.min.js"></script>
<script src="//cdn.bootcss.com/photoswipe/4.1.3/photoswipe-ui-default.min.js"></script>
<!-- Root element of PhotoSwipe. Must have class pswp. -->
<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true">
<!-- Background of PhotoSwipe.
It's a separate element as animating opacity is faster than rgba(). -->
<div class="pswp__bg"></div>
<!-- Slides wrapper with overflow:hidden. -->
<div class="pswp__scroll-wrap">
<!-- Container that holds slides.
PhotoSwipe keeps only 3 of them in the DOM to save memory.
Don't modify these 3 pswp__item elements, data is added later on. -->
<div class="pswp__container">
<div class="pswp__item"></div>
<div class="pswp__item"></div>
<div class="pswp__item"></div>
</div>
<!-- Default (PhotoSwipeUI_Default) interface on top of sliding area. Can be changed. -->
<div class="pswp__ui pswp__ui--hidden">
<div class="pswp__top-bar">
<!-- Controls are self-explanatory. Order can be changed. -->
<div class="pswp__counter"></div>
<button class="pswp__button pswp__button--close" title="Close (Esc)"></button>
<button class="pswp__button pswp__button--share" title="Share"></button>
<button class="pswp__button pswp__button--fs" title="Toggle fullscreen"></button>
<button class="pswp__button pswp__button--zoom" title="Zoom in/out"></button>
<!-- Preloader demo http://codepen.io/dimsemenov/pen/yyBWoR -->
<!-- element will get class pswp__preloader--active when preloader is running -->
<div class="pswp__preloader">
<div class="pswp__preloader__icn">
<div class="pswp__preloader__cut">
<div class="pswp__preloader__donut"></div>
</div>
</div>
</div>
</div>
<div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap">
<div class="pswp__share-tooltip"></div>
</div>
<button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)">
</button>
<button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)">
</button>
<div class="pswp__caption">
<div class="pswp__caption__center"></div>
</div>
</div>
</div>
</div>
2020-07-17 11:27:08 +08:00
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="//www.googletagmanager.com/gtag/js?id=UA-157733505-1"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {
dataLayer.push(arguments);
}
gtag('js', new Date());
2020-02-21 16:28:53 +08:00
2020-07-17 11:27:08 +08:00
gtag('config', 'UA-157733505-1');
</script>
2020-02-21 16:28:53 +08:00
<script>
2020-07-17 11:27:08 +08:00
function initialTyped() {
var typedTextEl = $('.typed-text');
if (typedTextEl && typedTextEl.length > 0) {
var typed = new Typed('.typed-text', {
strings: ['凡事都要留几分', '颜值是第一生产力'],
typeSpeed: 90,
loop: true,
loopCount: Infinity,
backSpeed: 20,
});
2020-02-21 16:28:53 +08:00
}
2020-07-17 11:27:08 +08:00
}
2020-02-21 16:28:53 +08:00
2020-07-17 11:27:08 +08:00
if ($('.article-header') && $('.article-header').length) {
$(document).ready(function () {
initialTyped();
});
}
2020-02-21 16:28:53 +08:00
</script>
2021-03-18 13:07:04 +08:00
<!-- 例:百度统计 --> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?your_code"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
2021-01-22 17:50:40 +08:00
2020-02-21 16:28:53 +08:00
</html>