skynet中newservice和uniqueservice的区别

先上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服务,分别的职责是什么?

  1. 启动新服务实例

    • 当你调用 skynet.newservice(name, ...) 函数时,实际上是向 .launcher 服务发送了一个 LAUNCH 消息,请求启动一个新的服务实例。
    • .launcher 服务接收到 LAUNCH 消息后,会根据指定的服务类型(例如 "snlua")和服务名称来启动一个新的服务实例。这可能涉及到加载对应的服务代码、初始化服务环境等操作。
    • 在启动新服务实例时,.launcher 服务会与 .service 服务进行协同工作,以确保服务的正常启动。
  2. 管理服务生命周期

    • 在服务启动后,.service 服务会记录新服务实例的信息,并管理其生命周期。这包括维护服务实例的状态、处理服务实例的消息等。
    • 如果一个服务实例发生异常退出或需要销毁,.service 服务会负责清理和释放相关资源,确保系统的稳定运行。
  3. 处理服务通信

    • 一旦服务实例启动成功,它就可以与其他服务实例进行通信。Skynet 框架提供了消息传递机制,服务实例可以通过消息来进行通信和协作。
    • 当你调用 skynet.sendskynet.call 函数向其他服务发送消息时,消息会通过 Skynet 框架的消息传递机制,被传递给目标服务实例进行处理。

总的来说,.launcher.service 两个服务配合协同工作,以确保新服务实例的正常启动、管理和通信。**.launcher 负责启动新服务实例,而 .service 则负责管理服务的生命周期和处理服务间的通信。**这样的设计使得 Skynet 框架能够更好地管理和运行分布式系统中的多个服务实例。

相关推荐
一眼万里*e3 个月前
skynet 实操篇
c++·skynet
一眼万里*e3 个月前
skynet 入门篇
服务器·c++·skynet
tissar6 个月前
【skynet】 网络编程之回显服务器
服务器·lua·skynet
笨死de猪7 个月前
skynet 使用protobuf
skynet·protobuf
ღCauchyོꦿ࿐10 个月前
【Skynet 入门实战练习】事件模块 | 批处理模块 | GM 指令 | 模糊搜索
mongodb·lua·skynet·游戏服务器·gm 指令
ღCauchyོꦿ࿐1 年前
【Skynet 入门实战练习】分布式 ID | 雪花算法 | 缓存设计 | LRU算法 | 数据库
数据库·分布式·算法·缓存·skynet·lru
ღCauchyོꦿ࿐1 年前
【Skynet 入门实战练习】实现网关服务 | 用户代理 | RPC 协议 | 客户端
网络协议·gateway·客户端·skynet·服务端
ღCauchyོꦿ࿐1 年前
【Skynet 入门实战练习】游戏模块划分 | 基础功能模块 | timer 定时器模块 | logger 日志服务模块
服务器·lua·定时器·日志·skynet
ღCauchyོꦿ࿐1 年前
【Skynet 入门实战练习】开发环境搭建 | 运行第一个项目 | debug console 简单使用
lua·游戏开发·skynet·服务器开发