最全的Linux教程,Linux从入门到精通
======================
-
linux从入门到精通(第2版)
-
Linux系统移植
-
Linux驱动开发入门与实战
-
LINUX 系统移植 第2版
-
Linux开源网络全栈详解 从DPDK到OpenFlow
第一份《Linux从入门到精通》466页
====================
内容简介
====
本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。
本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。
需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
这次通过了CKA(Certified Kubernetes Administration)考试,将考试中记得题目拿出来分享一下。
先秀一下CKA证书:
考试技巧就是对于kubectl原生的命令必须要熟悉,否则写yaml文件太浪费时间。
我在考试中用的集群都是 配置好了自动补全的。
要注意题目开始的时候切换集群的命令。
1.将所有pv按照name排序并输出结果到制定的文件中
这道题目主要考的就是对于kubectl命令中的sort-by的使用
kubectl get pv --sort-by=.metadata.name
2.启动一个daemonset名称为daemon-test,里面的pod名称为nginx,使用nginx image
这道题目考的是daemonset,这边可以先生成一个deployment的yaml,然后去修改这个yaml达到目的,要注意的是这里需要保证pod container的名称是nginx
#先生成一个deploy的yaml
kubectl run daemon-test --image=nginx -o yaml --dry-run >deploy.yaml
#修改一下yaml文件
apiVersion: apps/v1
kind: DaemonSet
metadata:
labels:
run: daemon-test
name: daemon-test
spec:
selector:
matchLabels:
run: daemon-test
template:
metadata:
name: nginx
labels:
run: daemon-test
spec:
containers:
- image: nginx:latest
name: nginx
3.启动一个包含nginx,redis,ubuntu的pod
kubectl run可以生成一个pod的yaml,我们在yaml中添上其他container就可以。不要使用kubectl run --image=nginx --image=redis这样只会生成最后一个container,不会生成三个container
#先生成单个container的pod
kubectl run test-pod --image=nginx -o yaml --dry-run --restart=Never>pod.yaml
#修改yaml文件
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
labels:
run: test-pod
name: test-pod
spec:
containers:
- image: nginx
name: nginx
- image: redis
name: redis
- image: ubuntu
name: ubuntu
4.启动一个deployment包含了nginx的pod,初始版本为1.9.1,升级到1.13.1并记录,升级完回滚到原来的版本
这道题目考查的是deployment的升级,主要使用rollout
#生成deployment
kubectl run deploy-nginx --image=nginx:1.9.1
#升级到1.13.1
kubectl set image deployment deploy-nginx deploy-nginx=nginx:1.13.1 --record
#查看升级历史
kubectl rollout history deployment deploy-nginx
#回滚
kubectl rollout undo deployment deploy-nginx
5.启动一个container,判断当目录/data下存在a.txt就继续运行,如果不存在就退出。a.txt需要使用initcontainer来创建
考查volume mount和init container,这里要使用emptydir来进行挂载
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
labels:
run: test-file
name: test-file
spec:
containers:
- name: myapp-container
image: busybox:1.28
command: ['sh', '-c', 'if [ -f /data/a.txt ];then sleep 3000;fi']
volumeMounts:
- mountPath: /data
name: cache-volume
initContainers:
- name: init-myservice
image: busybox:1.28
command: ['sh', '-c', 'touch /data/a.txt']
volumeMounts:
- mountPath: /data
name: cache-volume
volumes:
- name: cache-volume
emptyDir: {}
6.将loadbalncer的deployment实例扩展到3个
考查deploy的扩容,直接使用命令行操作
kubectl scale deployment loadbalancer --replicas=3
7.给pod front-app创建对应的service将它暴露出来
考查的是给pod绑定service
需要找到pod的端口
kubectl describe pod xxxx
绑定service
kubectl expose pod front-app --type=ClusterIp --port=80 --target-port=80
8.将deployment my-nginx绑定nodeport类型service,并且输出service和pod解析的dns日志
考查deploy绑定service,以及集群中的dns解析
#创建service
kubectl expose deployment my-nginx --type=NodePort --port=80 --target-port=80
#dns解析使用nslookup,需要启动一个pod来协助
wget http://kubernetes.io/examples/admin/dns/busybox.yaml
kubectl apply -f busybox.yaml
#使用nslookup解析service
kubectl exec -it busybox nslookup my-nginx
#使用nslookup解析pod
kubectl get pods -owide | grep my-nginx 查看到pod对应的ip
kubectl exec -it busybox nslookup 查到的对应的ip
9.pod redis挂载一个volume,挂载到目录/data/redis下,要求目录是non-presist的
non-presist就说明是一个emptydir类型
apiVersion: v1
kind: Pod
metadata:
creationTimestamp: null
labels:
run: redis
name: redis
spec:
containers:
- name: redis
image: redis
volumeMounts:
- mountPath: /data/redis
name: cache-volume
volumes:
- name: cache-volume
emptyDir: {}
10.将pod nginx调度到label为disk=ssd的节点上
考查nodeselector
kubectl run nginx --image=nginx -o yaml --dry-run >nginx.yml
在nginx.yml中加入nodeselector即可
apiVersion: v1
kind: Pod
metadata:
name: nginx
labels:
env: test
spec:
containers:
- name: nginx
image: nginx
imagePullPolicy: IfNotPresent
nodeSelector:
disk: ssd
11.创建一个deployment启动10个redis实例,并且label为check=test,不需要真实启动,只需要将yaml存储在指定目录
直接使用命令生成yaml文件即可
kubectl run redis --image=redis --replicas=10 --labels=check=test -o yaml --dry-run > redis.yaml
12.创建一个挂载本地目录/data/pv的pv大小为2G,策略为WRO
apiVersion: v1
kind: PersistentVolume
metadata:
name: task-pv-volume
labels:
type: local
spec:
storageClassName: manual
capacity:
storage: 2Gi
accessModes:
- ReadWriteOnce
hostPath:
path: "/data/pv"
13.将节点node1不参与调度,并将他所有的pod分配到其他node上
kubectl drain node1 --ignore-daemonsets --delete-local-data
14.统计集群中所有的可用节点,不包含不可调度的节点,将个数写到对应的文件中去
获取到节点注意有没有taints是noscheduler的
kubectl get nodes
kubectl describe node_name查看taint
15.列出pod中log为file-not-found的行并且写入到指定文件中
为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!
这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。
本份面试集锦涵盖了
- 174 道运维工程师面试题
- 128道k8s面试题
- 108道shell脚本面试题
- 200道Linux面试题
- 51道docker面试题
- 35道Jenkis面试题
- 78道MongoDB面试题
- 17道ansible面试题
- 60道dubbo面试题
- 53道kafka面试
- 18道mysql面试题
- 40道nginx面试题
- 77道redis面试题
- 28道zookeeper
总计 1000+ 道面试题, 内容 又全含金量又高
- 174道运维工程师面试题
1、什么是运维?
2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?
3、现在给你三百台服务器,你怎么对他们进行管理?
4、简述raid0 raid1raid5二种工作模式的工作原理及特点
5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?
6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?
7、Tomcat和Resin有什么区别,工作中你怎么选择?
8、什么是中间件?什么是jdk?
9、讲述一下Tomcat8005、8009、8080三个端口的含义?
10、什么叫CDN?
11、什么叫网站灰度发布?
12、简述DNS进行域名解析的过程?
13、RabbitMQ是什么东西?
14、讲一下Keepalived的工作原理?
15、讲述一下LVS三种模式的工作过程?
16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
17、如何重置mysql root密码?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
11、什么叫网站灰度发布?
12、简述DNS进行域名解析的过程?
13、RabbitMQ是什么东西?
14、讲一下Keepalived的工作原理?
15、讲述一下LVS三种模式的工作过程?
16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
17、如何重置mysql root密码?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!