nodejs mqtt 定时随机发送糗百帖子

var request = require('request');
var mqtt = require('mqtt');

client = mqtt.createClient(1883, 'localhost', {
    clientId: "Test",
    keepalive: 0,
    clean: false
});

function publishRandomThread() {
	request('http://www.qiushibaike.com/history', function (error, response, body) {
	if (!error && response.statusCode == 200) {
  		var matches = body.match(/<div class="mb-m fs-l">[\s\n]*?(.*?)[\s\n]*?<\/div>/g);
	  		client.publish('$SYS/Musikar', matches[0].replace(/<.*?>/g, ''));
	  	}
	})
}

setInterval(function(){
	publishRandomThread();
}, 60000);

 

发表在 android | 留下评论

android 判断服务有没有启动

public boolean isServiceRunning(Context context) {
	boolean isRunning = false;

	ActivityManager activityManager = (ActivityManager) context
			.getSystemService(Context.ACTIVITY_SERVICE);
	List<ActivityManager.RunningServiceInfo> serviceList = activityManager
			.getRunningServices(Integer.MAX_VALUE);

	if (serviceList.size() < 1) {
		return false;
	}

	for (int i = 0; i < serviceList.size(); i++) {
		if (serviceList.get(i).service.getClassName().equals(
				BootService.class.getName())) {
			isRunning = true;
			break;
		}
	}
	return isRunning;
}

 

发表在 Linux | 留下评论

swoole异步读文件

<?php
	
	swoole_async_readfile(__DIR__ . '/demo.php', function($filename, $content){
		echo $content.PHP_EOL;
		swoole_event_exit();
	});
?>

 

发表在 swoole | 标签为 | 留下评论

strace工具的使用

strace可以跟踪系统调用的执行情况,在程序发生问题后,可以用strace分析和跟踪问题。 使用方法:

FreeBSD/MacOS下可以使用truss

strace -o /tmp/strace.log -f -p $PID
  • -f 表示跟踪多线程和多进程,如果不加-f参数,无法抓取到子进程和子线程的运行情况
  • -o 表示将结果输出到一个文件中
  • -p $PID,指定跟踪的进程ID,通过ps aux可以看到
  • -tt 打印系统调用发生的时间,精确到微妙
发表在 Linux | 留下评论

tcpdump抓包工具的使用

在调试网络通信程序是tcpdump是必备工具。tcpdump很强大,可以看到网络通信的每个细节。如TCP,可以看到3次握手,PUSH/ACT数据推送,close4次挥手,全部细节。包括每一次网络收包的字节数,时间等。

最简单的一个使用示例:

sudo tcpdump -i any tcp port 9501
  • -i 参数制定了网卡,any表示所有网卡
  • tcp 指定仅监听TCP协议
  • port 制定监听的端口

tcpdump需要root权限
需要要看通信的数据内容,可以加 -Xnlps0 参数,其他更多参数请参见网上的文章

运行结果

13:29:07.788802 IP localhost.42333 > localhost.9501: Flags [S], seq 828582357, win 43690, options [mss 65495,sackOK,TS val 2207513 ecr 0,nop,wscale 7], length 0
13:29:07.788815 IP localhost.9501 > localhost.42333: Flags [S.], seq 1242884615, ack 828582358, win 43690, options [mss 65495,sackOK,TS val 2207513 ecr 2207513,nop,wscale 7], length 0
13:29:07.788830 IP localhost.42333 > localhost.9501: Flags [.], ack 1, win 342, options [nop,nop,TS val 2207513 ecr 2207513], length 0
13:29:10.298686 IP localhost.42333 > localhost.9501: Flags [P.], seq 1:5, ack 1, win 342, options [nop,nop,TS val 2208141 ecr 2207513], length 4
13:29:10.298708 IP localhost.9501 > localhost.42333: Flags [.], ack 5, win 342, options [nop,nop,TS val 2208141 ecr 2208141], length 0
13:29:10.298795 IP localhost.9501 > localhost.42333: Flags [P.], seq 1:13, ack 5, win 342, options [nop,nop,TS val 2208141 ecr 2208141], length 12
13:29:10.298803 IP localhost.42333 > localhost.9501: Flags [.], ack 13, win 342, options [nop,nop,TS val 2208141 ecr 2208141], length 0
13:29:11.563361 IP localhost.42333 > localhost.9501: Flags [F.], seq 5, ack 13, win 342, options [nop,nop,TS val 2208457 ecr 2208141], length 0
13:29:11.563450 IP localhost.9501 > localhost.42333: Flags [F.], seq 13, ack 6, win 342, options [nop,nop,TS val 2208457 ecr 2208457], length 0
13:29:11.563473 IP localhost.42333 > localhost.9501: Flags [.], ack 14, win 342, options [nop,nop,TS val 2208457 ecr 2208457], length 0
  • 13:29:11.563473 时间带有精确到微妙
  • localhost.42333 > localhost.9501 表示通信的流向,42333是客户端,9501是服务器端
  • [S] 表示这是一个SYN请求
  • [.] 表示这是一个ACT确认包,(client)SYN->(server)SYN->(client)ACT 就是3次握手过程
  • [P] 表示这个是一个数据推送,可以是从服务器端向客户端推送,也可以从客户端向服务器端推
  • [F] 表示这是一个FIN包,是关闭连接操作,client/server都有可能发起
  • [R] 表示这是一个RST包,与F包作用相同,但RST表示连接关闭时,仍然有数据未被处理。可以理解为是强制切断连接
  • win 342是指滑动窗口大小
  • length 12指数据包的大小
发表在 Linux | 留下评论

TCP连接的状态

 

  • LISTEN:首先服务端需要打开一个socket进行监听,状态为LISTEN. /* The socket is listening for incoming connections. 侦听来自远方TCP端口的连接请求 */
  • SYN_SENT:客户端通过应用程序调用connect进行active open.于是客户端tcp发送一个SYN以请求建立一个连接.之后状态置为SYN_SENT. /*The socket is actively attempting to establish a connection. 在发送连接请求后等待匹配的连接请求 */
  • SYN_RECV:服务端应发出ACK确认客户端的SYN,同时自己向客户端发送一个SYN.之后状态置为SYN_RECV /* A connection request has been received from the network. 在收到和发送一个连接请求后等待对连接请求的确认 */
  • ESTABLISHED: 代表一个打开的连接,双方可以进行或已经在数据交互了。/* The socket has an established connection. 代表一个打开的连接,数据可以传送给用户 */
  • FIN_WAIT1:主动关闭(active close)端应用程序调用close,于是其TCP发出FIN请求主动关闭连接,之后进入FIN_WAIT1状态./* The socket is closed, and the connection is shutting down. 等待远程TCP的连接中断请求,或先前的连接中断请求的确认 */
  • CLOSE_WAIT:被动关闭(passive close)端TCP接到FIN后,就发出ACK以回应FIN请求(它的接收也作为文件结束符传递给上层应用程序),并进入CLOSE_WAIT. /* The remote end has shut down, waiting for the socket to close. 等待从本地用户发来的连接中断请求 */
  • FIN_WAIT2:主动关闭端接到ACK后,就进入了FIN-WAIT-2 ./* Connection is closed, and the socket is waiting for a shutdown from the remote end. 从远程TCP等待连接中断请求 */
  • LAST_ACK:被动关闭端一段时间后,接收到文件结束符的应用程序将调用CLOSE关闭连接。这导致它的TCP也发送一个 FIN,等待对方的ACK.就进入了LAST-ACK . /* The remote end has shut down, and the socket is closed. Waiting for acknowledgement. 等待原来发向远程TCP的连接中断请求的确认 */
  • TIME_WAIT:在主动关闭端接收到FIN后,TCP就发送ACK包,并进入TIME-WAIT状态。/* The socket is waiting after close to handle packets still in the network.等待足够的时间以确保远程TCP接收到连接中断请求的确认 */
  • CLOSING: 比较少见./* Both sockets are shut down but we still don’t have all our data sent. 等待远程TCP对连接中断的确认 */
  • CLOSED: 被动关闭端在接受到ACK包后,就进入了closed的状态。连接结束./* The socket is not being used. 没有任何连接状态 */

 

发表在 Linux | 留下评论

Linux信号列表

 

  • SIGHUP
  • SIGINT
  • SIGQUIT
  • SIGILL
  • SIGTRAP
  • SIGABRT
  • SIGBUS
  • SIGFPE
  • SIGKILL
  • SIGUSR1
  • SIGSEGV
  • SIGUSR2
  • SIGPIPE
  • SIGALRM
  • SIGTERM
  • SIGCHLD
  • SIGCONT
  • SIGSTOP
  • SIGTSTP
  • SIGTTIN
  • SIGTTOU
  • SIGURG
  • SIGXCPU
  • SIGXFSZ
  • SIGVTALRM
  • SIGPROF
  • SIGWINCH
  • SIGIO
  • SIGPWR
  • SIGSYS
  • SIGRTMIN
  • SIGRTMIN+1
  • SIGRTMIN+2
  • SIGRTMIN+3
  • SIGRTMIN+4
  • SIGRTMIN+5
  • SIGRTMIN+6
  • SIGRTMIN+7
  • SIGRTMIN+8
  • SIGRTMIN+9
  • SIGRTMIN+10
  • SIGRTMIN+11
  • SIGRTMIN+12
  • SIGRTMIN+13
  • SIGRTMIN+14
  • SIGRTMIN+15
  • SIGRTMAX-14
  • SIGRTMAX-13
  • SIGRTMAX-12
  • SIGRTMAX-11
  • SIGRTMAX-10
  • SIGRTMAX-9
  • SIGRTMAX-8
  • SIGRTMAX-7
  • SIGRTMAX-6
  • SIGRTMAX-5
  • SIGRTMAX-4
  • SIGRTMAX-3
  • SIGRTMAX-2
  • SIGRTMAX-1
  • SIGRTMAX

 

发表在 Linux | 留下评论

swoole 获取ip

<?php
var_dump(swoole_get_local_ip());

 

发表在 Linux | 留下评论

手机定位技术(大话基站LBS,GPS,AGPS,WIFI定位区别)

关于基站,GPS,AGPS,GPS-ONE区别,网上有是一堆文档,这里另一视角来说明:

(Android的CDMA手机,支持GPS,AGPS,使用百度地图)

A.XX新买了一台手机(还没来得急办卡),此时开机,打开百度地图,无法获取位置信息。

1.打开GPS,经过长时间的搜星,定位成功。此为GPS定位。

2.关闭GPS,打开Wifi,连接家里的无线路由,百度地图定位成功。此为WIFI定位。

3.若同时打开GPS与Wifi,则先进行Wifi定位,待GPS定好后,使用GPS定位。

B.XX终于办了卡,然后开机,打开百度地图(离线地图,未开2G/3G数据业务,未开GPS,未开Wifi),无法定位。

1.仅打开数据业务,定位成功,此为基站定位。

2.又打开GPS,精确定位成功,则为AGPS定位。(网络辅助GPS定位)

总结一下,定位是按最快原则选择的。若同时开启,使用顺序如下,最终还是得靠GPS来准确定位。

WIFI > LSB > AGPS > GPS

发表在 android | 留下评论

Avoid passing null as the view root (need to resolve layout parameters on the inflated layout’s root element)

Instead of doing

convertView = infalInflater.inflate(R.layout.list_item, null);

do

convertView = infalInflater.inflate(R.layout.list_item, parent, false);

It will inflate it with the given parent, but won’t attach it to the parent.

发表在 android | 留下评论