首页 > 代码库 > redis 同步
redis 同步
1、忽略信号signal(SIGPIPE, SIG_IGN)
当服务器close一个连接时,若client端接着发数据。
根据TCP 协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。
根据信号的默认处理规则SIGPIPE信号的默认执行动作是terminate(终止、退出),所以client会退出。
若不想客户端退出可以把SIGPIPE设为SIG_IGN
如: signal(SIGPIPE,SIG_IGN);
这时SIGPIPE交给了系统处理。
服务器采用了fork的话,要收集垃圾进程,防止僵尸进程的产生,可以这样处理:
signal(SIGCHLD,SIG_IGN); 交给系统init去回收。
这里子进程就不会产生僵尸进程了。
2、读取配置文件 若传递参数则直接读取参数 若没有传递 使用默认路径
配置文件包括 日志的配置文件 输入数据的地址 redis集群的地址 线程数
3、创建n+2个线程 一个读线程 一个写线程 n个任务线程
创建n个信号量 n个task队列
每个线程绑定一个函数 处理数据
对写task的时候都先访问信号量
4、链接redis 如果链接失败就一直重连
在写redis之前
redis 同步
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。