2011年10月

发现MySQL在上午的时候忽然发飙,不断的挂掉。看MySQL的error.log,只能看到类似如下的信息:
Forcing close of thread 12232 user: 'root'

mysqladmin -uroot -p******** status -i 1

使用上述命令,发现Queries per second avg只有200左右,可以说很低,但是Threads确非常不稳定,居然会瞬间升至200以上,一般情况下这个线程这个值都是不会高于5的个位数。

mysqladmin -uroot -p******** processlist

使用上述命令,发现居然有大量的unauthenticated user进程。Google了一下,发现这算MySQL的一个BUG,不管连接是通过hosts还是ip的方式,MySQL都会对DNS做反查,IP到DNS,由于反查的接续速度过慢,大量的查询就难以应付,线程不够用就使劲增加线程,但是却得不到释放,所以MySQL会“假死”。

解决方案,结束这个反查的过程,禁止任何解析,打开mysql的配置文件(my.cnf),在[mysqld]下面增加一行:

skip-name-resolve

重新载入配置文件或者重启MySQL服务即可。

大河报讯(记者杨凌)最低工资标准上调了!9月30日,省人力资源和社会保障厅举行新闻通气会向全省通报这一好消息:2011年10月1日起,河南月最低工资标准将由现行的800元、700元、600元分别调整为1080元、950元和820元。

省辖市最低工资标准过千元

据悉,河南月最低工资标准由现行的800元、700元、600元分别调整为1080元、950元、820元;小时最低工资标准由现行的9元、7.9元、6.8元分别调整为10.2元、8.9元、7.7元。月最低工资标准适用于全日制就业劳动者;小时最低工资标准适用于非全日制就业劳动者。调整后的最低工资标准从2011年10月1日起执行。

根据当地经济发展水平的不同,我省将各地区分别划分为一、二、三类行政区域,分别执行高、中、低档月最低工资标准和小时最低工资标准,如郑州市、洛阳市、开封市等18个省辖市及省直管县巩义市属一类行政区域范围;新乡县、安阳县、临颍县等属二类行政区域范围;开封县、淅川县、沈丘县等属三类行政区域范围。

据悉,今年以来,全国已有18个省、市、区调整了最低工资标准。

最低工资标准包含个人缴纳“三险一金”

通气会上,该厅有关负责人介绍,河南现行月最低工资标准和小时最低工资标准是从2010年7月1日起执行的。以往河南公布的最低工资标准不包含职工个人缴纳的养老、医疗、失业保险费和住房公积金,即“三险一金”,用人单位需另行支付。自今年10月1日起,河南最低工资标准包含职工个人缴纳的“三险一金”,在构成上将与原劳动部颁发的《最低工资规定》并轨。

该负责人强调,最低工资标准不包含的项目有:用人单位支付给劳动者的加班加点工资;中班、夜班、高温、低温、井下、有毒有害等特殊工作环境、条件下的津贴;通过贴补伙食、住房等支付给劳动者的非货币性收入;用人单位依法为劳动者缴纳的各项社会保险费和住房公积金;按照国家规定为劳动者提供的福利待遇等内容。

第一个是我自己写的一个简单的PHP可逆加密函数
第二个是我根据Discux!X的函数改写的一个较为复杂的PHP可逆加密函数

//第一个
function anrip_authcode1($str, $opt = 'encode', $key = 'anrip') {
  $result = '';
  $self = __FUNCTION__;
  if($opt == 'mcrypt') {
    $key = md5($key);
    $key_length = strlen($key);
    $str_length = strlen($str);
    for($i = $m = 0; $i < $str_length; $i++, $m++) {
      $m = $m == $key_length ? 0 : $m;
      $result .= $str[$i] ^ $key[$m];
    }
  } elseif($opt == 'encode') {
    $rnd = md5(mt_rand().$key);
    $rnd_length = strlen($rnd);
    $str_length = strlen($str);
    for($i = $m = 0;$i < $str_length; $i++, $m++) {
      $m = $m == $rnd_length ? 0 : $m;
      $result .= $rnd[$m].($str[$i] ^ $rnd[$m]);
    }
    $result = base64_encode($self($result, 'mcrypt', $key));
    $result = str_replace('==', '', $result);
    $result = str_replace('+', '*', $result);
  } elseif($opt == 'decode') {
    $str = str_replace('*', '+', $str);
    $str = $self(base64_decode($str), 'mcrypt', $key);
    $str_length = strlen($str);
    for($i = 0; $i < $str_length; $i++) {
      $md5 = $str[$i];
      $result .= $str[++$i] ^ $md5;
    }
  }
  return $result;
}
//第二个
function anrip_authcode2($str, $opt = 'encode', $key = 'anrip', $expiry = 0, $length = 4) {
  //define some key
  $key = md5(defined(AUTH_KEY) ? AUTH_KEY : $key);
  $keya = $length > 0 ? substr($opt == 'encode' ? md5(microtime()) : $str, 0, $length) : '';
  $keyb = md5(substr($key, 0, 16)).md5($key.$keya);
  $keyc = md5(substr($key, 16, 16).$keya.$keyb);
  //set $rnd
  $rnd = array();
  for($i = 0, $j = strlen($keyb); $i < 256; $i++) {
    $rnd[$i] = ord($keyb[$i%$j]);
  }
  //set $box
  $box = range(0, 255);
  for($j = $i = 0; $i < 256; $i++) {
    $j = ($j + $box[$i] + $rnd[$i]) % 256;
    list($box[$i], $box[$j]) = array($box[$j], $box[$i]);
  }
  //get $result
  $result = '';
  $expiry = $expiry ? $expiry + time() : 0;
  $str = $opt == 'encode' ? sprintf('%010d', $expiry).substr(md5($str.$keyc), 0, 16).$str : base64_decode(substr($str, $length));
  for($a = $i = $j = 0, $l = strlen($str); $i < $l; $i++) {
    $a = ($a + 1) % 256;
    $j = ($j + $box[$a]) % 256;
    list($box[$a], $box[$j]) = array($box[$j], $box[$a]);
    $result .= chr(ord($str[$i]) ^ ($box[($box[$a]+$box[$j]) % 256]));
  }
  //return $str
  if($opt == 'encode') {
    return $keya.str_replace('=', '', base64_encode($result));
  }
  else {
    $str = substr($result, 26);
    $expiry = substr($result, 0, 10);
    if(($expiry == 0 || $expiry > time()) && substr($result, 10, 16) == substr(md5($str.$keyc), 0, 16)) {
      return $str;
    }
    else return '';
  }
}

因为项目需要,今天写了一个JS版的根据给定的时间获取Unix时间戳的转换函数,不多废话,直接上代码。

/*!
 * 根据给定的时间获取Unix时间戳
 * @time : 时间;字符:'yyyy-mth-dd hh:mm:ss'
 * @tzone: 时区;整数:[-12,+12]
 */
function timestamp(time, tzone) {
  if(time) {
    var t = time.match(/((\d{4})\D(\d\d)\D(\d\d))(\s(\d\d)\D(\d\d)\D(\d\d))?/) || [];
    if(t[8]) time = new Date(t[2], t[3]-1, t[4], t[6], t[7], t[8]);
    else if(t[4]) time = new Date(t[2], t[3]-1, t[4]);
    else return 0;
  }
  return Math.round((time||new Date()).getTime()/1000)+(tzone||8)*3600;
}

上述函数支持以下四种格式的参数:

timestamp(); //当前时间戳
timestamp('1970-01-01'); //表示当日0点
timestamp('1970-01-01 00:00:01'); //日期以-分割
timestamp('1970/01/01 00:00:01'); //日期以/分割

在做xServer批处理版控制台时写了这个方法,这里给出来,供大家参考:

:check_network
  echo. && echo 测试网络环境...
  ping 127.0.0.1 -n 2 >nul || (
    echo 测试失败,请检查网络连接.
    goto check_network
  )
  goto :EOF

本程序用于检测本地网络是否可用,不可用将循环检测,直到可用跳出循环。