zoukankan      html  css  js  c++  java
  • 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之前  
  • 相关阅读:
    Apachebench压力测试
    nodejs调试方法
    chrome 内存泄漏如何定位
    nodejs模块路径alias
    云计算基本概念IaaS,PaaS,SaaS和Serverless
    单点登录sso
    彻底删除mysql服务
    Java-Tomcat for Mac配置
    访问日志不记录静态文件 访问日志切割 静态元素过期时间
    Mac eclipse 连接安卓手机调试 adb
  • 原文地址:https://www.cnblogs.com/zhanzhao/p/5837727.html
Copyright © 2011-2022 走看看