linux 下文件夹数据实时同步。

linux 下文件夹数据实时同步。,第1张

sync+crontab。

sync

同步目录软件。可据图自定义任意目录。具体看他官网。

crontab:定是执行任务。用来定时启动sync执行同步。具体还是看他官网!

===========

另外,要做负载均衡,不如另外做数据服务器。,前提是你真不不需要把数据分两份存放!两份数据可以免去备份问题!两台服务器当然可以做高可用均衡,但是还需要额外的均衡服务器才能实现!

一楼嘛都不明白,就介绍软件来了!哈哈,笑死人了!

科技时代,任何行业都离不开数据的分析以及统筹,如果掌握了最关键的数据及技术,那成功就指日可待,所以数据对于一个企业来说,就是最无形的财富,而一个企业的数据基本都有服务器保存及管理着,如何保证数据安全,实现数据同步及备份?诚恺科技小编就同大家一起来看看在Linux服务器中利用rsync配合inotify实现数据实时同步及备份的方法。

rsync:可以镜像保存整个目录树和文件系统。可以很容易做到保持原来文件的权限、时间、软硬链接等等。第一次同步时 rsync 会复制全部内容,但在下一次只传输修改过的文件。

方案:起初用rsync进行数据备份是利用计划任务,定时执行一下命令实现rsync的同步,但最近开发这边修改比较频繁,看来需要实时同步备份来完善备份机制!所以需要利用inotify触发器来改善!达到一旦指定的位置有了新的变动就将其同步!

环境:

CentOS 64 64位

rsync-309

inotify-tools-314

说明:

101016 (rsync+inotify)----------网站程序(/data0/htdocs/)

101019 (rsync)------------------网站程序备份(/data0/htdocs/)

目的:

实现101016的/data0/htdocs/目录下发生任何变动都将实时同步到101019的/data0/htdocs/上(另,这两台都跑有keepalived+nginx,来实现出现故障自动切换的容灾,详细配置会在后面补上)

一、web服务器101016 (rsync+inotify)

1、准备软件包

2、安装Rsync

1)、1234 tar-zxvf rsync-309targz

2)、cdrsync-309

3)、/configure--prefix=/usr/local/rsync

4)、make;makeinstall

建立密码认证文件

[root@ftp ~]# echo "111111">/etc/rsyncd/rsyncdsecrets建立密码认证文件

其中111111可以自己设置密码,rsyncdsecrets名字也可以自己设置;

权限:要将/etc/rsyncd/rsyncdsecrets设置为root拥有, 且权限为600。

# chmod 600 /etc/rsyncd/rsyncdsecrets

3、安装inotify

1)、1234 tar-zxvf inotify-tools-314targz

2)、cdinotify-tools-314

3)、/configure--prefix=/usr/local/inotify

4)、make;makeinstall

4、创建rsync复制脚本

此项功能主要是将ftp端的目录/data0/htdocs/里的内容,如果修改了(无论是添加、修改、删除文件)能够通过inotify监控到,并通过rsync实时的同步给101019的/data0/htdocs里,下面是通过shell脚本实现的。

[root@web ~]# vim /root/shell/rsyncsh

[root@web ~]# chmod u+x /root/shell/rsyncsh

[root@web ~]# setsid /root/shell/rsyncsh &

#后台运行脚本,关闭shell终端继续后台运行

rsyncsh脚本加入开机启动项

# echo "/root/shell/rsyncsh" >> /etc/rclocal

防火墙开启rsync端口:873

添加:

iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 873 -jACCEPT

重启:

# /etc/initd/iptables restart

二、备份服务器101019(rsync)

1、准备工作

创建备份目录:

# mkdir /data0/htdocs

2、安装rsync(备份主机只安装rsync)

1)、1234 tar-zxvf rsync-309targz

2)、cdrsync-309

3)、/configure--prefix=/usr/local/rsync

4)、make;makeinstall

3、建立用户与密码认证文件

[root@backup ~]# echo "root:111111" > /etc/ rsyncd/rsyncdsecrets

[root@backup ~]# less /etc/rsyncd/rsyncdsecrets

root:111111

注意:

请记住,在101016端建立的密码文件,只有密码,没有用户名;而在101019里建立的密码文件,用户名与密码都有。

权限:要将/etc/rsyncd/rsyncdsecrets设置为root拥有, 且权限为600。

#chmod 600 /etc/rsyncd/rsyncdsecrets

4、建立rsync配置文件

[root@backup ~]# vim /etc/rsyncd/rsyncdconf

启动rsync服务

# /usr/local/rsync/bin/rsync --daemon --config=/etc/rsyncdconf

# ps -ef |grep rsync

Rsync服务加入开机启动项

# echo "/usr/local/rsync/bin/rsync --daemon --config=/etc/rsyncdconf" >> /etc/rclocal

防火墙开启rsync端口:873

添加:

iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 873 -jACCEPT

重启:

# /etc/initd/iptables restart

完成,其实这个时候数据已经同步了!

测试一下:

由于/data0/htdocs/下涉及到一些公司信息,所以就以/data0/htdocs/tmp/为例

主机名可以区别是两台机器,里面的内容完全一直,连文件的属性都一样

再对里面修改一下试试,创建一个文件,然后删除user目录试试

如何使用Linux提供的信号量来实现进程的互斥和同步?

设互斥信号量mutex初值为1,进程执行操作前P(mutex),操作完成后V(mutex)。P操作使mutex减1,如果mutex

(以前过的关于PV操作的答案一个,你看看有用没)

linux内核同步机制中的概念介绍和方法是什么?

简单说,

Linux内核编程

就是开发Linux驱动程序,学会内核编程后,将会对操作系统的内部机制和工作原理有充分了解,可以从事硬件驱动开发、嵌入式系统开发等。内核编程的语言仍是传统的C语言,但其编写方法和调用接口与传统应用程序的差别较大,你必须了解如何处理中断、如何在内核态和用户态之间转换、PCI、DMA、内核地址映射、内核I/O等

Linux编程

就是用户层编程,给人用的那些程序,比如,浏览器,截图工具,只不过是在linux上运行的

Linux内核的同步机制是什么?

从最初的原子操作,到后来的信号量,从大内核锁到今天的自旋锁。

这些同步机制的发展伴随Linux从单处理器到对称多处理器的过渡;伴随着从非抢占内核到抢占内核的过度。Linux的锁机制越来越有效,也越来越复杂。Linux的内核锁主要是自旋锁和信号量。自旋锁最多只能被一个可执行线程持有,如果一个执行线程试图请求一个已被争用(已经被持有)的自旋锁,那么这个线程就会一直进行忙循环——旋转——等待锁重新可用。

要是锁未被争用,请求它的执行线程便能立刻得到它并且继续进行。

自旋锁可以在任何时刻防止多于一个的执行线程同时进入临界区。Linux中的信号量是一种睡眠锁。如果有一个任务试图获得一个已被持有的信号量时,信号量会将其推入等待队列,然后让其睡眠。这时处理器获得自由去执行其它代码。

当持有信号量的进程将信号量释放后,在等待队列中的一个任务将被唤醒,从而便可以获得这个信号量。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » linux 下文件夹数据实时同步。

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情