listen = flag.String("listen", "/var/run/frakti.sock", "...")

hyperEndpoint = flag.String("hyper-endpoint", "127.0.0.1:8080", "...")

streamingServerPort = flag.String("streaming-server-port", "22521", "...")

streamingServerAddress = flag.String("streaming-server-addr", "0.0.0.0", "...")

// cmd/frakti/frakti.go

1、func main()

(0)、调用streamingConfig := getStreamingConfig()   --->用streaming.DefaultConfig的内容填充获得一个streaming.Config结构

(1)、调用hyperRuntime, streamingServer,  err := hyper.NewHyperRuntime(*hyperendpoint, streamingConfig),相当于生成一个hyper client

(2)、调用server, err := manager.NewFraktiManager(hyperRuntime, hyperRuntime, streamingServer)

(3)、最后调用fmt.Println(server.Server(*listen))

// Runtime is the HyperContainer implementation of kubelet runtime API

type Runtime struct {

  client  *Client
}

// pkg/hyper/hyper.go

// NewHyperRuntime creates a new Runtime

2、func NewHyperRuntime(hyperEndpoint string) (*Runtime, error)

(1)、调用hyperClient, err := NewClient(hyperEndpoint, hyperConnectionTimeout)

// Client is the gRPC client for hyperd

type Client struct {
  client   api.PublicAPIClient
  timeout  time.Duration
}

(2)、调用streamingRuntime := &streamingRuntime{client: hyperClient}

(3)、如果streamingConfig不为nil,调用streamingServer, err = streaming.NewServer(*streamingConfig, streamingRuntime)

(4)、最后return &Runtime{client: hyperClient, streamingServer: streamingServer}, streamingServer, nil

// pkg/hyper/client.go

// NewClient creates a new hyper client

3、func NewClient(server string, timeout time.Duration) (*Client, error)

调用conn, err := grpc.Dial(server, grpc.WithInsecure()),再返回&Client{client: api.NewPublicAPIClient(conn), timeout: timeout}

// FraktiManager serves the kubelet runtime gRPC api which will be consumed by kubelet

type FraktiManager struct {
  // The grpc server
  server  *grpc.Server
  // The streaming server
  streamingServer streaming.Server
  runtimeService  runtime.RuntimeService
  imageService   runtime.ImageService
}

// pkg/manager/manager.go

// NewFraktiManager creates a new FraktiManager

func NewFraktiManager(runtimeService runtime.RuntimeService, imageService runtime.ImageService) (*FraktiManager, error)

创建 s := &FraktiManager{server: grpc.NewServer(), runtimeService: runtimeService, imageService: imageService},再调用s.registerServer(),最后return s, nil

// pkg/manager/manager.go

func (s *FraktiManager) registerServer()

调用kubeapi.RegisterRuntimeServiceServer(s.server, s)和kubeapi.RegisterImageServiceServer(s.server, s)

//  pkg/manager/manager.go

// Server starts gRPC server at unix://addr

func (s *FraktiManager) Serve(addr string) error

(1)、调用syscall.Unlink(addr)

(2)、如果s.streamingServer不为nil,调用s.streamingServer.Start(true)

(3)、调用lis, err := net.Listen("unix", addr),最后return s.server.Serve(lis)

---------------------------------------------------  RunPodSandbox 源码分析 -----------------------------------------

// RunPodSandbox creates and starts a pod-level sandbox.

func (h *Runtime) RunPodSandbox(config *kubeapi.PodSandboxConfig) (string, error)

(1)、调用userpod, err := buildUserPod(config)

(2)、调用podID, err := h.client.CreatePod(userpod)

(3)、调用err = h.client.StartPod(podID)

(4)、最后return podID, nil

// buildUserPod builds hyperd's UserPod based kubelet PodSandboxConfig.

// TODO: support pod-level portmapping (depends on hyperd)

func buildUserPod(config *kubeapi.PodSandboxConfig) (*types.UserPod, error)

(1)、调用cgroupParent := config.Linux.GetCgroupParent(),根据cgroupParent计算得到cpuNumber和memoryinMegabytes

(2)、创建spec := &types.UserPod{

  Id:      buildSandboxName(config),

  Hostname:  config.GetHostname(),

  Labels:    buildLabelsWithAnnotations(config.Labels, config.Annotations),

  Resource:    &types.UserResource{

    Vcpu:    cpuNumber,

    Memory:  memoryinMegabytes,

  }

}

(3)、如果config.DnsConfig不为nil,则调用spec.Dns = config.DnsConfig.Servers

(4)、最后return spec, nil

frakti && RunPodSandbox 源码分析的更多相关文章

  1. ABP源码分析一:整体项目结构及目录

    ABP是一套非常优秀的web应用程序架构,适合用来搭建集中式架构的web应用程序. 整个Abp的Infrastructure是以Abp这个package为核心模块(core)+15个模块(module ...

  2. HashMap与TreeMap源码分析

    1. 引言     在红黑树--算法导论(15)中学习了红黑树的原理.本来打算自己来试着实现一下,然而在看了JDK(1.8.0)TreeMap的源码后恍然发现原来它就是利用红黑树实现的(很惭愧学了Ja ...

  3. nginx源码分析之网络初始化

    nginx作为一个高性能的HTTP服务器,网络的处理是其核心,了解网络的初始化有助于加深对nginx网络处理的了解,本文主要通过nginx的源代码来分析其网络初始化. 从配置文件中读取初始化信息 与网 ...

  4. zookeeper源码分析之五服务端(集群leader)处理请求流程

    leader的实现类为LeaderZooKeeperServer,它间接继承自标准ZookeeperServer.它规定了请求到达leader时需要经历的路径: PrepRequestProcesso ...

  5. zookeeper源码分析之四服务端(单机)处理请求流程

    上文: zookeeper源码分析之一服务端启动过程 中,我们介绍了zookeeper服务器的启动过程,其中单机是ZookeeperServer启动,集群使用QuorumPeer启动,那么这次我们分析 ...

  6. zookeeper源码分析之三客户端发送请求流程

    znode 可以被监控,包括这个目录节点中存储的数据的修改,子节点目录的变化等,一旦变化可以通知设置监控的客户端,这个功能是zookeeper对于应用最重要的特性,通过这个特性可以实现的功能包括配置的 ...

  7. java使用websocket,并且获取HttpSession,源码分析

    转载请在页首注明作者与出处 http://www.cnblogs.com/zhuxiaojie/p/6238826.html 一:本文使用范围 此文不仅仅局限于spring boot,普通的sprin ...

  8. ABP源码分析二:ABP中配置的注册和初始化

    一般来说,ASP.NET Web应用程序的第一个执行的方法是Global.asax下定义的Start方法.执行这个方法前HttpApplication 实例必须存在,也就是说其构造函数的执行必然是完成 ...

  9. ABP源码分析三:ABP Module

    Abp是一种基于模块化设计的思想构建的.开发人员可以将自定义的功能以模块(module)的形式集成到ABP中.具体的功能都可以设计成一个单独的Module.Abp底层框架提供便捷的方法集成每个Modu ...

随机推荐

  1. Hibernate框架与Mybatis框架的对比

    学习了Hibernate和Mybatis,但是一直不太清楚他们两者的区别的联系,今天在网上翻了翻,就做了一下总结,希望对大家有帮助! 原文:http://blog.csdn.net/firejuly/ ...

  2. 背水一战 Windows 10 (12) - 绘图: Shape, Path

    [源码下载] 背水一战 Windows 10 (12) - 绘图: Shape, Path 作者:webabcd 介绍背水一战 Windows 10 之 绘图 Shape - 图形 Path - 路径 ...

  3. this上下文,以及通过call 、apply 实现继承

    上下文:this关键字通常指向当前函数的拥有者,把拥有者叫做执行上下文. this代表函数运行时自动生成的内部对象,只能在函数内部使用. 构造函数中的this 指 构造函数的实例对象.javascri ...

  4. Ant搭建 一键生成APP技术 平台

    1.博客概要 本文详细介绍了当今流行的一键生成APP技术.介绍了这种设计思想的来源,介绍了国内外的研究背景,并介绍了这个技术体系中的一些实现细节,欢迎各路大神们多提意见.一键生成技术,说的通俗点就是, ...

  5. MongoDB主从复制(主从集群 )

    1.简介 主从复制是MongoDB最常用的复制方式.这种方式非常灵活,可用于备份.故障恢复.读扩展等. 最基本的设置方式就是建立一个主节点和一个或者多个从节点,每个从节点要知道主节点的地址.运行mon ...

  6. Lua-面向对象中类的构造

    在Lua中,我们可以通过table+function来模拟实现类. 而要模拟出类,元表(metatable)和__index元方法是必不可少的. 为一个表设置元表的方法: table = {} met ...

  7. jQuery静态方法globalEval使用和源码分析

    Eval函数大家都很熟悉,但是globalEval方法却很少使用,大多数参考手册也没有相关api,下面就对其用法和源码相应介绍: jQuery.globalEval()函数用于全局性地执行一段Java ...

  8. 详解JavaScript中的this

    JavaScript中的this总是让人迷惑,应该是js众所周知的坑之一. 个人也觉得js中的this不是一个好的设计,由于this晚绑定的特性,它可以是全局对象,当前对象,或者…有人甚至因为坑大而不 ...

  9. MyEclipse快捷键大全

    MyEclipse 快捷键1(CTRL)Ctrl+1 快速修复Ctrl+D: 删除当前行Ctrl+Q 定位到最后编辑的地方Ctrl+L 定位在某行Ctrl+O 快速显示 OutLineCtrl+T 快 ...

  10. iOS之处理不等高TableViewCell的几种方法

    课题一:如何计算Cell高度 方案一:直接法(面向对象) 直接法,就是把数据布局到Cell上,然后拿到Cell最底部控件的MaxY值. 第一步:创建Cell并正确设置约束,使文字区域高度能够根据文字内 ...