skynet中newservice和uniqueservice的区别

先上uniqueservice代码


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代码:

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 框架能够更好地管理和运行分布式系统中的多个服务实例。

相关推荐

  1. skynetnewserviceuniqueservice区别

    2024-04-13 22:08:02       34 阅读
  2. Mybatis${}#{}区别

    2024-04-13 22:08:02       40 阅读
  3. skynet 配置lua服务创建流程

    2024-04-13 22:08:02       46 阅读
  4. Shell ${} $() 区别

    2024-04-13 22:08:02       47 阅读
  5. Golangjsonjsoniter区别

    2024-04-13 22:08:02       59 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-13 22:08:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-13 22:08:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-13 22:08:02       82 阅读
  4. Python语言-面向对象

    2024-04-13 22:08:02       91 阅读

热门阅读

  1. ChatGPT革新学术写作:论文撰写的新思路

    2024-04-13 22:08:02       41 阅读
  2. shell脚本启动jar包

    2024-04-13 22:08:02       34 阅读
  3. C语言隐藏执行其他程序

    2024-04-13 22:08:02       34 阅读
  4. openjudge_2.5基本算法之搜索_1756:八皇后

    2024-04-13 22:08:02       38 阅读
  5. 预训练的启蒙:浅谈BERT、RoBERTa、ALBERT、T5

    2024-04-13 22:08:02       37 阅读
  6. P1085 [NOIP2004 普及组] 不高兴的津津

    2024-04-13 22:08:02       32 阅读
  7. 前端面试复习大纲

    2024-04-13 22:08:02       40 阅读
  8. 单片机家电产品--OC门电路

    2024-04-13 22:08:02       40 阅读
  9. 岛屿个数(dfs)

    2024-04-13 22:08:02       34 阅读
  10. 用户层read write io命令到NVMe SSD全流程

    2024-04-13 22:08:02       42 阅读
  11. 华为OD-C卷-考勤信息[100分]

    2024-04-13 22:08:02       36 阅读
  12. 面试经典150题 删除有序数组中的重复项 II

    2024-04-13 22:08:02       34 阅读