import "os/exec"
cmd := exec.Command("CLS")
err := cmd.Run()
cmd2 := exec.Command("PAUSE")
err2 := cmd.Run()
通过信号量来监听Ctrl+c退出信号来卡住命令行不退出func main{
fmt.Println("system(pause)")
quit := make(chan os.Signal)
signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
sig := <-quit
for { if sig.String() == "interrupt"{ break }}
return
k8s是google公司使用go语言开发,借鉴borg系统开发出来的。
k8s集群服务器主要分为两类角色,分别为master和node。
api server: k8s网关,所有指令请求都必须经过apiserver。
scheduler: 调度器 根据调度算法,将请求资源调度到某一个node节点。
controller: 控制器,维护k8s资源对象。
etcd: 分布式存储组件,用于存储资源对象。
docker: 运行容器的基础环境,容器引擎。
kubelet: 每个node节点都存在一份,在node节点上的资源操作指令均由kubelet执行,从etcd扫描相关请求,在节点上执行请求。
kube-proxy: 代理服务,负载均衡
fluentd: 日志收集服务
pod: 是k8s管理的基本单位(最小单元),pod 内部是容器
k8s是用来管理容器的,但是不直接操作容器,最小操作单元为pod
特点:
pod是一个虚拟化的分组(有自己的ip地址、主机名),pod相当于独立主机,可以封装一个或多个容器。通常情况下,一个pod中要么部署一个服务,要么部署多个相关的服务
1、pod底层网络和数据存储:
pod底层网络和存储主要依赖pause容器,该容器作用如下:
2、pod内部容器使用localhost相互访问
3、pod内部容器创建之前必须先创建pause