2017年8月

常用于表格表头,页面导航,选项卡等。
比如 这个 bar 在中间,但滚动向上,这个bar触到顶部时,则自动fixed。
当向下滚动,bar则自动融回原位置。

{position:-webkit-sticky;position:-moz-sticky;position:-ms-sticky;position:sticky;top:0;left:0;z-index:9980}

最近也在琢磨这个效果,js写得实在痛苦,就上网找找demo,在手机网易上看到了。

s1.jpg
s2.jpg

说明
在一些很长的表格中,常常会使用表头悬浮的设计以方便阅读,即在表格离开窗口之前,表头会一直 fixed 悬浮在表格的最顶上。还有许多诸如评论框等元素,也采用了这种被称为 Sticky Pin 或者 粘性元素 的设计。

这种效果一直以来需要通过 JavaScript 实现。不过就在去年,这项结合了 Relative (在屏幕中时) 和 Fixed (移出屏幕时) 的样式效果被提案添加到了 CSS3 中。下面是一个示例:

.sticky {  
    position: -webkit-sticky;  
    position: -moz-sticky;  
    position: -ms-sticky;  
    position: sticky;  
    top: 15px; // 使用和 Fixed 同样的方式设定位置  
} 

因为这个样式尚未进入标准,还必须使用私有前缀。

常用于表格表头,页面导航,选项卡等。
比如 这个 bar 在中间,但滚动向上,这个bar触到顶部时,则自动fix。
当向下滚动,bar则自动融回原位置。

{position:-webkit-sticky;position:-moz-sticky;position:-ms-sticky;position:sticky;top:0;left:0;z-index:9980}

说明
在一些很长的表格中,常常会使用表头悬浮的设计以方便阅读,即在表格离开窗口之前,表头会一直 fixed 悬浮在表格的最顶上。还有许多诸如评论框等元素,也采用了这种被称为 Sticky Pin 或者 粘性元素 的设计。

这种效果一直以来需要通过 JavaScript 实现。不过就在去年,这项结合了 Relative (在屏幕中时) 和 Fixed (移出屏幕时) 的样式效果被提案添加到了 CSS3 中。下面是一个示例:

.sticky {  
    position: -webkit-sticky;  
    position: -moz-sticky;  
    position: -ms-sticky;  
    position: sticky;  
    top: 15px; // 使用和 Fixed 同样的方式设定位置  
} 

因为这个样式尚未进入标准,还必须使用私有前缀。

本实例依赖于 vue.lazyimg.js 这个vue插件。
官方的demo非常清楚,个人在实际应用的实现如下

加载中
33.jpg
加载完成是一个200ms渐变过程
44.jpg

引用js

<script type="text/javascript" src="js/vue.min.js"></script>
<!--vue 懒加载组件-->
<script type="text/javascript" src="js/vue.lazyimg.js"></script>

Html代码

<div id="today-tui" v-cloak="">
            
        </div>
        <script type="text/v-template" id="template">
            <div id="today-tui" v-cloak="">
                <h5>今日推荐 <a href="javascript:rand_pic()">换一批 <img src="images/flush.svg" /></a></h5>
                <ul>
                    <li v-for="pic in list" >
                        <a v-bind:href="['javascript:show_pic('+pic['id']+')']" style="background-image: url(images/loading3.gif); background-repeat: no-repeat; background-position: center;">
                            <img v-lazyload="pic.img_surl" src="images/blocker.jpg" />
                        </a>
                        <a v-bind:href="['javascript:show_pic('+pic['id']+')']">{{pic.img_title}}</a>
                    </li>
                </ul>
            </div>
        </script>

..
注意,我们习惯了v-bind ,但是在这里图片的实际地址赋值是直接 v-lazyload="pic.img_surl" 。
调用懒加载

Vue.use(Lazyload,{
            //ms
            time: 200,
            fade: true,
            nohori: false
        });    

ajax代码如下

function rand_pic(){
            console.log('rand');
            $.ajax({
            type:"post",
            url:HTTP_URL+"/pic/rand",
            data:{
                token:token,
                t:new Date().getTime()
            },
            timeout:10000,
            dataType:'json',
            headers:{'Content-Type':'application/x-www-form-urlencoded'},//使用post的时候需设置为这个    
            success:function(data){
                console.log(data.data[0].img_surl)
                if(data.code == 1){
                    //vue_obj.$data = {'list':data.data};
                    new Vue({
                        el:'#today-tui',
                        template:document.querySelector('#template').innerHTML,
                        data:{
                            'list':data.data
                        }
                    });
                }
            },
            error:function(xhr,type){
                console.log(token);
                console.log('error:'+xhr.message);
            }
        });
        }
        rand_pic();

SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
*/30 * * * * perl /data/check_access.sh
*/31 * * * * python /data/check_txt.py
*/10 * * * * python /data/work.py

详解

如下所示,一般crontab文件里面的定时任务格式如下所示:

59 23 * * * /home/oracle/scripts/alert_log_archive.sh >/dev/null 2>&1

crontab 文件中每个条目中各个域的意义和格式:

第一列 分钟: 1——59

第二列 小时: 1——23(0表示子夜)

第三列 日 : 1——31

第四列 月 : 1——12

第五列 星期: 星期0——6(0表示星期天,1表示星期一、以此类推)

第六列 要运行的命令

我们暂且用C1、C2、C3、C4、C5、C6代表这六列,前面五列通过组合方式来决定执行脚本的频率,最小频率为每分钟执行一次,其中Cn可以用 ; /n ; T1-T2; a,b,c; 四种形式来表示:

当 C1 为 时表示每分钟都要执行脚本,C2 为 时表示每小时都要执行程式,依次类推.....

当 C1 为 T1-T2 时表示从第 T1 分钟到第 T2 分钟这段时间内要执行,C2 为 T1-T2 时表示从第 T1 到第 T2 小时都要执行,依次类推....

当 C1 为 /n 时表示每 n 分钟的时间间隔执行一次,C2 为 /n 表示每隔n小时的间隔执行一次,依次类推.....

当 C1 为 a, b, c,... 时表示第 a, b, c,... 分钟要执行,C2 为 a, b, c,... 时表示第 a, b, c...个小时要执行,依次类推....

20个超实用的Crontab使用实例

每天 02:00 执行任务

0 2 * * * /bin/sh backup.sh

每天 5:00和17:00执行任务

0 5,17 * * * /scripts/script.sh

每分钟执行一次任务
通常情况下,我们并没有每分钟都需要执行的脚本(默默的想到了12306--)

* * * * *  /scripts/script.sh

每周日 17:00 执行任务

0 17 * * sun  /scripts/script.sh

每 10min 执行一次任务

*/10 * * * * /scripts/monitor.sh

在特定的某几个月执行任务

* * * jan,may,aug * /script/script.sh

在特定的某几天执行任务

0 17 * * sun,fri /script/scripy.sh

在每周五、周日的17点执行任务
在某个月的第一个周日执行任务

0 2 * * sun  [ $(date +%d) -le 07 ] && /script/script.sh

每四个小时执行一个任务

0 */4 * * * /scripts/script.sh

每周一、周日执行任务

0 4,17 * * sun,mon /scripts/script.sh

每个30秒执行一次任务
我们没有办法直接通过上诉类似的例子去执行,因为最小的是1min。但是我们可以通过如下的方法。

* * * * * /scripts/script.sh
* * * * *  sleep 30; /scripts/script.sh

多个任务在一条命令中配置

* * * * * /scripts/script.sh; /scripts/scrit2.sh

每年执行一次任务

@yearly /scripts/script.sh

@yearly 类似于“0 0 1 1 *”。它会在每年的第一分钟内执行,通常我们可以用这个发送新年的问候。
每月执行一次任务

@yearly /scripts/script.sh

每周执行一次任务

@yearly /scripts/script.sh

每天执行一次任务

@yearly /scripts/script.sh

每分钟执行一次任务

@yearly /scripts/script.sh

系统重启时执行

@reboot /scripts/script.sh

将 Cron 结果重定向的特定的账户
默认情况下,cron 只会将结果详情发送给 cron 被制定的用户。如果需要发送给其他用户,可以通过如下的方式:

# crontab -l
MAIL=bob
0 2 * * * /script/backup.sh

将所有的 cron 命令备份到文本文件当中
这是一个当我们丢失了cron命令后方便快速的一个恢复方式。
下面是利用这个方式恢复cron的一个小例子。(看看就行~)
首先:检查当前的cron

# crontab -l
MAIL=rahul
0 2 * * * /script/backup.sh

然后:备份cron到文件中

# crontab -l > cron-backup.txt
# cat cron-backup.txt
MAIL=rahul
0 2 * * * /script/backup.sh

接着:移除当前的cron

# crontab -r
# crontab -l
no crontab for root

恢复:从text file中恢复

# crontab cron-backup.txt
# crontab -l
MAIL=rahul
0 2 * * * /script/backup.sh

为了使用scrapy这个框架,就必须安装使用python2.7 .

python2.7 的安装

yum install libbz2 readline-devel sqlite-devel zlib-devel openssl-deve
cd /usr/tmp
yum install gcc

wget https://www.python.org/ftp/python/2.7/Python-2.7.tgz
tar -xvf Python-2.7.tgz
cd Python-2.7
./configure --prefix=/var/python2.7
make && make install

mv /usr/bin/python /usr/bin/python2.6
ln -s /var/python2.7/bin/python2.7 /usr/bin/python

变更了python会导致yum无法正常使用,需修改

vi /usr/bin/yum
#把第一行
#"#!/usr/bin/python" 改为 "#!/usr/bin/python2.6"即可

安装pip (需要先安装setuptools)

wget https://pypi.python.org/packages/source/p/pip/pip-1.5.4.tar.gz
tar -xzvf pip-1.5.4.tar.gz
cd pip-1.5.4
python setup.py install

安装完成后可用
/var/python2.7/bin/pip

建立软链接
ln -s /var/python2.7/bin/pip /usr/bin/pip
就能直接用pip了

爬虫,需要安装以下(可用 yum install libxml2 libxml2-devel 安装,但试用pip操作)
/var/python2.7/bin/pip install requests
/var/python2.7/bin/pip install lxml
一大堆报错
src/lxml/lxml.etree.c:119908: error: ‘struct __pyx_obj_4lxml_5etree__SaxParserContext’ has no member named ‘_node_stack

处理

yum install libxslt-devel

再安装
/var/python2.7/bin/pip install lxml
报错
Could not find .egg-info directory in install record for lxml
处理 升级setuptools

wget https://bootstrap.pypa.io/ez_setup.py
chmod +x ./ez_setup.py
./ez_setup.py

再安装 /var/python2.7/bin/pip install lxml

出现
Requirement already satisfied (use --upgrade to upgrade)
说明已经安装成功

安装scrapy 爬虫框架
pip install scrapy

报错
Could not find .egg-info directory in install record for PyDispatcher>=2.0.5 (from Scrapy)
处理

Could not find .egg-info directory in install record for Twisted>=13.1.0 (from Scrapy)

处理
pip install twisted

>>报错
>>Could not find .egg-info directory in install record for zope.interface>=3.6.0 (from twisted)
>>处理
>>wget https://pypi.python.org/packages/source/z/zope.interface/zope.interface-4.0.5.zip
>>unzip zope.interface-4.0.5.zip
>>cd zope.interface-4.0.5
>>python setup.py install

再安装 pip install twisted

报错No package 'libffi' found

wget ftp://sourceware.org/pub/libffi/libffi-3.2.1.tar.gz
tar -zxvf libffi-3.2.1.tar.gz
cd libffi-3.2.1
./configure
make
make install

export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH

重新安装scrapy
卸载pip uninstall scrapy
安装pip install scrapy

安装成功 再也没有报错了

番外:
python2.7 安装bs4
pip install beautifulsoup4

安装mysql扩展
pip install MySQL-python