关键词:
背景:
Kubernetes介绍:http://kubernetes.io/docs/getting-started-guides/
github地址:https://github.com/kubernetes/kubernetes
在ubuntu上安装文档官方地址:http://kubernetes.io/docs/getting-started-guides/ubuntu/
环境:
- Master:
- Ubunut14.04
- 192.168.27.135(NAT)
- Minion1:
- Ubuntu14.04
- 192.168.27.136(NAT)
- Minion2:
- Ubuntu14.04
- 192.168.27.137(NAT)
准备工作:
需要在三个节点上安装docker和ssh,安装ssh:
$ sudo apt-get install openssh-server
$ sudo service ssh start
安装docker:
sudo apt-get install docker-engine
安装Kubernetes:
1、在Master上,首先创建一个工作目录,执行:
$ git clone https://github.com/kubernetes/kubernetes.git
2、下载完后,进入kubernetes目录,修改kubernetes/cluster/ubuntu/config-default.sh文件:
root@192.168.127.135 root@192.168.27.136 root@192.168.27.137
3、安装kubernetes:
$ cd kubernetes/cluster
$ KUBERNETES_PROVIDER=ubuntu ./kube-up.sh
成功安装的截图如下:
访问页面:
遇到的各种坑:
1、重启master节点,如何恢复?
这个问题弄了我至少3小时才搞定,因为我是准备直接重新执行一遍上面步骤的第三步,也就是再执行一次kube-up.sh,然而我发现每次该脚本都会从github上下载etcd、flanneld和kubernetes包,这个包有1.4G大小,可想而知要耽误多少时间。然后我就只能慢慢找这段脚本在哪执行的,最后发现在kubernetes/cluster/ubuntu/下的download-release.sh,也就是下图中的文件。所以我就把文件的内容改了,改成下面代码中的样子,目的是不让它每次都下。随后呢,我的做法是把第一次成功安装的文件备份一下,也就是把kubernetes/cluster/ubuntu/binaries这个目录备份起来,然后直接拷到重启后的master的对应目录。然后再执行kube-up.sh,之后就OK啦!
#!/bin/bash # Copyright 2015 The Kubernetes Authors All rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # Download the etcd, flannel, and K8s binaries automatically and stored in binaries directory # Run as root only # author @resouer @WIZARD-CXY set -e #function cleanup { # cleanup work #rm -rf flannel* kubernetes* etcd* binaries #} #trap cleanup SIGHUP SIGINT SIGTERM pushd $(dirname $0) mkdir -p binaries/master mkdir -p binaries/minion # flannel FLANNEL_VERSION=${FLANNEL_VERSION:-"0.5.5"} echo "Prepare flannel ${FLANNEL_VERSION} release ..." grep -q "^${FLANNEL_VERSION}\$" binaries/.flannel 2>/dev/null || { # curl -L https://github.com/coreos/flannel/releases/download/v${FLANNEL_VERSION}/flannel-${FLANNEL_VERSION}-linux-amd64.tar.gz -o flannel.tar.gz # tar xzf flannel.tar.gz # cp flannel-${FLANNEL_VERSION}/flanneld binaries/master # cp flannel-${FLANNEL_VERSION}/flanneld binaries/minion echo ${FLANNEL_VERSION} > binaries/.flannel } # ectd ETCD_VERSION=${ETCD_VERSION:-"2.3.1"} ETCD="etcd-v${ETCD_VERSION}-linux-amd64" echo "Prepare etcd ${ETCD_VERSION} release ..." grep -q "^${ETCD_VERSION}\$" binaries/.etcd 2>/dev/null || { # curl -L https://github.com/coreos/etcd/releases/download/v${ETCD_VERSION}/${ETCD}.tar.gz -o etcd.tar.gz # tar xzf etcd.tar.gz # cp ${ETCD}/etcd ${ETCD}/etcdctl binaries/master echo ${ETCD_VERSION} > binaries/.etcd } function get_latest_version_number { local -r latest_url="https://storage.googleapis.com/kubernetes-release/release/stable.txt" if [[ $(which wget) ]]; then wget -qO- ${latest_url} elif [[ $(which curl) ]]; then curl -Ss ${latest_url} else echo "Couldn't find curl or wget. Bailing out." >&2 exit 4 fi } KUBE_VERSION=$(get_latest_version_number | sed 's/^v//') # k8s echo "Prepare kubernetes ${KUBE_VERSION} release ..." grep -q "^${KUBE_VERSION}\$" binaries/.kubernetes 2>/dev/null || { # curl -L https://github.com/kubernetes/kubernetes/releases/download/v${KUBE_VERSION}/kubernetes.tar.gz -o kubernetes.tar.gz # tar xzf kubernetes.tar.gz # pushd kubernetes/server # tar xzf kubernetes-server-linux-amd64.tar.gz # popd # cp kubernetes/server/kubernetes/server/bin/kube-apiserver \ # kubernetes/server/kubernetes/server/bin/kube-controller-manager \ # kubernetes/server/kubernetes/server/bin/kube-scheduler binaries/master # cp kubernetes/server/kubernetes/server/bin/kubelet \ # kubernetes/server/kubernetes/server/bin/kube-proxy binaries/minion # cp kubernetes/server/kubernetes/server/bin/kubectl binaries/ echo ${KUBE_VERSION} > binaries/.kubernetes } #rm -rf flannel* kubernetes* etcd* echo "Done! All your binaries locate in kubernetes/cluster/ubuntu/binaries directory" popd
ubuntu14.0464bit安装teamviewer
1.下载teamviewer,链接如下:http://downloadus2.teamviewer.com/download/version_10x/teamviewer_10.0.36281_i386.deb2.安装teamviewer,安装命令如下:sudodpkg-iteamviewer_10.0.36281_i386.deb[email protected]:~/Download 查看详情
ubuntu14.0464位jdk安装
1官网下载jdkhttp://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.htmljdk-8u71-linux-x64.tar.gz2解压,并移至新建目录/usr/java中#tar-xzvfjdk-8u71-linux-x64.tar.gz#mkdir-p/usr/java#mvjdk1.8.0_ 查看详情
ubuntu14.0464bitsparkr安装部署
要安装SparkR,首先需要安装好hadoop和Spark,这个安装前面两篇已经引用了详细的教程。值得注意的是,jdk也要确保安装正确,并且有一个默认的版本(如果安装过多个不同版本的jdk),可以通过sudoupdate-... 查看详情
ubuntu14.0464位配置caffe教程(基于cuda7.5)
深度学习是研究计算机视觉的重要工具,尤其在图像分类与识别等领域有着划时代的意义。现在有很多深度学习框架,Caffe是比较常用的一个。本文讲述了Ubuntu14.04(64位)系统下配置Caffe的基本步骤,参考了Caffe的官方网站&n... 查看详情
spark快速安装与简单入门_ubuntu14.0464bitx
ApacheSpark是一个新兴的大数据处理通用引擎,提供了分布式的内存抽象。Spark正如其名,最大的特点就是快(Lightning-fast),可比HadoopMapReduce的处理速度快100倍。此外,Spark提供了简单易用的API,几行代... 查看详情
ubuntu14.0464bit编译u-boot-2016.07提示yourdtcistooold,pleaseupgradetodtc1.4ornewer
Author:AP0904225版权声明:本文为博主原创文章,转载请标明出处。Ubuntu14.0464bit环境下编译u-boot-2016.07提示如下错误:CHKinclude/config/uboot.releaseCHKinclude/generated/version_autogenerated.hCHKinclude/generated/timestamp_autogenerated 查看详情
hadoop2.x安装教程_单机/伪分布式配置_ubuntu14.0464bitx
最近需要跟进小组大势,所以学习一下Spark。本文提供一份Hadoop2.x.x的详细教程,非常好用。按照流程来,基本没有问题。本教程由给力星出品,原文链接http://www.powerxing.com/install-hadoop/ 查看详情
ubuntu14.04安装caffe+cuda7.5(代码片段)
Caffe官网的安装说明实在太简单了点,主要是参考的Caffe+Ubuntu14.0464bit+CUDA6.5配置说明和Ubuntu14.04下安装Caffe总结。系统是Ubuntu14.0464bit,显卡是GTX950M。1.Caffe依赖包sudoapt-getinstallbuild-essential#basicrequirementsudo 查看详情
Janus WebRTC 安装问题
...布时间】:2016-01-0500:24:45【问题描述】:我在Ubuntu机器(14.0464位)中安装JanusWebRTC网关。我按照以下链接中的说明进行操作:但是,尝试执行janus时出现以下错误:https://github.com/meetecho/janus-gateway(readme.md文件)[致命][janus 查看详情
从 ubuntu 卸载 mongoDB
...经按照InstallMongoDBCommunityEditiononUbuntu中的命令在我的ubuntu14.0464位系统上安装了MongoDB3.0.1,并且我安装了Robomongo接口来使用它。当我尝试使用Robomongo连接MongoDB时,我收到授权失败 查看详情
使用 boost 安装 libtorrent 时出错
...boost【发布时间】:2014-11-2219:11:15【问题描述】:在Lubuntu14.0464位上,当我尝试安装delibtorrent库时出现此配置错误:checkingforboostlib>=1.35...yescheckingwhethertheBoost::Systemlibraryisavai 查看详情
Armadillo + OpenBLAS 多线程
...ing【发布时间】:2015-10-1610:47:41【问题描述】:我在Ubuntu14.0464bit的硕士论文中成功使用了Armadillo和OpenBLAS(安装和未安装Armadillo)。性能非常令人印象深刻——我的代码主要由基本的矩阵运算组成。所有这些都是使用所有可用线... 查看详情
ubuntu14.04安装caffe+cuda7.5(代码片段)
...安装说明实在太简单了点,主要是参考的Caffe+Ubuntu14.0464bit+CUDA6.5配置说明和Ubuntu14.04下安装Caffe总结。系统是Ubuntu14.0464bit,显卡是GTX950M。1.Caffe依赖包sudoapt-getinstallbuild-essential#basicrequirementsudoapt-getinstalllibprotobuf-devlib... 查看详情
ets和读取文件出错
...正在尝试从here获取代码工作。设置是安装了Erlang的Ubuntu14.0464位机器。动作顺序如下:我正在做的事情如下:克隆代码cd到带有代码的文件夹和终端中的erlmake:all([load]).polis:create() 查看详情
ubuntu查询某个库的相关情况
环境:Ubuntu14.0464bit1.如:查询libjpeg库的位置ldconfig-p|greplibjpeg2.如:查询libjpeg库的相关名称dpkg-l‘*jpeg*‘3.如:通过2查到的名称来查找位置dpkg-L‘名称‘如:dpkg-L‘libopenjpeg2‘ 查看详情
安装arm交叉编译器
1、开发平台虚拟机:VMware12操作系统:Ubuntu14.0464bit2、准备ARM交叉编译工具包 编译uboot和linuxkernel都需要ARM交叉工具链支持,这里使用Linaro提供的交叉编译工具。下载地址为:http://releases.linaro.org/注意:如果主机... 查看详情
为啥连续调用 new[] 不分配连续内存?
...布时间】:2014-10-2921:50:44【问题描述】:我使用的是Ubuntu14.0464位。这是我的C++代码,看看内存是如何使用的。intmain()int**ptr;ptr=newint*[2];cout<< 查看详情
无法使可执行文件可移植
.../libtins.github.io我编译:g++-oarparp.cpp-ltins它运行良好(Ubuntu14.0464位),但是如果我将可执行文件发送给朋友,他在运行时会收到此错误:errorwhileloadingsharedli 查看详情