查看节点:
kubectl get nodes
运行一个镜像
kubectl run tomcat --image=45.248.69.241:5000/tomcat --replicas=2 --port=8080
确认Deployment
kubectl get deployment
确认pod
kubectl get pods
删除pod
kubectl delete pods podsname
确认结果
kubectl get pods
可以看到刚刚生成的sonarqube-1880671902-s3fdq正在结束(Terminating),随之一个新的sonarqube-1880671902-n75d2正在创建,这是正是确保replicas为1的动作
删除deployment
直接删除pod触发了replicas的确保机制,那么我们删除deployment
kubectl delete deployment sonarqube
强制删除
kubectl delete pods <pod> --grace-period=0 --force
结果确认
kubectl get pods
kubectl get deployments
kubectl create
使用kubectl run在设定很复杂的时候需要非常长的一条语句,敲半天也很容易出错,也没法保存,在碰到转义字符的时候也经常会很抓狂,所以更多场景下会使用yaml或者json文件,而使用kubectl create或者delete就可以利用这些yaml文件。
比如,我们使用如下的方式来分别创建mysql和sonarqube的RC。
创建redis-master Pod和服务
先定义RC来创建pod,然后定义与之关联的service。
为redis-master服务新建一个名为redis-master-controller.yaml的RC定义文件,内容为:
apiVersion: v1
kind: ReplicationController
metadata:
name: redis-master1
labels:
name: redis-master1
spec:
replicas: 1
selector:
name: redis-master1
template:
metadata:
labels:
name: redis-master1
spec:
containers:
- name: master
image: 45.248.69.241:5000/redis-master
ports:
- containerPort: 6379
新建好文件之后执行如下命令:
kubectl create -f redis-master-controller.yaml
删除:将create换为delete即可。
查看刚刚新建的redis-master:
kubectl get rc
检查pod信息:
kubectl get pods
下面新建与上面建的pod相关联的service,service对应的文件redis-master-service.yaml,内容如下:
apiVersion: v1
kind: Service
metadata:
name: redis-master1
labels:
name: redis-master1
spec:
ports:
- port: 6379
targetPort: 6379
selector:
name: redis-master1
查看新建的service:
kubectl get services
2. redis-salve Pod和服务
步骤和redis-master的一样。
新建文件
vim redis-salve-controller.yaml
内容如下:
apiVersion: v1
kind: ReplicationController
metadata:
name: redis-slave
labels:
name: redis-slave
spec:
replicas: 2
selector:
name: redis-slave
template:
metadata:
labels:
name: redis-slave
spec:
containers:
- name: slave
image: 45.248.69.241:5000/guestbook-redis-slave
env:
- name: GET_HOSTS_FROM
value: env
ports:
- containerPort: 6379
运行kubectl create命令:
kubectl create -f redis-salve-controller.yaml
查看RC:
kubectl get rc
查看pod:
kubectl get pods
配置文件
vim redis-slave-service.yaml
内容如下:
apiVersion: v1
kind: Service
metadata:
name: redis-slave
labels:
name: redis-slave
spec:
ports:
- port: 6379
selector:
name: redis-slave
创建service:
kubectl create -f redis-slave-service.yaml
检查service:
kubectl get services
3. 创建frontend Pod和服务
文件 vim frontend-controller.yaml 内容如下:
apiVersion: v1
kind: ReplicationController
metadata:
name: frontend
labels:
name: frontend
spec:
replicas: 3
selector:
name: frontend
template:
metadata:
labels:
name: frontend
spec:
containers:
- name: frontend
image: 45.248.69.241:5000/guestbook-php-frontend
env:
- name: GET_HOSTS_FROM
value: env
ports:
- containerPort: 80
执行命令kubectl create:
kubectl create -f frontend-controller.yaml
检查RC:
kubectl get rc
检查pod:
kubectl get pods
文件
vim frontend-service.yaml
内容如下:
apiVersion: v1
kind: Service
metadata:
name: frontend
labels:
name: frontend
spec:
type: NodePort
ports:
- port: 80
nodePort: 30001
selector:
name: frontend
创建服务:
kubectl create -f frontend-service.yaml
检查service:
kubectl get services
访问网站
如我的虚拟机IP为192.168.80.123
则浏览器访问: 192.168.80.123:30001
成功的话会出现简单的留言板界面,并可进行留言commit。
解决kubectl get pods时 No resources found.问题
https://www.jianshu.com/p/8fce5522950e
vi /etc/kubernetes/apiserver
找到这一行
"KUBE_ADMISSION_CONTROL="--admission_control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ServiceAccount,ResourceQuota"
,去掉ServiceAccount,保存退出。
重新启动kube-apiserver服务即可
systemctl restart kube-apiserver.service
Kubernetes 无法删除pod实例的排查过程
https://www.58jb.com/html/155.html
Kubernetes实践(2)–hello world 示例
http://blog.csdn.net/u010472499/article/details/53142409
Kubernetes之kubectl常用命令使用指南1:创建和删除
http://blog.csdn.net/liumiaocn/article/details/73913597