这个作业属于哪个课程 | 2302软件工程社区 |
---|---|
这个作业要求在哪里 | 软件工程实践总结&个人技术博客 |
这个作业的目标 | 课程回顾总结,个人技术总结 |
其他参考文献 | 无 |
文章目录
课程回顾与总结
收获
作为一名运维,我在每个阶段都进行了大量学习,学习服务网格架构,学习容器运行时(runtime),学习虚拟化。再将这些技能应用到生产实践中,我认为,不论是哪个阶段,实践就是最大的收获
问题思考
- 学生用GPT-4来做作业,老师要如何甄别呢?(https://bbs.csdn.net/topics/617526784)
实际上现在已经有比较系统的 GPT 识别工具。而且GPT 的回复相对的客套、官方,或者说具备 GPT 自己的回复语气,对 GPT 较为熟练的老师可以一眼分辨的出来。
实际上 GPT 的回复都是空洞、套话的。很容易识别。甚至不需要工具
- 在项目或程序比较复杂的情况下,如何高效率的进行程序理解?(https://bbs.csdn.net/topics/605551028)
一个庞大的项目通常是由无数小项目组成。这是模块化的思想,我们可以先按模块进行区分,而模块内部也可以再进行拆解,最后可以按功能逐步查看代码,实际上自己需要阅读的代码并不多的。
善用 source insight 等代码阅读工具,提升自己个人竞争力,其他的理解和寒假时一致
- 程序员是否有必要为满足小部分人的需求去做软件,或者为软件添加某些功能?(https://bbs.csdn.net/topics/605550627)
从商业角度考虑,程序员实现需求由产品经理决定,不符合这个题意。从个人开发者角度考虑,首先应当满足个人需求,其次再综合考虑自己的时间、能力等因素衡量是否需要满足小部分人的需求。
举个例子,如果这个需求既可以提升自己的能力,同时又能满足小部分人的需求,自己肯定是会去做的。
只有那些毫无工程能力提升可言,需求量又少,可以从时间角度出发,例如自己对这个项目是比较喜欢的,那是可以加入的,而如果项目一般、自己时间也不多,不需要考虑这部分人的需求。
答案是有必要的,Linus 开发 Linux 的理由也不是为了满足大部分的喜好,技术的发展往往是从小众开始的
- 为什么要在大学中只用一学期学软件工程,时间够吗?(https://bbs.csdn.net/topics/600462146)
大学提供的是一个系统性的学习体系,其中不止有软件工程,还有数据结构与算法、计算机组成原理、编译原理、计算机网络、操作系统等不同部分,大学学习的目的是建立一个体系知识,而专业决定了这个知识会更偏向哪一部分,以软件工程为例,我们就会更加的偏向软件工程,这门课的时长也就会更长。
软件工程的背后是庞大的计算机体系,软件工程不仅仅只有软件工程
- 花费时间越多,代表工作量越高吗?(https://bbs.csdn.net/topics/600462046)
肯定不是,重复的 CURD (增删改查)工作对个人提升是毫无意义的,不应当浪费大量时间在这部分上。
同上
掌握程度理解
目标1: 理解软件工程师的职业道德规范和实践要求,了解国情社情民情,理解软件产品对社会、健康文化等影响,树立积极向上的软件开发理念。
70,我认为我的理解还有进一步的提升空间(可能还蛮大)
目标2: 掌握需求分析的全过程,能辨别客户表述的多样化要求,熟练使用需求表达工具,能够规范、准确地表达客户的需求,构建需求分析模型。
80,本学期结合先前的经验,开发了不少项目,逐渐提升了自己全局掌握的能力
目标3: 掌握软件开发的全过程,遵循体系结构设计方法和基本设计原则,通过正式的技术评审,完成从体系结构设计模型、数据设计模型和构件级设计模型,形成面向高效可靠的服务组件设计方案或软件系统设计方案。
80,本学期学习了设计模式,结合先前项目经验,提升了很多能力
目标4: 能够执行从组件到软件系统的技术评测,具备设计模型的评判能力,具有创新设计意识,能够优选设计方案。
60,创新意识方面仍然需要训练
目标5: 遵循软件开发各阶段文档标准,采用规范的表达,掌握需求规格说明书、系统设计说明书、系统测试报告等文档撰写方法,具备与业界同行交流能力。
90,我推举并带领团队撰写了wiki.west2.online
目标6: 具有良好的团队意识和合作技能,能够与其他成员开展有效的沟通和协作;能够组织、协调或指挥团队开展工作。
70,从一开始队友找我找不到,到慢慢融入团体,我学会了很多,也收获了很多
目标7: 能够辨别具体软件项目管理中涉及的构成要素,掌握软件规模和工作量的估算方法,能够选择合适的工具规划软件进度并对项目管理过程进行配置,具备初步的管理复杂软件工程项目的能力。
80,本学期接触了大量软件,学习了不少软件的技巧
个人技术总结
技术概述
Kubernetes 是一个开源的容器编排平台,用于自动化容器化应用程序的部署、扩展和管理。它由 Google 设计并捐赠给CNCF来维护。Kubernetes提供了一个用于运行分布式系统的框架,允许应用程序在物理或虚拟机上的容器中无缝迁移和扩展。
当我们将服务器资源抽象成服务,涉及到云计算时,容器是避不开的一个话题,它让服务的运行和维护变得更加容易,
技术详述
a. Kubernetes 集群搭建
要使用 Kubernetes,首先需要搭建一个集群。这可以通过多种方式完成,例如使用 kubeadm
工具来初始化集群。
# 初始化 Kubernetes 主节点
kubeadm init --pod-network-cidr=10.244.0.0/16
# 设置 kubectl 访问
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
# 安装网络插件,例如 Flannel
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
b. 部署应用
部署应用通常涉及创建 Deployment 来管理 Pod 副本。以下是一个简单的 Deployment YAML 文件示例和命令。
apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
spec:
replicas: 3
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:1.14.2
ports:
- containerPort: 80
kubectl apply -f nginx-deployment.yaml
c. 监控与日志
部署 Prometheus 和 Grafana 来监控 Kubernetes 集群。
# 使用 Helm 安装 Prometheus
helm install stable/prometheus --name prometheus --namespace monitor
# 使用 Helm 安装 Grafana
helm install stable/grafana --name grafana --namespace monitor
d. 自动扩展
使用 Horizontal Pod Autoscaler 自动扩展 Pod 副本数量。
kubectl autoscale deployment nginx-deployment --min=2 --max=5 --cpu-percent=80
技术使用中遇到的问题和解决过程
在 K8s 上,k8s 的网络是极其复杂的,因此我遇到了部署项目的问题——服务无法从外部访问
解决过程
检查服务定义:首先确认 Service 资源是否正确配置了类型和端口。
kind: Service
apiVersion: v1
metadata:
name: nginx-service
spec:
selector:
app: nginx
ports:
- protocol: TCP
port: 80
targetPort: 80
type: LoadBalancer
-
检查防火墙规则:确保云提供商的网络防火墙规则允许访问 Kubernetes 节点上的端口。
-
检查负载均衡器状态:使用
kubectl get svc
检查负载均衡器的状态,确认它已经分配了外部 IP。 -
查看 Pod 日志:检查后端 Pod 的日志,确认没有错误信息。
-
使用端口转发测试:通过端口转发来测试服务。
kubectl port-forward service/nginx-service 8080:80
实际上,简单排查后我发现是在 Pod 内有自己一套独立的 DNS 解析系统,可以根据服务名去访问不同的服务,这个抽象概念是我使用 k8s 前所没有遇到的
参考文献/博客
操作系统、容器和 Kubernetes:https://west2-online.feishu.cn/wiki/NR0Iwp6mtij1oRkNKNXceeTknQL