Blog

  • tmpfs使用方法

    在使用df -h命令,会发现如下一条

    Filesystem                   Size  Used Avail Use% Mounted on

    tmpfs                        6.3G   13M  6.3G   1% /run/shm

    tmpfs是Linux/Unix系统上的一种基于内存的文件系统,类似于ext3, ext4。tmpfs可以使用您的内存或swap分区来存储文件。temfs主要存储暂存的文件。他有如下三个优势:
    1.动态文件系统的大小。
    2.tmpfs 的另一个主要的好处是它的速度。因为tmpfs位置为内存中,读写几乎可以是瞬间的。
    3.tmpfs 数据在重新启动之后不会保留,因为虚拟内存本质上就是易失的。所以有必要做一些脚本做诸如加载,绑定的操作。tmpfs不具备持久性,重启后数据不保留,原因很明显,它是基于内存的。

    二./dev/shm/相关

    /dev/shm就是tmpfs的挂载点了,它的大小一般为内存的一半(CentOS)。如果要修改/dev/shm的大小为4GB,修改/etc/fstab

    tmpfs                   /dev/shm                tmpfs   defaults        0 0

    改为

    tmpfs                   /dev/shm                tmpfs   defaults, size=4G        0 0

    然后重新挂载生效

    mount -o remount /dev/shm

    三.tmpfs(/dev/shm)的应用

    既然tmpfs速度很快,那很多不怕丢的东西放内存是最好的。比如经常使用的/tmp目录,可以使用mount –bind命令将/tmp挂载成tmpfs。

    mkdir /dev/shm/tmp
    chmod 1777 /dev/shm/tmp //注意权限
    mount –bind /dev/shm/tmp /tmp

    接下来很多应用的临时文件, cache就可以放在/tmp下,如

    (1)将squid的缓存目录cache_dir放到/tmp下
    vi /etc/squid/squid.conf
    修改成
    cache_dir ufs /tmp 256 16 256
    这里的第一个256表示使用256M内存,重启一下squid服务,这样缓存目录都放在了tmpfs文件中了,速度不用说吧。

    (2)将php的session文件放在/tmp下
    对于一个访问量大的以apache php的网站,可能tmp下的临时文件都会很多,比如seesion或者一些缓存文件,那么你可以把它保存到tmpfs文件。保存seesion的方法很简单了:只要修改php.ini就行了,通过phpinfo测试文件查看你的php session存储位置,如果不在/tmp下,修改php.ini文件,修改如下:
    session.save_path = “/tmp”

    (3)将服务的socket文件放在/tmp下
    nginx.socket和mysql.sock

    至于tmpfs的其他应用,我想大家可能通过这篇文章会有所启发。再次强调下:tmpfs 数据在重新启动之后不会保留,重启tmpfs 数据会丢失,所以有必要做一些脚本做诸如加载,绑定的操作!

  • javascript跳转

    在header里写功能函数

    var secs =5;
    var URL;
    function Load(url){
    URL = url;
    for(var i=secs; i>=0; i--){
    window.setTimeout('doUpdate(' + i + ')', (secs-i) * 1000);
    }
    }
    function doUpdate(num){
    document.getElementById('timer').innerHTML= num;
    if(num == 0){ window.location = URL;}
    }

    写一个span,然后不断更新秒数

    span id="timer"
    javascript:
    Load("/login");
  • linux创建lvm

    一、概念:

    1).PV(Physical Volume):物理卷,处于LVM最底层,可以是物理硬盘或者分区。
    2).VG(Volume Group):物理卷组,建立在PV之上,可以含有一个到多个PV。
    3).LV(Logical Volume):逻辑卷,建立在PV之上,相当于原来分区的概念。不过大小可动态改变。
    4).PE(Physical Extend):物理区域,PV中可以用于分配的最小存储单位,可以在建立PV时指定,如1,2,4,8… …64M,同一VG中的所有PV的PE应该相同。
    5).LE(Logical Extend):逻辑区域,LV中可以用于分配的最小存储单元,取决于LV所在PV中PE的大小,是PE的整数倍。
    6).VGDA(Volume Group Descriptor Area):卷组描述区域,存在于每个PV中,用于描述该PV本身、PV所含VG、VG中的LV以及LV中的物理区域分配等信息,在使用pvcreate命令建立PV时建立。

    二、步骤:

    1).建立LVM类型的分区
    2).建立LVM物理卷PV
    3).建立LVM卷组VG
    4).建立LVM逻辑卷LV
    5).建立文件系统
    6).挂接文件系统
    7).使用文件系统

    三、示例

    有硬盘sdb和sdc,sdb打算存数据盘,sdc用做数据的备份,为了防止以后空间不足等情况,需要创建lv,并分别挂载到/data和/backup下。

    1).要使用新硬盘,创建物理卷,这里使用整块硬盘

    pvcreate /dev/sdb
    pvcreate /dev/sdc

    pvdisplay:显示PV属性
    pvscan:在系统所有硬盘上查找PV
    pvdata:显示某个PV的详细信息

    2).将两块硬盘分别创建并加入不同的组datavg和backupvg

    vgcreate data /dev/sdb
    vgcreate backup /dev/sdc

    vgdisplay:显示卷组的属性
    vgscan:查找系统现有VG卷组
    vgdata:显示VG卷组上的VGDA信息
    vgchange:改变VG卷组属性
    此命令有两个常用的参数:
    -a:,–available{y|n}:在操作VG时,控制一个VG的可使用性,换句话说控制一个VG能否被系统内核识别。
    -x,–allocation{y|n}:控制一个VG能否被扩充或者缩减(控制一个VG内的PV能否被分配)。
    vgextend:用于向VG中添加新的PV
    如 vgextend datavg /dev/sda6
    vgreduce:用于从VG中删除PV
    如 vgreduce datavg /dev/sda6
    vgmerge:用于合并卷组。待合并的VG必须处于非活动状态。
    例如:将demoVG2合并到demoVG1中
    vgchange -a n demoVG1
    vgchange -a n demoVG2
    vgmerge demoVG1 demoVG2

    vgsplit:用于拆分已经存在的VG,VG必须处于活动状态。

    vgchange -a y demoVG2
    vgsplit demoVG2 demoVG4 /dev/hdd2 /dev/hdd5 /dev/hdd6 /dev/hdd7

    vgremove:用于删除VG,要求待删除的VG必须处于非激活状态。
    vgchange -a n demoVG1
    vgremove demoVG1

    vgrename:用于重命名VG,不要求VG处于非激活状态。
    vgrename demoVG2 demoVG3

    3)、创建逻辑卷

    由于这里要使用整个磁盘,所以在datavg和backupvg中分别建立datalv,backuplv

    lvcreate -l 100%FREE -n datalv datavg
    lvcreate -l 100%FREE -n backuplv backupvg

    lvdisplay:显示LV的属性
    lvscan:查找系统现有LV
    lvdata:显示LV上的LVDA信息
    lvchange:改变LV属性
    lvextend:扩展LV容量。LVM的最突出特点就是随时动态的调整LV空间大小。
    如lvextend -L +10m /dev/demoVG1/demoLV11 (为demoLV11增加10MB的空间)

    创建50% vg大小的lv
    lvcreate -l 50%VG -n lv001 vg001
    创建使用余下所有vg大小的lv
    lvcreate -l 100%FREE -n lv002 vg002
    创建100M大小的lv
    lvcreate -L 100M -n lv003 vg003

    lvreduce:减小LV容量。
    例如:
    lvextend -L -10m /dev/demoVG1/demoLV11 (为demoLV11减少10MB的空间)

    vrename:LV重命名
    例如:
    lvrename /dev/demoVG1/demoLV11 /dev/demoVG1/demoLV01
    lvremove:删除LV(逻辑卷)

    例如:
    lvremove /dev/demoVG1/demoLV01 <11>resize2fs/e2fsadm/resize_reiserfs:类似于extend命令。

    4).创建文件系统

    mkfs.ext4 /dev/datavg/datalv
    mkfs.ext4 /dev/backupvg/backuplv

    5).挂载文件系统

    mount /dev/datavg/datalv /data
    mount /dev/backupvg/backuplv /backup

    保证重启后还能用,/etc/fstab中加入

    /dev/jira/jiralv /var/lib/jira ext4 defaults 0 1
    /dev/backup/backuplv /var/lib/backup ext4 defaults 0 1

    LVM相关命令

    <1>lvmdiskscan:检测硬盘和分区中的逻辑卷管理信息
    <2>lvmsadc:收集逻辑卷的读写统计信息
    <3>lvmsar:查看LVM的日志文件信息
    <4>lvmchange:复位LVM组件

  • 使用dhclient重新获取ip地址

    dhcp的全称是Dynamic Host Configuration Protocol

    dhclient则是Dynamic Host Configuration Protocol client

    使用dhclient重新在dhcp服务器攻取ip地址

    dhclient -r eth0
    ifconfig eth0 down
    ifconfig eth0 up
    dhclient eth0

    经过上面操作,就会获取到新的ip地址。

    centos6的dhclient的信息缓存在/var/lib/dhclient/dhclient-*.leases

  • 建立一个yum源

    使用的工具是createrepo

    首先创建目录,

    mkdir -p mirrors.jpuyy.com/centos/6.4/os/x86_64

    并进入到此目录,执行

    createrepo .

    在当前目录下生成了repodata目录,记录了repo的信息。
    最终的rpm包都要放到Packages下

    目录结构参考http://mirrors.sohu.com。centos6的目录软链接到centos6.4

    mirrors.jpuyy.com
    └── centos
        ├── 6 -> 6.4
        ├── 6.0
        └── 6.4
            ├── centosplus
            ├── contrib
            ├── cr
            ├── extras
            ├── fasttrack
            ├── isos
            ├── os
            │   └── x86_64
            │       ├── EFI
            │       ├── images
            │       ├── isolinux
            │       ├── Packages
            │       │   ├── MariaDB-5.5.31-centos6-x86_64-client.rpm
            │       │   ├── MariaDB-5.5.31-centos6-x86_64-common.rpm
            │       │   ├── MariaDB-5.5.31-centos6-x86_64-devel.rpm
            │       │   ├── MariaDB-5.5.31-centos6-x86_64-server.rpm
            │       │   ├── MariaDB-5.5.31-centos6-x86_64-shared.rpm
            │       │   └── MariaDB-5.5.31-centos6-x86_64-test.rpm
            │       └── repodata
            │           ├── 0c2ce006b4ccb96b4d0947584daab68e971f25f0c59a2f856895a3dcc4760e0b-primary.xml.gz
            │           ├── 2a827a63089cb7561b755baff2c1ae4c202cd74a1a92e1274e85f9e4dac569a0-other.sqlite.bz2
            │           ├── 3e5e63e57c07f479edc526404f28c63c1ad097670cde380d3866b63090d6f3e0-filelists.xml.gz
            │           ├── 44a30e7cd6fd27e8f820ba7a50d329c99428ea68b4f0904475c5ee8961c1c8ec-primary.sqlite.bz2
            │           ├── b3d59bc4f2a6c3c198798e188b4a0d0af99692efaa88f989c47df4c036fea210-filelists.sqlite.bz2
            │           ├── f94e27df58d67783e29dd0aeca51ff7ffec2bc501e0f82e0a4c7d843dcb2cb6c-other.xml.gz
            │           └── repomd.xml
            ├── updates
            └── xen4

    这里的repo使用http提供服务,所以在nginx下,如果要酷一些的页面,可以编译nginx,添加fancyindex模块,http://wiki.nginx.org/NginxNgxFancyIndex

    server {
        listen 80;
        server_name mirrors.jpuyy.com;
        location / {
            root /data/mirrors.jpuyy.com/;
            autoindex on;
        }
    }

    在需要使用此源服务器上,添加/etc/yum.repos.d/jpuyy-mirrors.repo,写入

    [mirror-of-jpuyy]
    name=mirror-of-jpuyy
    baseurl=http://mirrors.jpuyy.com/centos/$releasever/os/$basearch/
    enabled=1
    gpgcheck=0

     

     

  • CentOS6禁用ipv6

    1.修改/etc/sysconfig/network,添加:

    NETWORKING_IPV6=no

    2.修改/etc/hosts,将ipv6的那句本地主机名解析的也注释掉:

    #::1 localhost localhost6 localhost6.localdomain6

    3.让系统不加载ipv6相关模块,这需要修改modprobe相关设定文件,可以新建一个/etc/modprobe.d/ipv6off.conf,添加

    alias net-pf-10 off
    options ipv6 disable=1

    4.重启系统,使用如下命令确认已经生效:

    [root@test ~]# lsmod | grep -i ipv6
    [root@test ~]# ifconfig | grep -i inet6

    参考:http://www.litvip.com/499/