frakti && RunPodSandbox 源码分析
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 源码分析的更多相关文章
- ABP源码分析一:整体项目结构及目录
ABP是一套非常优秀的web应用程序架构,适合用来搭建集中式架构的web应用程序. 整个Abp的Infrastructure是以Abp这个package为核心模块(core)+15个模块(module ...
- HashMap与TreeMap源码分析
1. 引言 在红黑树--算法导论(15)中学习了红黑树的原理.本来打算自己来试着实现一下,然而在看了JDK(1.8.0)TreeMap的源码后恍然发现原来它就是利用红黑树实现的(很惭愧学了Ja ...
- nginx源码分析之网络初始化
nginx作为一个高性能的HTTP服务器,网络的处理是其核心,了解网络的初始化有助于加深对nginx网络处理的了解,本文主要通过nginx的源代码来分析其网络初始化. 从配置文件中读取初始化信息 与网 ...
- zookeeper源码分析之五服务端(集群leader)处理请求流程
leader的实现类为LeaderZooKeeperServer,它间接继承自标准ZookeeperServer.它规定了请求到达leader时需要经历的路径: PrepRequestProcesso ...
- zookeeper源码分析之四服务端(单机)处理请求流程
上文: zookeeper源码分析之一服务端启动过程 中,我们介绍了zookeeper服务器的启动过程,其中单机是ZookeeperServer启动,集群使用QuorumPeer启动,那么这次我们分析 ...
- zookeeper源码分析之三客户端发送请求流程
znode 可以被监控,包括这个目录节点中存储的数据的修改,子节点目录的变化等,一旦变化可以通知设置监控的客户端,这个功能是zookeeper对于应用最重要的特性,通过这个特性可以实现的功能包括配置的 ...
- java使用websocket,并且获取HttpSession,源码分析
转载请在页首注明作者与出处 http://www.cnblogs.com/zhuxiaojie/p/6238826.html 一:本文使用范围 此文不仅仅局限于spring boot,普通的sprin ...
- ABP源码分析二:ABP中配置的注册和初始化
一般来说,ASP.NET Web应用程序的第一个执行的方法是Global.asax下定义的Start方法.执行这个方法前HttpApplication 实例必须存在,也就是说其构造函数的执行必然是完成 ...
- ABP源码分析三:ABP Module
Abp是一种基于模块化设计的思想构建的.开发人员可以将自定义的功能以模块(module)的形式集成到ABP中.具体的功能都可以设计成一个单独的Module.Abp底层框架提供便捷的方法集成每个Modu ...
随机推荐
- 基于jQuery的自适应图片左右切换
效果预览:http://hovertree.com/code/jquery/smjv6d0n.htm 基于jQuery编写的横向自适应幻灯片切换特效 全屏自适应jquery焦点图切换特效,在IE6这个 ...
- Win10计算器在哪里?三种可以打开Win10计算器的方法图文介绍
全新的windows10系统带来了不少新的特性和改变,其中win10的计算器位置就发生了很多的变化,导致很多网友们都以为win10计算器不见了,那么,win10计算器在哪里?如何打开?针对此问题,本文 ...
- 用C#读取相片(JPG图片)的EXIF信息的方法
引言:EXIF,是英文Exchangeable Image File{}#endregion#region 数据转换结构/// summary>/// 转换数据结构/// /summary> ...
- 如何使 WebAPI 自动生成漂亮又实用在线API文档
1.前言 1.1 SwaggerUI SwaggerUI 是一个简单的Restful API 测试和文档工具.简单.漂亮.易用(官方demo).通过读取JSON 配置显示API. 项目本身仅仅也只依赖 ...
- 基于SSH框架的学生公寓管理系统的质量属性
系统名称:学生公寓管理系统 首先介绍一下学生公寓管理系统,在学生公寓管理方面,针对学生有关住宿信息问题进行管理,学生公寓管理系统主要包含了1)学生信息记录:包括学号.姓名.性别.院系.班级:2)住宿信 ...
- java多线程-线程池
线程池(Thread Pool)对于限制应用程序中同一时刻运行的线程数很有用.因为每启动一个新线程都会有相应的性能开销,每个线程都需要给栈分配一些内存等等. 我们可以把并发执行的任务传递给一个线程池, ...
- Asp.net mvc5开源项目"超级冷笑话"
业务时间做了个小网站,超级冷笑话,地址:http://www.superjokes.cn/ 开发技术: asp.net mvc5 +SQLServer2012 ORM:NPoco 用了简单的三层结构 ...
- js--找字符串中出现最多的字符
在一个字符串中,如 'zhaochucichuzuiduodezifu',我们要找出出现最多的字符.本文章将详细说明方法思路. 先介绍两个string对象中的两个方法:indexOf()和charAt ...
- xcode8打包ipa文件, application loader上传成功,但是iTunes Connect不显示构建版本
最近更新的Xcode8.今天提交新项目时.按照以往的流程走 Xcode 编译ipa文件.applicaiton loader提交成功 但是.iTunes connect构建版本不显示.非常疑惑.平时等 ...
- iOS--KVO的概述与使用
一.概述 KVO,即:Key-Value Observing,它提供一种机制,当指定的对象的属性被修改后,则对象就会接受到通知.简单的说就是每次指定的被观察的对象的属性被修改后,KVO就会自动通知相应 ...