分类 默认分类 下的文章

僵尸进程是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。如果父进程先退出 ,子进程被init接管,子进程退出后init会回收其占用的相关资源
在UNIX 系统中,一个进程结束了,但是他的父进程没有等待(调用wait / waitpid)他, 那么他将变成一个僵尸进程。 但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程
僵尸进程的避免
⒈ 父进程通过wait和waitpid等函数等待子进程结束,这会导致父进程挂起。
⒉ 如果父进程很忙,那么可以用signal函数为SIGCHLD安装handler,因为子进程结束后, 父进程会收到该信号,可以在handler中调用wait回收。
⒊ 如果父进程不关心子进程什么时候结束,那么可以用signal(SIGCHLD,SIG_IGN) 通知内核,自己对子进程的结束不感兴趣,那么子进程结束后,内核会回收, 并不再给父进程发送信号。
根据百科的内容很容易联想到,即便使用golang的标准库,在kill进程后,父进程仍需调用wait方法回收资源。而实际上golang的os/exec包是提供了该方法的。只要确保在父进程杀死子进程后,可以调用到如下逻辑,即可在golang管理进程的过程中避免产生僵尸进程。

def reg1 = ~'.*?'
def reg2 = ~/.*?/

// 使用正则匹配字符串
matcher = 'hello world' =~ reg1
matcher是一个匹配集合,表达式被匹配多少次就有多少个成员,一般情况下只有一个。
matcher中的成员,第一个是被匹配的字符串,第二个成员是第一个捕获成员,以此类推。

1.在windows下 mirror 命令有一定概率同步不上,原因是路径没有正确区分 /\

2.在mac下 mirror --watch 无法侦测到从 Finder 中删除文件的操作,却可以侦测到命令行 rm 的操作,原因是 Finder 中的删除是把文件挪动到了垃圾桶,对应操作是 rename,mc 认为这个操作不算是删除操作。
QQ20200707-162917.png
5DBD7C50-1E32-4F33-AAB8-F02ADDE3CF94.png

3.minio所有事件都是针对文件对象的,删除一个文件夹是无法同步的。

4.mc mirror 中的 --exclude 参数在首次同步阶段与目录监视阶段是不一样的,监视阶段开头需要增加 / 比如:
mc mirror --exclude ".git/" --exclude "/.git/" // 第一个 exclude 是同步阶段,第二个是监视阶段,只有这样才能排除 .git 文件夹
注意 / 和 的区别

import groovy.json.*

def jsonSlurper = new JsonSlurper()
def object = jsonSlurper.parseText('{ "name": "大球机器人" } / 大球有只小毛驴,从来也不骑 /')
println(object.name)

使用 JsonSlurperClassic 替换 JsonSlurper 可解决 LazyMap 序列化的问题。

参考资料:
http://www.groovy-lang.org/json.html