美文网首页
sersync 实时同步

sersync 实时同步

作者: linux_阿杰 | 来源:发表于2020-03-13 21:02 被阅读0次

    实现web 上传视频文件,实则是写入NFS 至存储,当NFS存在新的数据则会实时的复制到备份服务器

    NFS服务器

    root@nfs:~# yum install nfs-utils
    root@nfs:~# cat /etc/exports
    /data 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)
    root@nfs:~# mkdir /data
    root@nfs:~# groupadd -g666 www
    root@nfs:~# useradd -u666 -g666 -M -s /sbin/nologin www
    root@nfs:~# chown -R www.www /data
    root@nfs:~# systemctl start nfs
    root@nfs:~# systemctl enable nfs
    

    web服务器

    [root@web01 ~]#yum -y install httpd php
    [root@web01 ~]#mount -t nfs 172.16.1.31:/data /var/www/html
    # 上传提交视频的代码到/var/www/html
    [root@web01 ~]#cat /etc/httpd/conf/httpd.conf
    User www
    Group www
    [root@web01 ~]#systemctl restart httpd
    

    web和nfs的数据都备份到备份服务器的/backup
    bakcup服务器下的/backup目录接收 web和NFS重要的文件 /etc/hosts fstab

    backup服务器操作

    # 安装rsync
    [root@backup ~]#yum -y install rsync
    # 配置rsync
    [root@backup ~]# cat /etc/rsyncd.conf 
        uid = rsync
        gid = rsync
        port = 873
        fake super = yes
        use chroot = no
        max connections = 200
        timeout = 600
        ignore errors
        read only = false
        list = false
        auth users = rsync_backup
        secrets file = /etc/rsync.passwd
        log file = /var/log/rsyncd.log
        [backup]
        comment = welcome
        path = /backup
    [root@backup ~]# useradd -M -s /sbin/nologin rsync
    [root@backup ~]# echo 'rsync_backup:123456' >/etc/rsync.passwd
    [root@backup ~]# chmod 600 /etc/rsync.passwd
    [root@backup ~]# mkdir /backup
    [root@backup ~]# chown -R rsync.rsync /backup
    [root@backup ~]# mkdir /data
    [root@backup ~]# chown -R rsync.rsync /data
    

    web服务器和nfs服务器操作

    nfs自动备份脚本

    #!/bin/bash
    # 指定环境变量
    export PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin"
    
    # 定义变量
    NAME=`hostname`
    IP=`ifconfig eth1|awk 'NR==2{print $2}'`
    DATE=`date +%F`
    DIR=/backup
    DEST=${NAME}_${IP}_$DATE
    
    # 创建备份目录
    mkdir -p $DIR/$DEST/
    
    # 备份数据
    tar zcf /$DIR/$DEST/messages.tar.gz /var/log/ &>/dev/null
    
    # 加密文件
    md5sum $DIR/$DEST/messages.tar.gz > $DIR/$DEST/md5.log
    
    # 远程传输
    rsync -zva $DIR/  rsync@172.16.1.81::backup --password-file=/etc/rsync.password
    
    # 删除七天前的数据
    find  /backup/  -mtime +7  |xargs rm -fr
    

    将NFS数据实时同步到备份服务器的/data目录

    # 1.安装inotify 事件监控服务
    [root@nfs ~]# yum -y install inotify-tools
    [root@nfs ~]# yum -y install rsync
    # 2.下载sersync
    [root@nfs ~]#wget https://github.com/wsgzao/sersync/blob/master/sersync2.5.4_64bit_binary_stable_final.tar.gz
    [root@nfs ~]#tar xf sersync2.5.4_64bit_binary_stable_final.tar.gz
    [root@nfs ~]# mv GNU-Linux-x86 /usr/local/sersync
    # 3.配置
    # 自行修改配置文件/usr/local/sersync/confxml.xml
    <sersync>
            <localpath watch="/data" //共享目录>
                <remote ip="172.16.1.81" //推送服务器内网 ip name="data" //名字 />
            </localpath>
            <rsync>
                <commonParams params="-az" // 推送参数/>
                <auth start="true" //true users="rsync" passwordfile="/etc/rsync.password" //密码文件/>
                <userDefinedPort start="false" port="874"/><!-- port=874 -->
                <timeout start="true" //true time="100"/><!-- timeout=100 -->
                · · · · · · 
    # 4.启动
    /usr/local/sersync/sersync2 -rdo /usr/local/sersync/confxml.xml
    # 5.测试
        # 1.服务器是否有数据
        # 2.使用复制命令的方式检查配置文件是否成功
    cd /data && rsync -az -R --delete ./  --timeout=100 rsync_backup@172.16.1.41::data --password-file=/etc/rsync.passwd
    # 6.如果监控多个目录如何实现?
    一个配置文件对应一个监控目录 分别指定不同的配置文件启动
    /usr/local/sersync/sersync2 -rdo /usr/local/sersync/confxml.xml 
    /usr/local/sersync/sersync2 -rdo /usr/local/sersync/opt_conf.xml 
    # 7.上传视频进行文件测试
    

    如果NFS不可用,如何快速的切换到backup备份服务器

    backup服务器操作

    # 1.安装nfs服务
        [root@backup ~]# yum -y install nfs-utils
        # 2.cat /etc/exports
        /data 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)
        # 3.创建并授权
        groupadd -g666 www
        useradd -u666 -g666 -M -s /sbin/nologin www
        chown -R www.www /data
        web01服务器操作
        # 1.卸载172.16.1.31的挂载目录 /var/www/html
        [root@web01 ~]# umount -lf /var/www/html
    

    如何NFS恢复 把挂载目录挂载到NFS服务器上

    1.把差异的文件推送到NFS上
    rsync -azv /data/ root@172.16.1.31:/data/
    2.卸载backup服务器的挂载目录
    umount -lf /var/www/html
    

    挂载到NFS

    mount -t nfs 172.16.1.31:/data /var/www/html

    NFS探测脚本

        [root@web01 scripts]# cat check_network.sh 
        #!/bin/sh
        source /etc/profile
        ping -c2 -W1 172.16.1.31 &>/dev/null
        if [ $? -ne 0 ];then
           ping -c2 -W1 172.16.1.41 &>/dev/null
           if [ $? -eq 0 ];then
                umount -lf /var/www/html
                mount -t nfs 172.16.1.41:/data /var/www/html
           else
                mail -s "check nfs backup" 593528156@qq.com < /server/scripts/nfs.txt
           fi
        else
            echo "NFS服务正常"
    
        fi 
    

    相关文章

      网友评论

          本文标题:sersync 实时同步

          本文链接:https://www.haomeiwen.com/subject/aqpyshtx.html