先上uniqueservice代码
Lua
function skynet.uniqueservice(global, ...)
if global == true then
return assert(skynet.call(".service", "lua", "GLAUNCH", ...))
else
return assert(skynet.call(".service", "lua", "LAUNCH", global, ...)) -- 调用.call的时候,会把"LAUNCH"以及后面的数据打包发到底层C语言中去处理,C里面通过LAUNCH映射到cmd_launch
end
end
在 Skynet 中,.service
是一个特殊的服务名称,用于管理服务的启动和销毁。这个服务不需要你在业务代码中显式地编写,而是由 Skynet 框架内部自动管理的。
当你调用 skynet.uniqueservice(global, ...)
函数时,会向 .service
服务发送相应的消息,以请求创建一个新的服务实例。具体来说:
- 如果
global
参数为true
,表示创建一个全局唯一的服务实例,那么会向.service
发送GLAUNCH
消息,由.service
服务负责创建并返回一个全局唯一的服务实例。 - 如果
global
参数不为true
,表示创建一个普通的服务实例,那么会向.service
发送LAUNCH
消息,由.service
服务负责创建并返回一个普通的服务实例。
.service
服务是 Skynet 框架内部的一个重要组成部分,负责管理服务的生命周期、调度和通信等功能。你不需要显式地与 .service
服务进行交互,而是通过 Skynet 提供的 API 接口来进行服务的创建、销毁和通信等操作。
newservice代码:
Lua
function skynet.newservice(name, ...)
return skynet.call(".launcher", "lua" , "LAUNCH", "snlua", name, ...)
end
在 Skynet 中,.
launcher****服务是负责启动新服务实例的组件之一 。当你调用 skynet.newservice(name, ...)
函数时,实际上是向 .launcher
服务发送了一个 LAUNCH
消息,请求启动一个新的服务实例。
具体来说,.launcher
服务接收到 LAUNCH
消息后,会根据指定的服务类型(这里是 "snlua")和服务名称(name
)来启动一个新的服务实例。在启动新服务实例时,.launcher
服务会与 .service
服务配合工作,确保新服务实例的正常启动。
总的来说,.launcher
服务是 Skynet 框架中的一个重要组件,负责启动新的服务实例,并与 .service
服务配合协同工作,确保服务的正常启动和管理 。在业务代码中,你通常不需要直接与 .launcher
服务进行交互,而是通过 Skynet 提供的 API 接口来启动新的服务实例。
这两个接口都是用来启动一个服务,uniqueservice中是用来启动一个唯一的服务(是否是全局取决于global参数),即使是多次调用并传入相同的参数,也只会有一个唯一的服务实例;而newservice启动一个服务,多次调用会创建多个服务实例。
===================================================================
.launcher服务和.service服务,分别的职责是什么?
-
启动新服务实例:
- 当你调用
skynet.newservice(name, ...)
函数时,实际上是向.launcher
服务发送了一个LAUNCH
消息,请求启动一个新的服务实例。 .launcher
服务接收到LAUNCH
消息后,会根据指定的服务类型(例如 "snlua")和服务名称来启动一个新的服务实例。这可能涉及到加载对应的服务代码、初始化服务环境等操作。- 在启动新服务实例时,
.launcher
服务会与.service
服务进行协同工作,以确保服务的正常启动。
- 当你调用
-
管理服务生命周期:
- 在服务启动后,
.service
服务会记录新服务实例的信息,并管理其生命周期。这包括维护服务实例的状态、处理服务实例的消息等。 - 如果一个服务实例发生异常退出或需要销毁,
.service
服务会负责清理和释放相关资源,确保系统的稳定运行。
- 在服务启动后,
-
处理服务通信:
- 一旦服务实例启动成功,它就可以与其他服务实例进行通信。Skynet 框架提供了消息传递机制,服务实例可以通过消息来进行通信和协作。
- 当你调用
skynet.send
或skynet.call
函数向其他服务发送消息时,消息会通过 Skynet 框架的消息传递机制,被传递给目标服务实例进行处理。
总的来说,.launcher
和 .service
两个服务配合协同工作,以确保新服务实例的正常启动、管理和通信。**.launcher
负责启动新服务实例,而 .service
则负责管理服务的生命周期和处理服务间的通信。**这样的设计使得 Skynet 框架能够更好地管理和运行分布式系统中的多个服务实例。