skynet中newservice和uniqueservice的区别

先上uniqueservice代码


function skynet.uniqueservice(global, ...)if global == true thenreturn assert(skynet.call(".service", "lua", "GLAUNCH", ...))elsereturn assert(skynet.call(".service", "lua", "LAUNCH", global, ...))  -- 调用.call的时候,会把“LAUNCH”以及后面的数据打包发到底层C语言中去处理,C里面通过LAUNCH映射到cmd_launchend
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 框架能够更好地管理和运行分布式系统中的多个服务实例。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/813391.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Beamer使用

Step00 准备工作 申请Overleaf的账号,登录,新建一个空白项目。 点击左上角Menu,在菜单中找到complier,选中XeLatex。 Step01 一个Beamer框架 在main.tax中,添加下面的内容: % 导入必要的LaTeX包 \documentclass{beamer} % 使…

CentOS 7开机启动过程,引导和服务,密码的修改

开机启动过程: 引导过程:1.开机自检(BIOS)->2.MBR引导->GRUB菜单->加载内核kernel->systemd进程初始化 程序:执行特定任务的一串代码,静态,存在硬盘中。 进程:运行中的程序叫进程&#xff0…

Django之rest_framework(一)

一、请求和响应对象介绍 REST framework引入了2个新的对象:Request和Response 1.1、Request rest_framework.request.Request 该对象扩展了常规的HttpRequest ,增加了对REST框架灵活的请求解析和请求认证的支持 官网:Requests - Django REST framework 主要属性: data 这…

Oracle 数据库全表扫描的4种优化方法(DB)

全表扫描的工作是扫描高水位一下所有的数据块。 这里就有一个问题,什么是高水位线。高水位的标志存在表头。 该数据块以后都是崭新未格式化的数据块,高水位的目的有二。它是全表扫描的 终点,并行插入的起点! 优化全表扫描的办法有…

类和对象(拷贝构造函数)

目录 拷贝构造函数 特征 结论: 拷贝构造函数 拷贝构造函数:只有单个形参,该形参是对本类类型对象的引用(一般常用const修饰),在用已存 在的类类型对象创建新对象时由编译器自动调用。 特征 拷贝构造函数也是特殊的成员函数&…

AD7685BRMZRL7 16位 2.3V 低功耗模数转换器芯片 ADI

AD7685BRMZRL7是一款由ADI(亚德诺)公司生产的模数转换器(ADC)芯片。该芯片的主要功能是将模拟信号转换为数字信号,以便在数字系统中处理. AD7685BRMZRL7 规格信息: 制造商:Analog Devices Inc. 产品种类:模…

【SpringBoot】获取参数

获取参数 传递单个参数传递多个参数传递对象后端参数重命名传递数组传递 json 数据获取 URL 中参数上传文件获取 cookie 和 session获取cookie获取session 传递单个参数 RequestMapping("/user") RestController public class UserController {// 传递单个参数Reque…

实现自动打包py及替换pyinstaller --add-data参数的方法

2024年了,PyInstaller已经来到了6.5.0版本,可我还是不会用它那个--add-data的方法,度了几圈试了试,始终不(行)如(不)意(通),就是没能把附加文件&a…

ActiveMQ 03 整合SpringBoot

Active MQ 03 整合SpringBoot 配置文件 POM <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation&qu…

红色文化展馆3D线上互动展览推动党建创新发展

实现现代化是世界各国人民的共同追求。在追求现代化的艰苦卓绝奋斗中&#xff0c;我们党领导人民不仅创造了世所罕见的经济快速发展和社会长期稳定两大奇迹&#xff0c;而且成功走出了中国式现代化道路&#xff0c;创造了人类文明新形态。对党建学习也应该与时俱进&#xff0c;…

c语言多功能计算软件170

定制魏&#xff1a;QTWZPW&#xff0c;获取更多源码等 目录 题目 要求 主要代码片段 题目 设计一个计算器软件&#xff0c;具备如下功能提示界面。 要求 设计出界面&#xff0c;注意界面名称最后为自己的姓名&#xff1b;&#xff08;20分&#xff09;能够实现加、减、乘、…

Vector部分底层源码解析

JDK版本为1.8.0_271&#xff0c;Vector底层也是使用object数组&#xff0c;但使用synchronized 关键字来确保线程安全&#xff0c;但效率比ArrayList低&#xff0c;比较少见。这里以插入删除元素为例&#xff1a; //属性 protected Object[] elementData; protected int eleme…

Linux之bpfjit(2)使用分析和mini-tcpdump实现

Linux之bpfjit(2)使用分析和mini-tcpdump实现 Author: Once Day Date: 2024年4月13日 一位热衷于Linux学习和开发的菜鸟&#xff0c;试图谱写一场冒险之旅&#xff0c;也许终点只是一场白日梦… 漫漫长路&#xff0c;有人对你微笑过嘛… 全系列文章可以参考专栏&#xff1a;…

idea 使用springboot helper 创建springboot项目

Spring Boot Helper 是一个在 IntelliJ IDEA 中用于快速创建 Spring Boot 项目的插件。通过这个插件&#xff0c;开发者可以简化 Spring Boot 项目的创建过程&#xff0c;并快速生成所需的依赖和配置文件。以下是使用 Spring Boot Helper 插件创建 Spring Boot 项目的详细步骤&…

Docker搭建Dillinger

Dillinger是一款功能强大的在线Markdown编辑器&#xff0c;它支持实时预览、导出至各种格式、多种主题等功能。通过Docker&#xff0c;我们可以轻松地部署和运行Dillinger&#xff0c;从而实现在线Markdown编辑与预览。本教程将分别介绍使用Docker CLI和Docker Compose两种不同…

QT windeployqt打包出现无法正常启动问题

QT 通过windeployqt 打包后出现的问题 原因QT构建选择的是64位的 但是windows下运行的却是32位的 步骤打开32的所在路径 一般在上一级目录会有安装好的64位的MSVC工具 运行打包即可

《乱弹篇(27)回乡祭扫感慨多》

人老了&#xff0c;真的就要记住“好汉不提当年勇&#xff0c;梅花不提前世绣”这话。 忆往昔&#xff0c;中青年时代的笔者精力旺盛&#xff0c;也曾只身一人闯荡江湖&#xff0c;把自己的足迹印到过大半个中国土地上&#xff0c;可如今岁近耄耋残年&#xff0c;清明节想回一…

Python | Leetcode Python题解之第19题删除链表的倒数第N个结点

题目&#xff1a; 题解&#xff1a; class Solution:def removeNthFromEnd(self, head: ListNode, n: int) -> ListNode:dummy ListNode(0, head)first headsecond dummyfor i in range(n):first first.nextwhile first:first first.nextsecond second.nextsecond.ne…

gemini1.5 API调用

https://ai.google.dev/pricing?hlzh-cn 查询可用的model https://generativelanguage.googleapis.com/v1beta/models?keyxxx 使用postman调用 https://generativelanguage.googleapis.com/v1beta/models/gemini-1.5-pro-latest:generateContent?keyxxx https://ai.google…

聊一下HashMap的底层原理

HashMap作为我们熟悉的一种集合&#xff0c;今天就来聊一下它的原理、数据结构。 1.HashMap的数据结构 JDK1.7的数据结构是数组链表&#xff0c;JDK1.7还有人在用&#xff1f;不会吧…… 说一下JDK1.8的数据结构吧&#xff1a; JDK1.8的数据结构是数组链表红黑树。 数据结…