January 25, 2013
git remote用法总结
"\u003cp\u003e\u003cstrong\u003egit remote\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003egit remote显示所有的remote(加-v显示详细信息)。\ngit remote add [shortname] [url]用来添加remote。\ngit fetch [remote-name]只会pull下来全部的更动,但不会自动merge,但是git pull会自动merge。\ngit remote show [remote-name]可以看到一个remote的详细信息。\ngit remote rename old new 用来改变一个remote的名字。\ngit remote rm [remote-name]删除一个remote。\ngit remote 不带参数,列出已经存在的远程分支,例如:\n#git remote\norigin_apps\u003c/p\u003e\n\u003cp\u003egit remote -v | –verbose 列出详细信息,在每一个名字后面列出其远程url,例如:\n#git remote -v\norigin_apps gitolite@scm:apps/Welcome.git (fetch)\norigin_apps …\u003c/p\u003e"
January 17, 2013
如何查看crontab的日志记录
"\u003cp\u003e昨天crontab中的同步任务没有执行,不知道是什么原因没有执行,貌似任务hang住了,想查询一下crontab到底问题出在哪里,或者hang在了什么地方。\u003c/p\u003e\n\u003cp\u003e1. linux\u003c/p\u003e\n\u003cp\u003e看 /var/log/cron这个文件就可以,可以用tail -f /var/log/cron观察\u003c/p\u003e\n\u003cp\u003e2. unix\u003c/p\u003e\n\u003cp\u003e在 /var/spool/cron/tmp文件中,有croutXXX001864的tmp文件,tail 这些文件就可以看到正在执行的任务了。\u003c/p\u003e\n\u003col start=\"3\"\u003e\n\u003cli\u003email任务\u003c/li\u003e\n\u003c/ol\u003e\n\u003cp\u003e在 /var/spool/mail/root 文件中,有crontab执行日志的记录,用tail -f /var/spool/mail/root 即可查看最近的crontab执行情况。\u003c/p\u003e"
January 17, 2013
运行cacti的问题Cannot connect to MySQL server on ‘localhost’.Please make sure you have specified a valid MySQL database name in ‘include/config.php’
"\u003cp\u003e参考以次的教程 \u003ca href=\"http://blog.haohtml.com/archives/9428\"\u003ehttp://blog.haohtml.com/archives/9428\u003c/a\u003e,在centos安装cacti监控工具,发现在命令行下运行\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp\u003ephp /var/www/html/cacti/poller.php\u003c/p\u003e\u003c/blockquote\u003e\n\u003cp\u003e的时候,提示以下错误\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp\u003eFATAL: Cannot connect to MySQL server on ‘localhost’. Please make sure you have specified a valid MySQL database name in ‘include/config.php’\u003c/p\u003e\u003c/blockquote\u003e\n\u003cp\u003e而这此配置文件是没有任何问题的,cacti后台访问一切正常的。poller.php是使用/var/lib/mysql/mysql.sock的,\u003c/p\u003e\n\u003cp\u003e当我在my.cnf里把mysql.sock定义到/var/lib/mysql/mysql.sock时,poller.php可以连接,\n但执行mysql就提示错误了,我把mysql.sock的位置改为/tmp/mysql.sock,使用网上提供\u003cstrong\u003e解决办法:\u003c/strong\u003e\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp\u003eln -s /tmp/mysql.sock …\u003c/p\u003e\u003c/blockquote\u003e"
January 17, 2013
查看Linux系统 重启日志,登录日志和输入命令的日志
"\u003cp\u003e查看 重启情况\u003c/p\u003e\n\u003cp\u003e# last reboot\u003c/p\u003e\n\u003cp\u003e——————————————————————————————————————————————–\u003c/p\u003e\n\u003cp\u003ereboot system boot 2.6.18-92.el5 Mon Dec 6 12:50 (05:11)\nreboot system boot 2.6.18-92.el5 Mon Dec 6 10:49 (07:12)\nreboot system boot 2.6.18-92.el5 Sun Dec 5 18:56 (23:05)\nreboot system boot 2.6.18-92.el5 Mon Nov 29 09:55 (7+08:06)\nreboot system boot 2.6.18-92.el5 Sun Nov 28 13:47 (8+04:14)\nreboot system boot 2.6.18-92.el5 Thu Nov 25 11:59 …\u003c/p\u003e"
January 14, 2013
nginx无法启动: libpcre.so.1/libpcre.so.0: cannot open shared object file解决办法
"\u003cp\u003eNGINX启动时提示错误:\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp\u003e/usr/local/nginx/sbin/nginx -t\n/usr/local/nginx/sbin/nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory\u003c/p\u003e\u003c/blockquote\u003e\n\u003cp\u003eldd $(which /usr/local/nginx/sbin/nginx)\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp\u003elinux-vdso.so.1 =\u0026gt; (0x00007fff48ff0000)\nlibcrypt.so.1 =\u0026gt; /lib64/libcrypt.so.1 (0x0000003065800000)\nlibpcre.so.1 =\u0026gt; not found\nlibssl.so.6 =\u0026gt; /lib64/libssl.so.6 (0x0000003067000000)\nlibcrypto.so.6 =\u0026gt; /lib64/libcrypto.so.6 (0x0000003066400000)\nlibdl.so.2 =\u0026gt; …\u003c/p\u003e\u003c/blockquote\u003e"
December 31, 2012
golang中的函数
"\u003cp\u003e函数是构建Go程序的基础部件;所遇有趣的事情都是在它其中发生的。函数\n的定义看起来像这样:\nListing 3.1. 函数定义\u003c/p\u003e\n\u003cp\u003etype mytype int 新的类型,参阅第 5 章\n\u003ca href=\"http://blog.haohtml.com/wp-content/uploads/2012/12/golang-func.png\"\u003e\u003cimg src=\"http://blog.haohtml.com/wp-content/uploads/2012/12/golang-func.png\" alt=\"golang-func\"\u003e\u003c/a\u003e\n0 保留字func用于定义一个函数;\u003c/p\u003e\n\u003cp\u003e1 函数可以定义用于特定的类型,这类函数更加通俗的称呼是method。这\n部分称作receiver而它是可选的(可参考: \u003ca href=\"http://blog.haohtml.com/archives/13766\"\u003ehttp://blog.haohtml.com/archives/13766\u003c/a\u003e)。如下图:\u003c/p\u003e\n\u003cp\u003e\u003ca href=\"http://blog.haohtml.com/wp-content/uploads/2012/12/golang-struct-func.png\"\u003e\u003cimg src=\"http://blog.haohtml.com/wp-content/uploads/2012/12/golang-struct-func.png\" alt=\"golang-struct-func\"\u003e\u003c/a\u003e\u003c/p\u003e\n\u003cp\u003e2 funcname是你函数的名字;\n3 int类型的变量q作为输入参数。参数用pass-by-value方式传递,意味着它\n们会被复制;\n4 变量r和s是这个函数的命名返回值。在Go的函数中可以返回多个值。\n参阅第32页的“多值返回”。如果不想对返回的参数命名,只需要提供类\n型:(int,int)。如果只有一个返回值,可以省略圆括号。如果函数是一\n个子过程,并且没有任何返回值,也可以省略这些内容;\n5 这是函数体,注意return是一个语句,所以包裹参数的括号是可选的。\u003c/p\u003e\n\u003cp\u003e这里有两个例子,左边的函数没有返回值,右边的只是简单的将输入返回。 …\u003c/p\u003e"
December 27, 2012
[golang]将函数作为值
"\u003cp\u003e就像其它在Go中的几乎所有的东西,函数也同样是值而已.它们可以像下面这样赋值给变量:\u003c/p\u003e\n\u003cdiv class=\"highlight\"\u003e\u003cpre tabindex=\"0\" style=\"color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;\"\u003e\u003ccode class=\"language-go\" data-lang=\"go\"\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#f92672\"\u003epackage\u003c/span\u003e \u003cspan style=\"color:#a6e22e\"\u003emain\u003c/span\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#f92672\"\u003eimport\u003c/span\u003e \u003cspan style=\"color:#e6db74\"\u003e\u0026#34;fmt\u0026#34;\u003c/span\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\u003cspan style=\"color:#66d9ef\"\u003efunc\u003c/span\u003e \u003cspan style=\"color:#a6e22e\"\u003emain\u003c/span\u003e() {\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e \u003cspan style=\"color:#a6e22e\"\u003ef\u003c/span\u003e \u003cspan style=\"color:#f92672\"\u003e:=\u003c/span\u003e \u003cspan style=\"color:#66d9ef\"\u003efunc\u003c/span\u003e() {\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\t \u003cspan style=\"color:#a6e22e\"\u003efmt\u003c/span\u003e.\u003cspan style=\"color:#a6e22e\"\u003ePrintln\u003c/span\u003e(\u003cspan style=\"color:#e6db74\"\u003e\u0026#34;func\u0026#34;\u003c/span\u003e)\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e }\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e \u003cspan style=\"color:#75715e\"\u003e// 下面才开始调用函数\u003c/span\u003e\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e \u003cspan style=\"color:#a6e22e\"\u003ef\u003c/span\u003e()\n\u003c/span\u003e\u003c/span\u003e\u003cspan style=\"display:flex;\"\u003e\u003cspan\u003e}\n\u003c/span\u003e\u003c/span\u003e\u003c/code\u003e\u003c/pre\u003e\u003c/div\u003e\u003cp\u003e结果会打印出 func 字符串。\u003c/p\u003e\n\u003cp\u003e另一种用法是立即调用函数,但是要求匿名函数要有返回值才可以,不然会提示错误信息.\u003c/p\u003e\n\u003cp\u003e\u003ca href=\"http://blog.haohtml.com/wp-content/uploads/2012/12/golang_func.jpg\"\u003e\u003cimg src=\"https://blogstatic.haohtml.com//uploads/2023/09/golang_func.jpg\" alt=\"golang_func\"\u003e\u003c/a\u003e\u003c/p\u003e"
December 16, 2012
mysql中alter语句中change和modify的区别
"\u003cp\u003e以下摘自mysql5手册\u003c/p\u003e\n\u003cp\u003e您可以使用CHANGE _old_col_name__column_definition_子句对列进行重命名。重命名时,需给定旧的和新的列名称和列当前的类型。例如:要把一个INTEGER列的名称从a变更到b,您需要如下操作:\u003c/p\u003e\n\u003cp\u003e· mysql\u0026gt; \u003cstrong\u003eALTER TABLE t1 CHANGE a b INTEGER;\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e如果您想要更改列的类型而不是名称, CHANGE语法仍然要求旧的和新的列名称,即使旧的和新的列名称是一样的。例如:\u003c/p\u003e\n\u003cp\u003emysql\u0026gt; \u003cstrong\u003eALTER TABLE t1 CHANGE b b BIGINT NOT NULL;\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e您也可以使用MODIFY来改变列的类型,此时不需要重命名:\u003c/p\u003e\n\u003cp\u003emysql\u0026gt; \u003cstrong\u003eALTER TABLE t1 MODIFY b BIGINT NOT NULL;\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003emysql alter 语句用法,添加、修改、删除字段等\u003c/p\u003e\n\u003cp\u003e//主键549830479\u003c/p\u003e\n\u003cp\u003ealter table tabelname add new_field_id int(5) unsigned default 0 not null …\u003c/p\u003e"
December 15, 2012
windows 下搭建 GoLang 语言开发环境
"\u003cp\u003egolang官方二进制分发包包括FreeBSD, Linux, Mac OS X (Snow Leopard/Lion), and Windows等平台,包括32位、64位等版本。\u003c/p\u003e\n\u003cp\u003e我自己使用的是windows 32位分发包,MSI格式的,下载地址为: \u003ca href=\"http://code.google.com/p/go/downloads/list\"\u003ehttp://code.google.com/p/go/downloads/list\u003c/a\u003e\u003c/p\u003e\n\u003cp\u003egolang支持交叉编译,也就是说你在32位平台的机器上开发,可以编译生成64位平台上的可执行程序。\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e环境变量说明:\u003c/strong\u003e\n$GOROOT 指向golang安装之后的根目录,windows平台下默认为c:\\go,会在安装过程中由安装程序自动写入系统环境变量。\n$GOARCH 目标平台(编译后的目标平台)的处理器架构(386、amd64、arm)\n$GOOS 目标平台(编译后的目标平台)的操作系统(darwin、freebsd、linux、windows)\n$GOBIN 指向安装之后根目录下的bin目录,即$GOROOT/bin,windows平台下默认为c:\\go\\bin,会在安装过程中由安装程序自动添加到PATH变量中\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e配 …\u003c/strong\u003e\u003c/p\u003e"
December 11, 2012
破解youku等视频网站广告的插件OpenGG.Clean.Player
"\u003cp\u003e官方网址: \u003ca href=\"http://opengg.me/781/opengg-clean-player/\"\u003ehttp://opengg.me/781/opengg-clean-player/\u003c/a\u003e\u003c/p\u003e\n\u003cp\u003e安装地址: \u003ca href=\"http://userscripts.org/scripts/show/120679\"\u003ehttp://userscripts.org/scripts/show/120679\u003c/a\u003e\u003c/p\u003e"
December 8, 2012
PHP类中static 和self的使用区别
"\u003cp\u003e摘自: \u003ca href=\"http://php.net/manual/en/language.oop5.late-static-bindings.php\"\u003ehttp://php.net/manual/en/language.oop5.late-static-bindings.php\u003c/a\u003e\u003c/p\u003e\n\u003ch3 id=\"limitations-ofself\"\u003eLimitations of \u003cem\u003eself::\u003c/em\u003e\u003c/h3\u003e\n\u003cp\u003eStatic references to the current class like \u003cem\u003eself::\u003c/em\u003e or \u003cem\u003e\u003cstrong\u003eCLASS\u003c/strong\u003e\u003c/em\u003e are resolved using the class in which the function belongs, as in where it was defined:\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003eExample #1 \u003cem\u003eself::\u003c/em\u003e usage\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e\u003ccode\u003e\u0026lt;code\u0026gt;\u0026lt;?php\u0026lt;br /\u0026gt; class A {\u0026lt;br /\u0026gt; public static function who() {\u0026lt;br /\u0026gt; echo __CLASS__;\u0026lt;br /\u0026gt; }\u0026lt;br /\u0026gt; public static function test() {\u0026lt;br /\u0026gt; self::who();\u0026lt;br /\u0026gt; }\u0026lt;br /\u0026gt; }\u003c/code\u003e class B …\u003c/p\u003e"
November 24, 2012
mysql中的主从复制slave-skip-errors参数使用方法
"\u003cp\u003e在主从复制中,难免会遇到一些sql语句错误的问题。这个时候我们需要手动来重新设置中继日志的起始点了,有些麻烦。今天在看“2012华东架构师大会”视频的时候,发现淘宝丁奇的ppt里有这个参数,看名字就知道是让从库跳过一些错误了。以前没有注意过这个参数,这里了解一下这个参数的用法。\u003c/p\u003e\n\u003cp\u003e—————————————-\u003c/p\u003e\n\u003cp\u003e环境说明:\u003c/p\u003e\n\u003cp\u003emysql\u0026gt;show slave stsatus\\G;\u003c/p\u003e\n\u003cp\u003e报错信息如下:\u003c/p\u003e\n\u003cp\u003e……\u003c/p\u003e\n\u003cp\u003eLast_Errno: 1062\u003c/p\u003e\n\u003cp\u003eLast_Error: Error ‘Duplicate entry ‘1’ for key ‘PRIMARY” on query…….\u003c/p\u003e\n\u003cp\u003e……\u003c/p\u003e\n\u003cp\u003e1062的错误是指一些主键重复的错误,在my.cnf用slave-skip-erros 可以跳过去。这样就避免了由于sql出错导致的从复制失效。\u003c/p\u003e\n\u003cp\u003e—————————————-\u003c/p\u003e\n\u003cp\u003eError_code: 1032; handler error HA_ERR_KEY_NOT_FOUND;\u003c/p\u003e\n\u003cp\u003e造成1032错误的根本原因是主从数据库数据不一致,导致同步操作在从库上无法执行.解决办法同上\u003c/p\u003e\n\u003cpre tabindex=\"0\"\u003e\u003ccode\u003e在slave的my.cnf …\u003c/code\u003e\u003c/pre\u003e"
November 22, 2012
ftp中“二进制传输模式”和“ASCII传输模式”有什么区别?
"\u003cp\u003e《Red Hat Linux 指南:服务器设置与程序设计篇》第2章FTP:跨越网络传送文件,这一章为您介绍实现FTP协议的服务器和客户端有很多种、以及开FTP服务器可以让用户以匿名用户身份anonymous或者ftp登录,最后为您介绍FTP提供了两种传输文件的模式:二进制模式和ASCII模式。本小节讲述的是二进制传输模式和ASCII传输模式。\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e2.3.6 二进制传输模式和ASCII传输模式\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003eFTP服务器vsftpd能够(但并不总是)提供两种文件传输模式。二进制模式传输总是复制文件的精确的、字节对字节的文件映像,而绝不会改变行结束符。所有二进制文件都用二进制模式传送。除非需要转换行结束符,否则也要使用二进制模式来传输ASCII文件。\u003c/p\u003e\n\u003cp\u003eASCII文件(比如文本文件或程序源代码,在Linux下使用vi之类的文本编辑器创建这些文件)使用单个换行符(NEWLINE,CONTROL-J,记作”\\n”)来标记每行的末尾;其他操作系统则用不同的方式来标记行尾。Windows用RETURN(CONTROL-M,记作”\\r”)后面跟随NEWLINE(总共两个字符)来标记每行的末尾。Mac系统只使 …\u003c/p\u003e"
November 21, 2012
理解MySQL数据库覆盖索引
"\u003cp\u003e话说有这么一个表:\u003c/p\u003e\n\u003cp\u003eCREATE TABLE \u003ccode\u003euser_group\u003c/code\u003e (\u003c/p\u003e\n\u003cp\u003e\u003ccode\u003eid\u003c/code\u003e int(11) NOT NULL auto_increment,\u003c/p\u003e\n\u003cp\u003e\u003ccode\u003euid\u003c/code\u003e int(11) NOT NULL,\u003c/p\u003e\n\u003cp\u003e\u003ccode\u003egroup_id\u003c/code\u003e int(11) NOT NULL,\u003c/p\u003e\n\u003cp\u003ePRIMARY KEY (\u003ccode\u003eid\u003c/code\u003e),\u003c/p\u003e\n\u003cp\u003eKEY \u003ccode\u003euid\u003c/code\u003e (\u003ccode\u003euid\u003c/code\u003e),\u003c/p\u003e\n\u003cp\u003eKEY \u003ccode\u003egroup_id\u003c/code\u003e (\u003ccode\u003egroup_id\u003c/code\u003e),\u003c/p\u003e\n\u003cp\u003e) ENGINE=InnoDB AUTO_INCREMENT=750366 DEFAULT CHARSET=utf8\u003c/p\u003e\n\u003cp\u003e看AUTO_INCREMENT就知道数据并不多,75万条。然后是一条简单的查询:\u003c/p\u003e\n\u003cp\u003e SELECT SQL_NO_CACHE uid FROM user_group WHERE group_id = 245;\u003c/p\u003e\n\u003cp\u003e很简单对不对?怪异的地方在于:\u003c/p\u003e\n\u003cp\u003e如果换成MyISAM做存储引擎的时候,查询耗时只需要0.01s,用InnoDB却会是0.15s左右。\u003c/p\u003e\n\u003cp\u003e如果只是就这么点差距其实不是什么大不了的事,但是真实的业务需求比这个复杂,造成的差距也很大:MyISAM只需要0.12s,InnoDB则需要2.2s.,最终定位到问题症结是在这 …\u003c/p\u003e"
November 19, 2012
Ajax getjson 跨域通信 php+jquery
"\u003cp\u003e\u003cstrong\u003e网站A的表单提交部分:\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e\u003cstrong\u003e网站B的输出json部分:\u003c/strong\u003e\u003c/p\u003e\n\u003cp\u003e$_GET[‘jsoncallback’] . ‘(‘ . json_encode($return) . ‘)‘);\u003c/p\u003e\n\u003cp\u003e?\u0026gt;\u003c/p\u003e"