2018-05-10 16:07:14 +08:00
|
|
|
|
// Copyright 2018 gf Author(https://gitee.com/johng/gf). All Rights Reserved.
|
|
|
|
|
//
|
|
|
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
|
|
|
// If a copy of the MIT was not distributed with this file,
|
|
|
|
|
// You can obtain one at https://gitee.com/johng/gf.
|
2018-05-20 13:49:02 +08:00
|
|
|
|
// "不要通过共享内存来通信,而应该通过通信来共享内存"
|
2018-05-19 01:04:20 +08:00
|
|
|
|
|
2018-05-10 16:07:14 +08:00
|
|
|
|
|
|
|
|
|
package gproc
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"os"
|
|
|
|
|
"gitee.com/johng/gf/g/os/gfile"
|
|
|
|
|
"gitee.com/johng/gf/g/util/gconv"
|
2018-05-20 13:49:02 +08:00
|
|
|
|
"gitee.com/johng/gf/g/container/gmap"
|
2018-05-10 16:07:14 +08:00
|
|
|
|
)
|
|
|
|
|
|
2018-07-04 19:32:51 +08:00
|
|
|
|
// 本地进程通信接收消息队列(按照分组进行构建的map,键值为*gqueue.Queue对象)
|
|
|
|
|
var commReceiveQueues = gmap.NewStringInterfaceMap()
|
|
|
|
|
|
|
|
|
|
// (用于发送)已建立的PID对应的Conn通信对象,键值为一个Pool,防止并行使用同一个通信对象造成数据重叠
|
|
|
|
|
var commPidConnMap = gmap.NewIntInterfaceMap()
|
2018-05-10 16:07:14 +08:00
|
|
|
|
|
|
|
|
|
// TCP通信数据结构定义
|
|
|
|
|
type Msg struct {
|
2018-07-04 19:32:51 +08:00
|
|
|
|
Pid int // PID,来源哪个进程
|
|
|
|
|
Data []byte // 数据
|
|
|
|
|
Group string // 分组名称
|
2018-05-10 16:07:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 获取指定进程的通信文件地址
|
|
|
|
|
func getCommFilePath(pid int) string {
|
2018-05-15 18:34:00 +08:00
|
|
|
|
return getCommDirPath() + gfile.Separator + gconv.String(pid)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 获取进程间通信目录地址
|
|
|
|
|
func getCommDirPath() string {
|
2018-07-02 14:21:02 +08:00
|
|
|
|
tempDir := os.Getenv(gPROC_TEMP_DIR_ENV_KEY)
|
2018-05-10 17:48:47 +08:00
|
|
|
|
if tempDir == "" {
|
|
|
|
|
tempDir = gfile.TempDir()
|
|
|
|
|
}
|
2018-05-15 18:34:00 +08:00
|
|
|
|
return tempDir + gfile.Separator + "gproc"
|
2018-05-10 16:07:14 +08:00
|
|
|
|
}
|