本文原文出处: http://blog.csdn.net/bluishglc/article/details/52440312 严禁任何形式的转载,否则将委托CSDN官方维护权益!
for SERVICE in etcd kube-apiserver kube-controller-manager kube-scheduler; do
sudo systemctl restart $SERVICE
sudo systemctl enable $SERVICE
sudo systemctl status $SERVICE
done
for SERVICE in etcd kube-apiserver kube-controller-manager kube-scheduler; do
sudo systemctl status $SERVICE
done
for SERVICE in kube-proxy kubelet flanneld; do
sudo systemctl restart $SERVICE
sudo systemctl enable $SERVICE
sudo systemctl status $SERVICE
done
sudo systemctl stop docker
sudo /sbin/ifconfig docker0 down
sudo brctl delbr docker0
sudo systemctl start docker
sudo systemctl enable docker
sudo systemctl status docker
注:docker服务总是在要flannel服务之后启动,flannel服务重启,docker服务必须重启。这是因为flannel会为docker配置好网络参数并以环境变量的方式传递给docker, 这些配置好的环境变量会存放在/run/flannel/docker
文件里,文件中一般会存储这些变量:
DOCKER_OPT_BIP="--bip=172.16.54.1/24"
DOCKER_OPT_IPMASQ="--ip-masq=true"
DOCKER_OPT_MTU="--mtu=1450"
DOCKER_NETWORK_OPTIONS=" --bip=172.16.54.1/24 --ip-masq=true --mtu=1450 "
for SERVICE in kube-proxy kubelet flanneld docker; do
sudo systemctl status $SERVICE
done
补充:如果机器上没有安装brctl,可使用如下命令安装:
sudo yum -y install bridge-utils
for NAMESPACE in your-namespace; do
echo ""
echo "########## [ $NAMESPACE ] ##########"
echo ""
for ITEM in rc services pods; do
echo ""
echo "---------- [ $ITEM ] ----------"
echo ""
sudo kubectl --namespace=$NAMESPACE get $ITEM
done
done
for NAMESPACE in your-namespace; do
echo ""
echo "########## [ $NAMESPACE ] ##########"
echo ""
for ITEM in rc services pods; do
echo ""
echo "---------- [ $ITEM ] ----------"
echo ""
sudo kubectl --namespace=$NAMESPACE delete $ITEM --all --cascade --timeout=0
done
done
所谓“废弃”镜像是指那些不再被任何tag标记的镜像。
sudo docker rmi $(sudo docker images | awk '/^<none>/ { print $3 }')
我们可以把上述命令添加到cron作业里,让机器自动定时清理。
sudo docker rm -f $(sudo docker ps -a|awk '/your-keyword/ { print $1 }')
初学者在刚刚接触Kubernetes时会遇到Service无法访问的问题,原因往往只是Service的selector的值没有和pod匹配,这种错误很容易通过查看service的endpoints信息来验证,如果endpoints为空,就说明selector的值配错了。只需要修改为对应pod的标签就可以了。
在kubernetes的yaml配置文件中,使用spec.volumes
来指定一个Pod需要的volume信息,使用spec.containers.volumeMounts
来将container和一个volume关联起来。
Kubernetes支持非常多类型的volume, 具体的信息可以参考官方文档: http://kubernetes.io/docs/user-guide/volumes/ 其中最为常见的是
emptyDir: 随Pod删除,适用于临时存储、灾难恢复、共享运行时数据
hostPath 类似于Docker的本地Volume,把Pod上的某个文件夹映射到本地目录,用于访问一些本地资源(比如本地Docker)。
下面这个份配置是一个比较典型的例子,mysql的官方docker镜像中配置了一个指定的文件夹:/docker-entrypoint-initdb.d
mysql容器启动时会自动执行这个文件夹下的shell脚本和sql文件,这给了应用程序初始化数据库的机会,所以当我们需要在mysql容器启动时初始化我们的数据库,我们以把数据库脚本放到本地的某个目录下,本例中我们使用的是/home/admin/mysql
, 然后配置mysql的部署描述文件,把容器预定义的文件夹/docker-entrypoint-initdb.d
映射到本地的/home/admin/mysql
即可。在下述配置中,我们需要特别注意spec.volumes
和spec.containers.volumeMounts
两处配置:
apiVersion: v1
kind: ReplicationController
metadata:
name: app-db
namespace: app-dev
labels:
name: app-db
spec:
replicas: 1
template:
metadata:
labels:
name: app-db
spec:
containers:
- name: app-db
image: my-registry:5000/docker_library/mysql:5.7
imagePullPolicy: Always
volumeMounts:
- mountPath: /docker-entrypoint-initdb.d
name: init-volume
env:
- name: MYSQL_ROOT_PASSWORD
value: root
ports:
- containerPort: 3306
name: mysql
volumes:
- name: init-volume
hostPath:
path: /home/admin/mysql
host: db-node
nodeName: db-node