🚙

💨 💨 💨

×

  • Categories

  • Archives

  • Tags

  • About

白话TCP快速重传

Posted on 09-23-2017 | In NP

快速重传算法概绍

在收到一个失序的报文段时, TCP立即需要产生一个ACK(一个重复的ACK)。这个重复的ACK不应该被迟延。该重复的ACK的曰的在于让对方知道收到一个失序的报文段,并告诉对方自己希望收到的序号。

由于我们不知道一个重复的ACK足由一个丢失的报文段引起的,还是由于仅仅出现了几个报文段的重新排序,因此我们等待少量重复的ACK到来。假如这只是一些报文段的重新排序,则在重新排序的报文段被处理并产生一个新的ACK之前,只可能产生1~2个重复的ACK。
如果一连串收到3个或3个以上的重复ACK,就非常可能足一个报文段丢失了。于足我们就重传丢失的数据报文段,而无需等待超时定时器溢出。这就是快速重传算法。接下来执行的不是慢启动算法而是拥塞避免算法。这就是快速恢复算法。

在这种情况下没有执行慢启动的原因是由于收到重复的ACK不仅仅告诉我们一个分组丢失了。由于接收方只有在收到另一个报文段耐才会产生重复的ACK,而该报文段已经离开了网络并进入了接收方的缓存。
也就是说,在收发两端之问仍然有流动的数据,而我们不想执行慢启动来突然减少数据流。

. . .

基于hexo的next个性化配置小技巧

Posted on 09-21-2017 | In Misc

原文出处


1. 在右上角或者左上角实现fork me on github

实现效果图

具体实现方法

点击这里挑选自己喜欢的样式,并复制代码。 例如,我是复制如下代码:

然后粘贴刚才复制的代码到themes/next/layout/_layout.swig文件中(放在<div class="headband"></div>的下面),并把href改为你的github地址


2.添加RSS

实现效果图

具体实现方法

切换到你的blog(我是取名blog,具体的看你们的取名是什么)的路径,例如我是在/Users/chenzekun/Code/Hexo/blog这个路径上,也就是在你的根目录下

然后安装 Hexo 插件:(这个插件会放在node_modules这个文件夹里)

1
$ npm install −−save hexo-generator-feed

接下来打开画红线的文件,如下图:

在里面的末尾添加:(请注意在冒号后面要加一个空格,不然会发生错误!)

1
2
3
# Extensions
## Plugins: http://hexo.io/plugins/
plugins: hexo-generate-feed

然后打开next主题文件夹里面的_config.yml,在里面配置为如下样子:(就是在rss:的后面加上/atom.xml,注意在冒号后面要加一个空格)

1
2
3
4
# Set rss to false to disable feed link.
# Leave rss as empty to use site‘s feed link.
# Set rss to specific value if you have burned your feed already.
rss: /atom.xml

配置完之后运行:

1
$ hexo g

重新生成一次,你会在./public 文件夹中看到 atom.xml 文件。然后启动服务器查看是否有效,之后再部署到 Github 中。


3. 添加动态背景

实现效果图

具体实现方法

这个我之前有一篇文章有讲过了,详情点击我的博客


4. 实现点击出现桃心效果

实现效果图

具体实现方法

在网址输入如下

1
http://7u2ss1.com1.z0.glb.clouddn.com/love.js

然后将里面的代码copy一下,新建love.js文件并且将代码复制进去,然后保存。将love.js文件放到路径/themes/next/source/js/src里面,然后打开\themes\next\layout_layout.swig文件,在末尾(在前面引用会出现找不到的bug)添加以下代码:

1
2
<!– 页面点击小红心 –>
<script type=“text/javascript” src=“/js/src/love.js”></script>

5. 修改文章内链接文本样式

实现效果图

具体实现方法

修改文件 themes\next\source\css_common\components\post\post.styl,在末尾添加如下css样式,:

1
2
3
4
5
6
7
8
9
10
11
// 文章内链接文本样式
.post-body p a{
color: #0593d3;
border-bottom: none;
border-bottom: 1px solid #0593d3;
&:hover {
color: #fc6423;
border-bottom: none;
border-bottom: 1px solid #fc6423;
}
}

其中选择.post-body 是为了不影响标题,选择 p 是为了不影响首页“阅读全文”的显示样式,颜色可以自己定义。


6. 修改文章底部的那个带#号的标签

实现效果图

具体实现方法

修改模板/themes/next/layout/_macro/post.swig,搜索 rel="tag">#,将 # 换成<i class="fa fa-tag"></i>


7. 在每篇文章末尾统一添加“本文结束”标记

实现效果图

具体实现方法

在路径 \themes\next\layout_macro 中新建 passage-end-tag.swig 文件,并添加以下内容:

1
2
3
4
5
<div>
{% if not is_index %}
<div style=“text-align:center;color: #ccc;font-size:14px;”>————-本文结束<i class=“fa fa-paw”></i>感谢您的阅读————-</div>
{% endif %}
</div>

接着打开\themes\next\layout_macro\post.swig文件,在post-body 之后, post-footer 之前添加如下画红色部分代码(post-footer之前两个DIV):

代码如下:

1
2
3
4
5
<div>
{% if not is_index %}
{% include ‘passage-end-tag.swig’ %}
{% endif %}
</div>

然后打开主题配置文件(_config.yml),在末尾添加:

1
2
3
# 文章末尾添加“本文结束”标记
passage_end_tag:
enabled: true

完成以上设置之后,在每篇文章之后都会添加如上效果图的样子。


8. 修改作者头像并旋转

实现效果图

具体实现方法

打开\themes\next\source\css_common\components\sidebar\sidebar-author.styl,在里面添加如下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
.site-author-image {
display: block;
margin: 0 auto;
padding: $site-author-image-padding;
max-width: $site-author-image-width;
height: $site-author-image-height;
border: $site-author-image-border-width solid $site-author-image-border-color;
/ 头像圆形 /
border-radius: 80px;
-webkit-border-radius: 80px;
-moz-border-radius: 80px;
box-shadow: inset 0 -1px 0 #333sf;
/ 设置循环动画 [animation: (play)动画名称 (2s)动画播放时长单位秒或微秒 (ase-out)动画播放的速度曲线为以低速结束
(1s)等待1秒然后开始动画 (1)动画播放次数(infinite为循环播放) ]/
/ 鼠标经过头像旋转360度 /
-webkit-transition: -webkit-transform 1.0s ease-out;
-moz-transition: -moz-transform 1.0s ease-out;
transition: transform 1.0s ease-out;
}
img:hover {
/ 鼠标经过停止头像旋转
-webkit-animation-play-state:paused;
animation-play-state:paused;/
/ 鼠标经过头像旋转360度 /
-webkit-transform: rotateZ(360deg);
-moz-transform: rotateZ(360deg);
transform: rotateZ(360deg);
}
/ Z 轴旋转动画 /
@-webkit-keyframes play {
0% {
-webkit-transform: rotateZ(0deg);
}
100% {
-webkit-transform: rotateZ(-360deg);
}
}
@-moz-keyframes play {
0% {
-moz-transform: rotateZ(0deg);
}
100% {
-moz-transform: rotateZ(-360deg);
}
}
@keyframes play {
0% {
transform: rotateZ(0deg);
}
100% {
transform: rotateZ(-360deg);
}
}

9. 博文压缩

在站点的根目录下执行以下命令:

1
2
$ npm install gulp -g
$ npm install gulp-minify-css gulp-uglify gulp-htmlmin gulp-htmlclean gulp −−save

在如下图所示,新建 gulpfile.js ,并填入以下内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
var gulp = require(‘gulp’);
var minifycss = require(‘gulp-minify-css’);
var uglify = require(‘gulp-uglify’);
var htmlmin = require(‘gulp-htmlmin’);
var htmlclean = require(‘gulp-htmlclean’);
// 压缩 public 目录 css
gulp.task(‘minify-css’, function() {
return gulp.src(‘./public//*.css’)
.pipe(minifycss())
.pipe(gulp.dest(‘./public’));
});
// 压缩 public 目录 html
gulp.task(‘minify-html’, function() {
return gulp.src(‘./public//.html’)
.pipe(htmlclean())
.pipe(htmlmin({
removeComments: true,
minifyJS: true,
minifyCSS: true,
minifyURLs: true,
}))
.pipe(gulp.dest(‘./public’))
});
// 压缩 public/js 目录 js
gulp.task(‘minify-js’, function() {
return gulp.src(‘./public/**/.js’)
.pipe(uglify())
.pipe(gulp.dest(‘./public’));
});
// 执行 gulp 命令时执行的任务
gulp.task(‘default’, [
‘minify-html’,‘minify-css’,‘minify-js’
]);

生成博文是执行 hexo g && gulp 就会根据 gulpfile.js 中的配置,对 public 目录中的静态资源文件进行压缩。


10. 修改代码块自定义样式

实现效果图

具体实现方法

打开\themes\next\source\css_custom\custom.styl,向里面加入:(颜色可以自己定义)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// Custom styles.
code {
color: #ff7600;
background: #fbf7f8;
margin: 2px;
}
// 大代码块的自定义样式
.highlight, pre {
margin: 5px 0;
padding: 5px;
border-radius: 3px;
}
.highlight, code, pre {
border: 1px solid #d6d6d6;
}

11. 侧边栏社交小图标设置

实现效果图

具体实现方法

打开主题配置文件(_config.yml),搜索social_icons:,在图标库找自己喜欢的小图标,并将名字复制在如下位置,保存即可


12. 主页文章添加阴影效果

实现效果图

具体实现方法

打开\themes\next\source\css_custom\custom.styl,向里面加入:

1
2
3
4
5
6
7
8
// 主页文章添加阴影效果
.post {
margin-top: 60px;
margin-bottom: 60px;
padding: 25px;
-webkit-box-shadow: 0 0 5px rgba(202, 203, 203, .5);
-moz-box-shadow: 0 0 5px rgba(202, 203, 204, .5);
}

13. 在网站底部加上访问量

实现效果图

具体实现方法
打开\themes\next\layout_partials\footer.swig文件,在copyright前加上画红线这句话:

代码如下:

1
<script async src=“https://dn-lbstatics.qbox.me/busuanzi/2.3/busuanzi.pure.mini.js“></script>

然后再合适的位置添加显示统计的代码,如图:

代码如下:

1
2
3
4
5
<div class=“powered-by”>
<i class=“fa fa-user-md”></i><span id=“busuanzi_container_site_uv”>
本站访客数:<span id=“busuanzi_value_site_uv”></span>
</span>
</div>

在这里有两中不同计算方式的统计代码:

  1. pv的方式,单个用户连续点击n篇文章,记录n次访问量
1
2
3
<span id=“busuanzi_container_site_pv”>
本站总访问量<span id=“busuanzi_value_site_pv”></span>次
</span>
  1. uv的方式,单个用户连续点击n篇文章,只记录1次访客数
1
2
3
<span id=“busuanzi_container_site_uv”>
本站总访问量<span id=“busuanzi_value_site_uv”></span>次
</span>

添加之后再执行hexo d -g,然后再刷新页面就能看到效果


14. 添加热度

实现效果图

具体实现方法

next主题集成leanCloud,打开/themes/next/layout/_macro/post.swig,在画红线的区域添加℃:

然后打开,/themes/next/languages/zh-Hans.yml,将画红框的改为热度就可以了


15. 网站底部字数统计

实现效果图

具体方法实现
切换到根目录下,然后运行如下代码

1
$ npm install hexo-wordcount −−save

然后在/themes/next/layout/_partials/footer.swig文件尾部加上:

1
2
3
4
<div class=“theme-info”>
<div class=“powered-by”></div>
<span class=“post-count”>博客全站共{{ totalcount(site) }}字</span>
</div>

16. 添加 README.md 文件

每个项目下一般都有一个 README.md 文件,但是使用 hexo 部署到仓库后,项目下是没有 README.md 文件的。

在 Hexo 目录下的 source 根目录下添加一个 README.md 文件,修改站点配置文件 _config.yml,将 skip_render 参数的值设置为

1
skip_render: README.md

保存退出即可。再次使用 hexo d 命令部署博客的时候就不会在渲染 README.md 这个文件了。


17. 设置网站的图标Favicon

实现效果图

具体方法实现

在EasyIcon中找一张(3232)的ico图标,或者去别的网站下载或者制作,并将图标名称改为favicon.ico,然后把图标放在/themes/next/source/images里,并且修改主题配置文件:

1
2
# Put your favicon.ico into hexo-site/source/ directory.
favicon: /favicon.ico

18. 实现统计功能

实现效果图

具体实现方法

在根目录下安装 hexo-wordcount,运行:

1
$ npm install hexo-wordcount −−save

然后在主题的配置文件中,配置如下:

1
2
3
4
5
6
# Post wordcount display settings
# Dependencies: https://github.com/willin/hexo-wordcount
post_wordcount:
item_text: true
wordcount: true
min2read: true

19. 添加顶部加载条

实现效果图

具体实现方法

打开/themes/next/layout/_partials/head.swig文件,添加红框上的代码

代码如下:

1
2
<script src=“//cdn.bootcss.com/pace/1.0.2/pace.min.js”></script>
<link href=“//cdn.bootcss.com/pace/1.0.2/themes/pink/pace-theme-flash.css” rel=“stylesheet”>

但是,默认的是粉色的,要改变颜色可以在/themes/next/layout/_partials/head.swig文件中添加如下代码(接在刚才link的后面)

1
2
3
4
5
6
7
8
9
10
11
12
13
<style>
.pace .pace-progress {
background: #1E92FB; /进度条颜色/
height: 3px;
}
.pace .pace-progress-inner {
box-shadow: 0 0 10px #1E92FB, 0 0 5px #1E92FB; /阴影颜色/
}
.pace .pace-activity {
border-top-color: #1E92FB; /上边框颜色/
border-left-color: #1E92FB; /左边框颜色/
}
</style>

目前,博主的增加顶部加载条的pull request 已被Merge😀===>详情
现在升级最新版的next主题,升级后只需修改主题配置文件(_config.yml)将pace: false改为pace: true就行了,你还可以换不同样式的加载条,如下图:


20. 在文章底部增加版权信息

实现效果图

在目录 next/layout/_macro/下添加 my-copyright.swig:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
{% if page.copyright %}
<div class=“my_post_copyright”>
<script src=“//cdn.bootcss.com/clipboard.js/1.5.10/clipboard.min.js”></script>
<!– JS库 sweetalert 可修改路径 –>
<script type=“text/javascript” src=“http://jslibs.wuxubj.cn/sweetalert_mini/jquery-1.7.1.min.js“></script>
<script src=“http://jslibs.wuxubj.cn/sweetalert_mini/sweetalert.min.js“></script>
<link rel=“stylesheet” type=“text/css” href=“http://jslibs.wuxubj.cn/sweetalert_mini/sweetalert.mini.css“>
<p><span>本文标题:</span><a href=“{{ url_for(page.path) }}“>{{ page.title }}</a></p>
<p><span>文章作者:</span><a href=“/“ title=“访问 {{ theme.author }} 的个人博客”>{{ theme.author }}</a></p>
<p><span>发布时间:</span>{{ page.date.format(“YYYY年MM月DD日 - HH:MM”) }}</p>
<p><span>最后更新:</span>{{ page.updated.format(“YYYY年MM月DD日 - HH:MM”) }}</p>
<p><span>原始链接:</span><a href=“{{ url_for(page.path) }}“ title=“{{ page.title }}“>{{ page.permalink }}</a>
<span class=“copy-path” title=“点击复制文章链接”><i class=“fa fa-clipboard” data-clipboard-text=“{{ page.permalink }}“ aria-label=“复制成功!”></i></span>
</p>
<p><span>许可协议:</span><i class=“fa fa-creative-commons”></i> <a rel=“license” href=“https://creativecommons.org/licenses/by-nc-nd/4.0/“ target=“_blank” title=“Attribution-NonCommercial-NoDerivatives 4.0 International (CC BY-NC-ND 4.0)”>署名-非商业性使用-禁止演绎 4.0 国际</a> 转载请保留原文链接及作者。</p>
</div>
<script>
var clipboard = new Clipboard(‘.fa-clipboard’);
clipboard.on(‘success’, $(function(){
$(“.fa-clipboard”).click(function(){
swal({
title: “”,
text: ‘复制成功’,
html: false,
timer: 500,
showConfirmButton: false
});
});
}));
</script>
{% endif %}

在目录next/source/css/_common/components/post/下添加my-post-copyright.styl:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
.my_post_copyright {
width: 85%;
max-width: 45em;
margin: 2.8em auto 0;
padding: 0.5em 1.0em;
border: 1px solid #d3d3d3;
font-size: 0.93rem;
line-height: 1.6em;
word-break: break-all;
background: rgba(255,255,255,0.4);
}
.my_post_copyright p{margin:0;}
.my_post_copyright span {
display: inline-block;
width: 5.2em;
color: #b5b5b5;
font-weight: bold;
}
.my_post_copyright .raw {
margin-left: 1em;
width: 5em;
}
.my_post_copyright a {
color: #808080;
border-bottom:0;
}
.my_post_copyright a:hover {
color: #a3d2a3;
text-decoration: underline;
}
.my_post_copyright:hover .fa-clipboard {
color: #000;
}
.my_post_copyright .post-url:hover {
font-weight: normal;
}
.my_post_copyright .copy-path {
margin-left: 1em;
width: 1em;
+mobile(){display:none;}
}
.my_post_copyright .copy-path:hover {
color: #808080;
cursor: pointer;
}

修改next/layout/_macro/post.swig,在代码

1
2
3
4
5
<div>
{% if not is_index %}
{% include ‘wechat-subscriber.swig’ %}
{% endif %}
</div>

之前添加增加如下代码:

1
2
3
4
5
<div>
{% if not is_index %}
{% include ‘my-copyright.swig’ %}
{% endif %}
</div>

如下:

修改next/source/css/_common/components/post/post.styl文件,在最后一行增加代码:

1
@import “my-post-copyright”

保存重新生成即可。
如果要在该博文下面增加版权信息的显示,需要在 Markdown 中增加copyright: true的设置,类似:

小技巧:如果你觉得每次都要输入copyright: true很麻烦的话,那么在/scaffolds/post.md文件中添加:

这样每次hexo new "你的内容"之后,生成的md文件会自动把copyright:加到里面去
(注意:如果解析出来之后,你的原始链接有问题:如:http://yoursite.com/前端小项目:使用canvas绘画哆啦A梦.html,那么在根目录下_config.yml中写成类似这样:)
就行了。


21. 添加网易云跟帖(跟帖关闭,已失效,改为来必力)

实现效果图

具体方法实现
有两种实现方法:
①更新next主题,因为最新版本的主题已经支持这种评论。直接在主题配置文件_config.yml 文件中添加如下配置:

1
gentie_productKey: #your-gentie-product-key

②如果你不想更新的话,那么按下面步骤进行:
首先,还是在主题配置文件_config.yml 文件中添加如下配置:

1
gentie_productKey: #your-gentie-product-key

你的productKey就是下面画红线部分

然后在在layout/_scripts/third-party/comments/ 目录中添加 gentie.swig,文件内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
{% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname and not theme.disqus_shortname and not theme.hypercomments_id %}
{% if theme.gentie_productKey %}
{% set gentie_productKey = theme.gentie_productKey %}
<script>
var cloudTieConfig = {
url: document.location.href,
sourceId: “”,
productKey: “{{gentie_productKey}}“,
target: “cloud-tie-wrapper”
};
</script>
<script src=“https://img1.ws.126.net/f2e/tie/yun/sdk/loader.js“></script>
{% endif %}
{% endif %}

然后在layout/_scripts/third-party/comments.swig文件中追加:

1
{% include ‘./comments/gentie.swig’ %}

最后,在 layout/_partials/comments.swig 文件中条件最后追加网易云跟帖插件引用的判断逻辑:

1
2
3
{% elseif theme.gentie_productKey %}
<div id=“cloud-tie-wrapper” class=“cloud-tie-wrapper”>
</div>

具体位置如下:

可能你hexo s时可能看不到,直接hexo d就可以看到了


近日,我朋友发来消息,说网易云跟帖要关了,我网上查了一下,果然如此

😭都是泪,上次用了多说,结果多说关了,接着是网易云跟帖😷,这次直接用国外的来必力,应该不会这么容易关吧😏

方法其实还是跟上面差不多的

首先在 _config.yml 文件中添加如下配置:(注意!如果主题是最新版的,直接写你的liver_uid就行了)

1
2
3
# Support for LiveRe comments system.
# You can get your uid from https://livere.com/insight/myCode (General web site)
livere_uid: your uid

其中,livere_uid就是画红线的部分

然后在 layout/_scripts/third-party/comments/ 目录中添加 livere.swig,文件内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
{% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname and not theme.disqus_shortname and not theme.hypercomments_id and not theme.gentie_productKey %}
{% if theme.livere_uid %}
<script type=“text/javascript”>
(function(d, s) {
var j, e = d.getElementsByTagName(s)[0];
if (typeof LivereTower === ‘function’) { return; }
j = d.createElement(s);
j.src = ‘https://cdn-city.livere.com/js/embed.dist.js‘;
j.async = true;
e.parentNode.insertBefore(j, e);
})(document, ‘script’);
</script>
{% endif %}
{% endif %}

然后在 layout/_scripts/third-party/comments.swig文件中追加:

1
{% include ‘./comments/livere.swig’ %}

最后,在 layout/_partials/comments.swig 文件中条件最后追加 LiveRe 插件是否引用的判断逻辑:

1
2
3
{% elseif theme.livere_uid %}
<div id=“lv-container” data-id=“city” data-uid=“{{ theme.livere_uid }}“></div>
{% endif %}

完


22. 隐藏网页底部powered By Hexo / 强力驱动

打开themes/next/layout/_partials/footer.swig,使用””隐藏之间的代码即可,或者直接删除。位置如图:


23. 修改网页底部的桃心

还是打开themes/next/layout/_partials/footer.swig,找到:
,然后还是在图标库中找到你自己喜欢的图标,然后修改画红线的部分就可以了。


24. 文章加密访问

实现效果图

具体实现方法

打开themes->next->layout->_partials->head.swig文件,在以下位置插入这样一段代码:

代码如下:

1
2
3
4
5
6
7
8
9
10
<script>
(function(){
if(‘{{ page.password }}’){
if (prompt(‘请输入文章密码’) !== ‘{{ page.password }}’){
alert(‘密码错误!’);
history.back();
}
}
})();
</script>

然后在文章上写成类似这样:


25. 添加jiathis分享

在主题配置文件中,jiathis为true,就行了,如下图

默认是这样子的:

如果你想自定义话,打开themes/next/layout/_partials/share/jiathis.swig修改画红线部分就可以了


26. 博文置顶

修改 hero-generator-index 插件,把文件:node_modules/hexo-generator-index/lib/generator.js 内的代码替换为:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
‘use strict’;
var pagination = require(‘hexo-pagination’);
module.exports = function(locals){
var config = this.config;
var posts = locals.posts;
posts.data = posts.data.sort(function(a, b) {
if(a.top && b.top) { // 两篇文章top都有定义
if(a.top == b.top) return b.date - a.date; // 若top值一样则按照文章日期降序排
else return b.top - a.top; // 否则按照top值降序排
}
else if(a.top && !b.top) { // 以下是只有一篇文章top有定义,那么将有top的排在前面(这里用异或操作居然不行233)
return -1;
}
else if(!a.top && b.top) {
return 1;
}
else return b.date - a.date; // 都没定义按照文章日期降序排
});
var paginationDir = config.pagination_dir || ‘page’;
return pagination(‘’, posts, {
perPage: config.index_generator.per_page,
layout: [‘index’, ‘archive’],
format: paginationDir + ‘/%d/‘,
data: {
__index: true
}
});
};

在文章中添加 top 值,数值越大文章越靠前,如

1
2
3
4
5
6
7
8
—
title: 解决Charles乱码问题
date: 2017-05-22 22:45:48
tags: 技巧
categories: 技巧
copyright: true
top: 100
—

27. 修改字体大小

打开\themes\next\source\css\ _variables\base.styl文件,将$font-size-base改成16px,如下所示:

1
$font-size-base =16px

28. 修改打赏字体不闪动

修改文件next/source/css/_common/components/post/post-reward.styl,然后注释其中的函数wechat:hover和alipay:hover,如下:

1
2
3
4
5
6
7
8
9
10
11
12
/ 注释文字闪动函数
#wechat:hover p{
animation: roll 0.1s infinite linear;
-webkit-animation: roll 0.1s infinite linear;
-moz-animation: roll 0.1s infinite linear;
}
#alipay:hover p{
animation: roll 0.1s infinite linear;
-webkit-animation: roll 0.1s infinite linear;
-moz-animation: roll 0.1s infinite linear;
}
/

29. 侧边栏推荐阅读

今天有位网友问推荐阅读是怎么弄,其实挺简单的,打开主题配置文件修改成这样就行了(links里面写你想要的链接):

1
2
3
4
5
6
7
8
9
10
11
# Blogrolls
links_title: 推荐阅读
#links_layout: block
links_layout: inline
links:
优设: http://www.uisdc.com/
张鑫旭: http://www.zhangxinxu.com/
Web前端导航: http://www.alloyteam.com/nav/
前端书籍资料: http://www.36zhen.com/t?id=3448
百度前端技术学院: http://ife.baidu.com/
google前端开发基础: http://wf.uisdc.com/cn/

30. 自定义鼠标样式

打开themes/next/source/css/_custom/custom.styl,在里面写下如下代码

1
2
3
4
5
6
7
// 鼠标样式
{
cursor: url(“http://om8u46rmb.bkt.clouddn.com/sword2.ico“),auto!important
}
:active {
cursor: url(“http://om8u46rmb.bkt.clouddn.com/sword1.ico“),auto!important
}

其中 url 里面必须是 ico 图片,ico 图片可以上传到网上(我是使用七牛云图床),然后获取外链,复制到 url 里就行了


31.为博客加上萌萌的宠物

实现效果图

具体实现方法
在终端切换到你的博客的路径里,然后输入如下代码:

1
npm install --save hexo-helper-live2d

然后打开Hexo/blog/themes/next/layout
的_layout.swig,将下面代码放到</body>之前:

1
{{ live2d() }}

然后在在 hexo 的 _config.yml中添加参数:

1
2
3
live2d:
model: wanko
bottom: -30

然后hexo clean ,hexo g ,hexo d 就可以看到了。

下面是一些model,可以换不同的宠物

  • model 模型名称 默认值: z16
    • Gantzert_Felixander
    • Epsilon2.1
    • haru
    • miku
    • ni-j
    • nico
    • nito
    • nipsilon
    • nietzsche
    • shizuku
    • tsumiki
    • wanko
    • z16
    • hibiki
    • koharu
    • haruto
    • Unitychan
    • tororo
    • hijiki
  • width 宽度 默认值: 150
  • height 高度 默认值: 300
  • className <canvas>元素的类名 默认值: live2d
  • id <canvas> 元素的id 默认值: live2dcanvas
  • bottom <canvas> 元素的底部偏移 默认值: -20 如果嫌模型位置不正确 可以调整这个参数

用这个有缺点,如果是在手机上看的话,感觉不是很好,宠物一直挡着文字😂😂,还有就是加载有点慢

注意!如果你在 hexo d 的时候出现我下面这个问题

你可以这样,首先删除hexo 下面的.deploy_git文件夹,然后运行

1
git config –global core.autocrlf false

重新 hexo clean,hexo g,hexo d就行了


致谢

感谢大神们的文章,真的学到了许多,有些忘了记录下来,在这里由衷的感谢。虽然比较折腾,但是确实满满的成就感,Road endless its long and far, I will seek up and down!

欢迎访问我的博客


参考的文章:

  1. http://blog.csdn.net/MasterAnt_D/article/details/56839222
  2. http://zidingyi4qh.com/2017/04/27/NexT%E5%BA%95%E9%83%A8logo%E6%B7%BB%E5%8A%A0%E8%AE%BF%E9%97%AE%E9%87%8F/
  3. https://fuyis.me/2017/01/25/Hexo-theme-next-and-optimized-configuration/
  4. http://www.vitah.net/posts/20f300cc/
  5. http://thief.one/2017/03/03/Hexo%E6%90%AD%E5%BB%BA%E5%8D%9A%E5%AE%A2%E6%95%99%E7%A8%8B/

kbe服务端笔记(二)

Posted on 07-29-2017 | In Misc

FixedMessages:

FixedMessages存储所有固定消息(有显示制定id的消息,当然,这并不表示非固定消息就没有id,也是有的,只是不是显示制定的)。
它的构造地方如下(lib/network/message_handler.cpp):

MessageHandlers::MessageHandlers():
msgHandlers_(),
msgID_(1),
exposedMessages_()
{
g_fm = Network::FixedMessages::getSingletonPtr();
if(g_fm == NULL)
g_fm = newNetwork::FixedMessages;

Network::FixedMessages::getSingleton().loadConfig("server/messages_fixed.xml");
messageHandlers().push_back(this);
}

意即MessageHandlers构造的时候,如果它还没构造,那就构造。
它的初始化(配置)是由loadConfig接口来完成的,代码见上。

. . .

重读UNP(UNIX网络编程)13章到31章笔记整理(结合TLPI和APUE两书的笔记整理)(二)

Posted on 07-29-2017 | In NP

16章

  • 16.3节 : 非阻塞connect
    • 有三个用途:
      • 我们想在connect的时候处理其他事情
      • 可以同时建立多个连接
      • 可以通过select设置一个更短一点的超时时间
    • 实现步骤:
      a. 用fcntl把套接字设置为非阻塞
      b. 处理客户端和服务器都在同一主机上的情况
      c. 使用select设置超时,并处理超时情况
      d. 处理当连接建立的时候,描述符变为可写;以及当连接建立遇到错误的时候, 描述符变为可写并可读的情况

. . .

重读UNP(UNIX网络编程)13章到31章笔记整理(结合TLPI和APUE两书的笔记整理)(一)

Posted on 07-28-2017 | In NP

因为UNP第三部分(第三版13-31章)的内容结合APUE(UNIX环境高级编程)和TLPI(The Linux Programming Interface)来看才能比较清晰,所以笔记整理会穿插很多这两本书的内容

引申知识,作业控制以及相关命令

daemon_command

. . .

crontab笔记整理

Posted on 07-09-2017 | In Linux

crontab命令被用来提交和管理用户的需要周期性执行的任务,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。

  • -e:编辑该用户的计时器设置;
  • -l:列出该用户的计时器设置;
  • -r:删除该用户的计时器设置;
  • -u<用户名称>:指定要设定计时器的用户名称

. . .

重读UNIX网络编程第三章到第十一章笔记整理(二)

Posted on 07-03-2017 | In NP

第七章

  • 7.5节 : 通用套接字选项, 常用的有

    • SO_KEEPALIVE
    • SO_REVBUF
    • SO_SNDBUF
    • SO_REUSEADDR
  • 7.9节 : tcp套接字选项, 常用的有

    • TCP_NODELAY
    • TCP_MAXSEG
  • 7.11节 :fcntl函数,常用的用法是使用F_SETFL命令设置O_NOBLOCK文件状态标志, 我们可以把一个套接字设置为非阻塞型。

. . .

重读UNIX网络编程第三章到第十一章笔记整理(一)

Posted on 07-02-2017 | In NP

因为第二章之后基本都是纯Socket API的内容, 第三章到第十一章的笔记整理合并到一起。

第三章

  • 3.4 :字节排序函数,涉及到大小端,处理网络字节序和主机字节序的转换

    如何判别是大端(Big-Endian)还是小端(Little-Endian):

    union TestBigOrLittle
    {
    short var_short;
    char array_char[2];
    };

    int main()
    {
    TestBigOrLittle unTestUnion;
    unTestUnion.var_short = 0x1234;
    if (sizeof(short) == 2)
    {

    if (unTestUnion.array_char[0] == 0x12)
    printf("BigEndian\n");
    else if(unTestUnion.array_char[0] == 0x34)
    printf("LittleEndian\n");
    else
    printf("unkonw endian\n");
    }
    else
    {
    printf("sizeof(short) : %d \n", sizeof(short));
    }
    return 0;
    }

    网际协议使用大端字节序来传送这些多字节整数, 也就是说网络字节序就是大端字节序.

    由图中我们可以知道, htons和ntohs是用于端口的字节序转换的, 而htonl和ntohl是用于32位IP地址的, 下图就是一个例子:

  • 3.6 : 地址转换函数,它们在ASCII字符串(这是人们偏爱使用的格式)与网络字节序的二进制值(这是存放在套接字地址结构中的值)之间转换网际地址

第四章基本TCP套接字编程

  • 这里写图片描述

  • listen函数

    int listen(int sockfd, int backlog);

    当来自客户的SYN到达时,TCP在未完成连接队列中创建个新项,然后响应以三路握手
    的第—个分节服务器的SYN响应,其中捎带对客户SYN的ACK(2.6节)。这一项.直保留在
    未完成连接队列中,直到三路握手的第二个分节(客户对服务器SYN的ACK)到达或者该项超
    时为止。(源白Berkeley的实现为这些末完成连接的项设置的超时值为75s。)如果3路握手正常
    完成,该项就从未完成连接队列移到已完成连接队列的队尾。当进程调用accept时(该函数在
    下一节讲解),己完成连接队列巾的队头项将返回给给进程,或者如果该队列为空,那么进程将被
    投入睡眠,直到TCP在该队列中放入一项才唤醒它。

  • 4.6节: accept函数
    accept函数用于从已完成连接队列对头返回下一个已完成连接
    int accept(int sockfd, struct sockaddr *cliaddr, socklent_t *addrlen);

  • 4.7节: fork函数
    fork函数的内存语义:

    1. 共享代码段, 子指向父 : 父子进程共享同一代码段, 子进程的页表项指向父进程相同的物理内存页(即数据段/堆段/栈段的各页)
    2. 写时复制(copy-on-write) : 内核会捕获所有父进程或子进程针对这些页面(即数据段/堆段/栈段的各页)的修改企图, 并为将要修改的页面创建拷贝, 将新的页面拷贝分配给遭内核捕获的进程, 从此父/子进程可以分别修改各自的页拷贝, 不再相互影响.
  • 4.9节:
    close函数, 涉及到描述符引用计数,所以多进程并发服务器才可以共享已连接套接字,因为父进程调用close函数知识把该套接字标记成已关闭并导致该套接字描述符减1。只要引用计数的值仍大于0,就不会引发tcp的四分组连接终止序列

第五章

  • 5.9节:
    处理SIGCHLD信号, 涉及到僵死进程(子进程终止时给父进程发送了一个SIGCHLD信号,若父进程未加处理,则子进程进入僵死状态),所以要建立该信号处理函数,并在函数中调用waitpid来处理
  • 5.10节 :
    使用wait或者waitpid来处理已终止的子进程,通常是使用waitpid并指定WNOHANG选项,来告知waitpid在有尚未终止的子进程在运行时不要阻塞。

. . .

1…8910111213141516171819202122232425262728…36
Mike

Mike

🚙 🚗 💨 💨 If you want to create a blog like this, just follow my open-source project, "hexo-theme-neo", click the GitHub button below and check it out ^_^ . It is recommended to use Chrome, Safari, or Edge to read this blog since this blog was developed on Edge (Chromium kernel version) and tested on Safari.

11 categories
287 posts
110 tags
about
GitHub Spotify
© 2013 - 2025 Mike