k8s day04
昨日内容回顾:
- configMap ---> cm
应用场景: 主要用于配置文件的持久化。
- secret
应用场景: 存储敏感数据,并非加密数据。
- pod探针(probe):
- livenessProbe:
健康检查探针,若检查失败,则会重启容器(重新创建容器)。
值得注意的是,若手动去使用docker去kill容器,是否会重启取决于重启策略,注意,尽管重新拉起容器会计数重启次数。
- readinessProbe
可用性检查探针,若检查失败,则将容器标记为未就绪状态,与此同时,对于svc的ep资源列表不会自动发现;
- env获取cm或者secret资源的值
Q1: 请问Pod导入secret资源有几种方式?
- env
- volume
Q2: 请问cm资源有几种定义方式?
- 单行模式,
KEY: VALUE
- 多行模式,类文件模式
KEY : |
...
...
...
Q3: 外网访问K8S集群的Pod有多少种方式?
- hostNetwork
- hostPort ---> 1.5.2有效! 1.15.12则无效!【了解即可】
- Svc
- Ing
- ApiServer
Q4: 影响Pod调度的方式有哪些?
- nodeName
- resources
- 污点
- 污点容忍
- 亲和性
- 反亲和性
- 自定义调度器
- 工作负载调度器 ---> ds,deploy
...
kubectl version :
查看K8S的版本号。
GitVersion:"v1.5.2",
BuildDate:"2017-07-03T15:31:10Z"
GitVersion:"v1.15.12",
BuildDate:"2020-05-06T05:09:48Z"
[root@k8s151.oldboyedu.com po]# cat 22-pods-ports.yaml
kind: Pod
apiVersion: v1
metadata:
name: oldboyedu-linux82-ports-001
spec:
nodeName: k8s152.oldboyedu.com
containers:
- name: linux82-web
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
# 定义容器的端口映射相关信息
ports:
# 容器内服务监听的端口
- containerPort: 80
# 指定绑定的宿主机IP地址
hostIP: 0.0.0.0
# 指定宿主机的端口
hostPort: 18888
# 给映射的端口起名字,要求唯一
name: myweb
# 指定协议,有效值为: UDP, TCP, or SCTP.
protocol: TCP
[root@k8s151.oldboyedu.com po]#
容器的三种类型:
网络基础镜像容器:
pause:v3.1
---> 提供网络基础的。
初始化容器:
initContainers
---> 为业务容器提供基础环境准备的。
业务容器:
containers
---> 跑实际业务。
初始化容器参考案例:
[root@k8s151.oldboyedu.com po]# cat 23-pods-initContainers.yaml
---
apiVersion: v1
data:
.dockerconfigjson: eyJhdXRocyI6eyIxMC4wLjAuMjUwIjp7InVzZXJuYW1lIjoiamFzb255aW4yMDIwIiwicGFzc3dvcmQiOiJPbGRib3llZHVAMjAyMiIsImVtYWlsIjoiamFzb255aW5Ab2xkYm95ZWR1LmNvbSIsImF1dGgiOiJhbUZ6YjI1NWFXNHlNREl3T2s5c1pHSnZlV1ZrZFVBeU1ESXkifX19
kind: Secret
metadata:
name: oldboyedu-harbor
type: kubernetes.io/dockerconfigjson
---
kind: Pod
apiVersion: v1
metadata:
name: oldboyedu-linux82-initcontianer-002
spec:
nodeName: k8s152.oldboyedu.com
imagePullSecrets:
- name: oldboyedu-harbor
# 初始化容器,为业务容器提供基础环境准备的。
initContainers:
- name: init-web
image: 10.0.0.250/oldboyedu-linux/stress:v0.1
command:
- sleep
- "30"
# 我们可以将containers理解为业务容器。初始化容器要先于业务容器运行。
containers:
- name: linux82-web
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
# 定义容器的端口映射相关信息
ports:
# 容器内服务监听的端口
- containerPort: 80
# 指定绑定的宿主机IP地址
hostIP: 0.0.0.0
# 指定宿主机的端口,k8s1.5.2会监听端口,K8S1.15.12不会监听端口但能访问哟!
hostPort: 28888
# 给映射的端口起名字,要求唯一
name: myweb
# 指定协议,有效值为: UDP, TCP, or SCTP.
protocol: TCP
[root@k8s151.oldboyedu.com po]#
静态Pod:
vim /var/lib/kubelet/config.yaml
...
staticPodPath: /etc/kubernetes/manifests
温馨提示:
(1)静态Pod是由kubelet启动时通过"staticPodPath"配置参数指定路径
(2)静态Pod创建的Pod名称会自动加上kubelet节点的主机名,比如"-k8s151.oldboyedu.com",会忽略"nodeName"字段哟;
(3)静态Pod的创建并不依赖API-Server,而是直接基于kubelet所在节点来启动Pod;
(4)静态Pod的删除只需要将其从staticPodPath指定的路径移除即可;
(5)静态Pod路径仅对Pod资源类型有效,其他类型资源将不被创建哟
(6)咱们的kubeadm部署方式就是基于静态Pod部署的哟;
rc简介:
replicationcontrollers控制器简称"rc",可以保证指定数量的Pod始终存活,rc通过标签选择器来关联Pod。
[root@k8s151.oldboyedu.com rc]# cat 01-rc-nginx.yaml
kind: ReplicationController
apiVersion: v1
metadata:
name: oldboyedu-linux82-rc-web
spec:
# 指定Pod的副本数量,若不指定,则默认值为1.
replicas: 3
# 定义标签选择器,即用于关联Pod的标签。
selector:
school: oldboyedu
# 定义Pod的模板
template:
metadata:
name: linux82-web
labels:
school: oldboyedu
class: linux82
spec:
# nodeName: k8s152.oldboyedu.com
containers:
- name: linux82-web
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
[root@k8s151.oldboyedu.com rc]#
创建RS资源用于测试svc:
[root@k8s151.oldboyedu.com rs]# cat 01-rs-nginx.yaml
kind: ReplicaSet
apiVersion: extensions/v1beta1
metadata:
name: oldboyedu-linux82-rs-web
spec:
# 指定Pod的副本数量,若不指定,则默认值为1.
replicas: 3
# 定义标签选择器,即用于关联Pod的标签。
selector:
# 相比于rc资源,rs资源支持的功能更加强大,不仅仅支持标签选择器,还支持表达式(matchExpressions)
matchLabels:
school: oldboyedu
# 定义Pod的模板
template:
metadata:
name: linux82-web
labels:
school: oldboyedu
class: linux82
spec:
# nodeName: k8s152.oldboyedu.com
containers:
- name: linux82-web
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
livenessProbe:
tcpSocket:
port: 80
failureThreshold: 3
initialDelaySeconds: 15
periodSeconds: 1
successThreshold: 1
timeoutSeconds: 1
readinessProbe:
httpGet:
port: 80
path: /oldboyedu.html
failureThreshold: 3
initialDelaySeconds: 15
periodSeconds: 1
successThreshold: 1
timeoutSeconds: 1
[root@k8s151.oldboyedu.com rs]#
创建svc资源:
[root@k8s151.oldboyedu.com rs]# cat ../svc/01-svc-nginx.yaml
apiVersion: v1
kind: Service
metadata:
name: linux82-svc-web
spec:
# 映射Pod端口信息
ports:
# 指定SVC的端口
- port: 9999
# 指定Pod提供服务的端口
targetPort: 80
# 指定标签,用于匹配关联的POD
selector:
class: linux82
[root@k8s151.oldboyedu.com rs]#
查看所有的svc:
kubectl get svc
查看指定svc的详细信息:
kubectl describe svc linux82-svc-web
rc资源有两大缺陷:
(1)不支持声明式更新镜像;
(2)升级的时候有时候需要运维人员介入解决svc无法自动关联Pod的现象;
为了避免这种现象发生,将rc资源的selector和svc的selector定义成不一样的关联即可。见视频。
基于rc升级和回滚:
1.创建原始版本
kubectl apply -f 01-rc-svc.yaml -f 02-rc-nginx-old.yaml
2.测试访问服务
curl -I 10.0.0.53:30088
3.升级
kubectl rolling-update oldboyedu-linux82-rc-web-old -f 03-rc-nginx-update-new.yaml --update-period=1s
oldboyedu-linux82-rc-web-old:
表示现有的rc名称。
-f 03-rc-nginx-update-new.yaml
基于哪个文件升级或回滚。
--update-period=1s
升级的间隔时间。
4.升级后运行需要解决用户无法访问Pod的情况
方案一:
使用旧的svc,即给新的pod打标签。
kubectl label pods --all class=linux82
# kubectl label pods --all class- # 删除标签
方案二:
使用新的svc。
kubectl delete -f 01-rc-svc.yaml
kubectl apply -f 04-rc-svc-new.yaml
5.回滚
kubectl rolling-update oldboyedu-linux82-rc-web-new -f 02-rc-nginx-old.yaml --update-period=1s
kubectl delete -f 04-rc-svc-new.yaml
kubectl apply -f 01-rc-svc.yaml
资源清单:
[root@k8s151.oldboyedu.com test]# cat 01-rc-svc.yaml
apiVersion: v1
kind: Service
metadata:
name: linux82-svc-web-nodeport-002
spec:
type: NodePort
ports:
- port: 9999
targetPort: 80
nodePort: 30088
selector:
class: linux82
[root@k8s151.oldboyedu.com test]#
[root@k8s151.oldboyedu.com test]# cat 02-rc-nginx-old.yaml
kind: ReplicationController
apiVersion: v1
metadata:
name: oldboyedu-linux82-rc-web-old
spec:
# 指定Pod的副本数量,若不指定,则默认值为1.
replicas: 3
# 定义标签选择器,即用于关联Pod的标签。
selector:
school: oldboyedu
# 定义Pod的模板
template:
metadata:
name: linux82-web
labels:
school: oldboyedu
class: linux82
spec:
# nodeName: k8s152.oldboyedu.com
containers:
- name: linux82-web
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.14
[root@k8s151.oldboyedu.com test]#
[root@k8s151.oldboyedu.com test]# cat 03-rc-nginx-update-new.yaml
kind: ReplicationController
apiVersion: v1
metadata:
name: oldboyedu-linux82-rc-web-new
spec:
replicas: 3
selector:
school: oldboyedu-new
template:
metadata:
name: linux82-web
labels:
school: oldboyedu-new
address: beijing-linux82
spec:
containers:
- name: linux82-web
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.16
[root@k8s151.oldboyedu.com test]#
[root@k8s151.oldboyedu.com test]# cat 04-rc-svc-new.yaml
apiVersion: v1
kind: Service
metadata:
name: linux82-svc-web-nodeport-002-new
spec:
type: NodePort
ports:
- port: 9999
targetPort: 80
nodePort: 30088
selector:
school: oldboyedu-new
address: beijing-linux82
[root@k8s151.oldboyedu.com test]#
deoloyment资源控制器: ---> 声明式更新
[root@k8s151.oldboyedu.com deploy]# cat 01-deploy-nginx.yaml
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
name: oldboyedu-linux82-deploy-nginx
spec:
replicas: 3
selector:
matchLabels:
school: oldboyedu
template:
metadata:
name: linux82-web
labels:
school: oldboyedu
class: linux82
spec:
containers:
- name: linux82-web
# image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.18
livenessProbe:
tcpSocket:
port: 80
failureThreshold: 3
initialDelaySeconds: 15
periodSeconds: 1
successThreshold: 1
timeoutSeconds: 1
# readinessProbe:
# httpGet:
# port: 80
# path: /oldboyedu.html
# failureThreshold: 3
# initialDelaySeconds: 15
# periodSeconds: 1
# successThreshold: 1
# timeoutSeconds: 1
---
apiVersion: v1
kind: Service
metadata:
name: linux82-svc-web-nodeport-002
spec:
type: NodePort
clusterIP: 10.254.100.100
ports:
- port: 9999
targetPort: 80
nodePort: 30088
selector:
class: linux82
[root@k8s151.oldboyedu.com deploy]#
响应式更新:
kubectl set image deploy oldboyedu-linux82-deploy-nginx linux82-web=k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.16
kubectl set image 资源类型 资源类型名称 容器名称=镜像名称
基于edit编辑:
kubectl edit deployments. oldboyedu-linux82-deploy-nginx
副本数量
old : 5
new : 5
附加条件:
old ---> new :
- 5 + 2 ---> 7 升级过程中最大的pod
- 5 - 1 ---> 4 最少保证4个可用。
升级需要几次?请说明原因:
第一次升级:
old : 3 5 4 5 2 ---> 4
new : 2 2 2 2 3 ---> 3
第二次升级:
old: 3 0 4 2 1 3 6 ---> 1
new: 4 7 2 5 6 4 4 ---> 3 + 2 ---> 5
...
replicas: 8
maxSurge: 5
maxUnavailable: 3
---->
第一次升级
old : 5
new : 8
replicas: 7
maxSurge: 2
---> max ---> 9
maxUnavailable: 3
---> min ---> 4
第一次升级:
old: 4
new: 5
第二次升级:
old: 0
new: 5 + 2 --> 7
基于deployment升级:
[root@k8s151.oldboyedu.com deploy]# cat 02-deploy-nginx-update-strategy.yaml
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
name: oldboyedu-linux82-deploy-nginx-strategy
spec:
replicas: 5
selector:
matchLabels:
school: oldboyedu
# 定义升级策略
strategy:
# 升级的类型,"Recreate" or "RollingUpdate"
# Recreate:
# 先停止所有的Pod运行,然后在批量创建更新。
# 生产环节中不推荐使用这种策略,因为升级过程中用户将无法访问服务!
# RollingUpdate:
# 滚动更新,即先实现部分更新,逐步替换原有的pod,是默认策略。
type: RollingUpdate
# 自定义滚动更新的策略
rollingUpdate:
# 在原有Pod的副本基础上,多启动Pod的数量。
maxSurge: 2
# 在升级过程中最大不可访问的Pod数量.
maxUnavailable: 1
template:
metadata:
name: linux82-web
labels:
school: oldboyedu
class: linux82
spec:
containers:
- name: linux82-web
# image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.20.1
# image: k8s151.oldboyedu.com:5000/oldboyedu-web/nginx:1.18
image: nginx:1.14
livenessProbe:
tcpSocket:
port: 80
failureThreshold: 3
initialDelaySeconds: 15
periodSeconds: 1
successThreshold: 1
timeoutSeconds: 1
# readinessProbe:
# httpGet:
# port: 80
# path: /oldboyedu.html
# failureThreshold: 3
# initialDelaySeconds: 15
# periodSeconds: 1
# successThreshold: 1
# timeoutSeconds: 1
---
apiVersion: v1
kind: Service
metadata:
name: linux82-svc-web-nodeport-002
spec:
type: NodePort
clusterIP: 10.254.100.100
ports:
- port: 9999
targetPort: 80
nodePort: 30088
selector:
class: linux82
扩展作业:
(1)使用阿里云部署K8S集群,并将11个游戏将部署到云平台提供访问,要求使用svc的类型为LoadBalancer。
(2)使用kubeadm1.15或Kubeadm 1.19版本将其etcd数据库独立部署出来,不要使用内置的;
(3)调研K3S二进制部署,K3S是轻量级的K8S发行版;
(4)部署ranger管理K8S集群;
常见错误:
PodFitsHostPorts:
问题原因:
和Pod调度节点的端口有所冲突。
解决方案:
可能无法提供给"ss -ntl"来观察,需要借助"iptables -t nat -vnL"来观察哟。
Init:ErrImagePull
问题原因:
初始化容器拉取镜像失败。
解决方案:
一般情况下,请检查网络,权限等维度即可。
相关文章:
k8s day04
昨日内容回顾: - configMap ---> cm 应用场景: 主要用于配置文件的持久化。 - secret 应用场景: 存储敏感数据,并非加密数据。 - pod探针(probe): - livenessProbe: 健康检查探针&#x…...
ESP32-IPS彩屏ST7789-Arduino-简单驱动
目的: 使ESP32能够驱动点亮ST7789显示屏 前提条件: ESP32 ST7789 (240 x240,IPS) 杜邦线 Arduino 过程: 0x00--接线 0x01--驱动: 彩屏驱动库 针对不同的彩屏驱动芯片,常用的 Arduino…...
高效工具类软件使用
高效工具类软件使用 目录概述需求: 设计思路实现思路分析1.Leanote2.Obsidian 的使用 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for…...
批处理文件(.bat)中,dir与tree命令的效果
目录 dir命令 用法 操作 效果 dir /? dir dir D:\111\111_3 dir D:\111 *.mp4 dir D:\111 /ad dir D:\111 /ar dir D:\111 /s dir D:\111\111_3 >1bat.txt dir D:\111 >>1bat.txt tree命令 用法 操作 效果 tree /? tree tree D:\111\111_3 tree…...
STM32 ---- 再次学习STM32F103C8T6/STM32F409IGT6
目录 一、环境搭建及介绍 关于STM32基础介绍 新建工程 外设案例 LED流水灯 蜂鸣器 上拉电阻和下拉电阻知识 电压比较器 c语言基础知识 类型、结构体、枚举 类型int8_t int16_t int32_t 宏替换 #define 和typedef用法 结构体两种填充方法 和 命名规则 枚举用法 常用…...
UE4 EQS环境查询 学习笔记
EQS环境查询对应Actor的范围 EQS环境查询查询对应的类 查询到即有一个蓝色的球在Actor上,里面有位置信息等等 在行为树运行EQS,按键(‘)可以看到Player的位置已经被标记 运行对应的EQS在这里放如EQS就可以了 Generated Point&…...
计算机算法分析与设计(11)---贪心算法(活动安排问题和背包问题)
文章目录 一、贪心算法概述二、活动安排问题2.1 问题概述2.2 代码编写 三、背包问题3.1 问题描述3.2 代码编写 一、贪心算法概述 1. 贪心算法的定义:贪心算法是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以…...
shell命令以及运行原理
Linux严格意义上说的是一个操作系统,我们称之为“核心(kernel)“ ,但我们一般用户,不能直接使用kernel。 而是通过kernel的“外壳”程序,也就是所谓的shell,来与kernel沟通。如何理解&a…...
MySQL进阶(再论JDBC)——JDBC编程思想的分析 JDBC的规范架构 JDBC相关的类分析
前言 SQL(Structured Query Language)是一种用于管理关系型数据库的标准化语言,它用于定义、操作和管理数据库中的数据。SQL是一种通用的语言,可以用于多种关系型数据库管理系统(RDBMS),如MySQ…...
rabbitMQ的知识点
RabbitMQ是一种消息队列软件,它实现了高度可靠的消息传递机制。RabbitMQ支持多种消息协议,包括AMQP、STOMP、MQTT等,比较灵活。以下是一些rabbitmq的知识点: 1. 消息队列:消息队列是一种分布式系统中广泛使用的通信模…...
EtherNet/IP 库卡机器人和EtherCAT倍福PLC总线协议连接案例
EtherNet/IP 是一种适合于工业环境和对时间要求比较苛刻的应用的网络。而远创智控YC-EIPM-ECT通讯网关,是一款自主研发的EtherNet/IP 从站功能的通讯网关。它不仅可以实现EtherNet/IP 和EtherCAT的无缝连接,还可以将EtherNet/IP 作为从站连接到EtherCAT总…...
微信小程序 uniapp+vue线上洗衣店业务管理系统演89iu2
本课题意在设计一种系统的、基于用户体验的线上洗衣服务模式,具有如下的研究意义: (1)为用户提供更简单、便捷的洗衣服务模式; (2)为智能柜的盈利模式提供了新的方向; (3)通过线上系统、智能柜与洗衣工厂结合的方式,为洗衣企业构建了一套节 省人力成本的…...
Maven项目,进行编译,使用idea的 编译功能,就是正常的,但是在终端中执行 mvn clean compile 报错
一、背景: Maven项目,进行编译,使用idea的 编译功能,就是正常的,但是在终端中执行 mvn clean compile 报错 报错信息: [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin…...
mssql还原数据库失败
标题: Microsoft SQL Server Management Studio ------------------------------ 服务器 "192.168.31.132" 的 附加数据库 失败。 (Microsoft.SqlServer.Smo) 有关帮助信息,请单击: https://go.microsoft.com/fwlink?ProdNameMicrosoftSQLServer&…...
Linux多线程编程- 无名信号量
简介 无名信号量(在 POSIX 环境下通常指 sem_t 类型的信号量)是用于同步和互斥的原语,它允许线程和进程按照预期的顺序执行,并确保对共享资源的安全访问。无名信号量与命名信号量的主要区别在于它们的可见性和生命周期。无名信号…...
【网络协议】聊聊DHCP和PXE 工作原理
DHCP 动态主机配置协议 对于每个主机来说,只要连接了网络,那么就会配置一个IP地址,那么这个IP地址,如果是手动配置的话,对于公司内部的人员来说都要找IT进行配置,这个太浪费人力物力了,所以解决…...
发现国内优秀的团队协作软件,帮助提高工作效率
中国有许多优秀的团队协作软件,它们在企业和组织中发挥着重要作用。 以下是一些最受欢迎的团队协作软件: 1、钉钉(DingTalk): 这是一款由阿里巴巴推出的企业级协作工具,旨在帮助企业和组织实现高效沟通和协作。钉钉提…...
LeetCode 面试题 08.12. 八皇后
文章目录 一、题目二、C# 题解 一、题目 设计一种算法,打印 N 皇后在 N N 棋盘上的各种摆法,其中每个皇后都不同行、不同列,也不在对角线上。这里的“对角线”指的是所有的对角线,不只是平分整个棋盘的那两条对角线。 注意&#…...
Excel 的下拉列表
可以将 Sheet6 隐藏,就更好地隐藏了来源。...
基于Effect的组件设计 | 京东云技术团队
Effect的概念起源 从输入输出的角度理解Effect https://link.excalidraw.com/p/readonly/KXAy7d2DlnkM8X1yps6L 编程中的Effect起源于函数式编程中纯函数的概念 纯函数是指在相同的输入下,总是产生相同的输出,并且没有任何副作用(side effect)的函数。…...
2021-03-15 iview一些问题
1.iview 在使用tree组件时,发现没有set类的方法,只有get,那么要改变tree值,只能遍历treeData,递归修改treeData的checked,发现无法更改,原因在于check模式下,子元素的勾选状态跟父节…...
【算法训练营Day07】字符串part1
文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接:344. 反转字符串 双指针法,两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...
DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...
BCS 2025|百度副总裁陈洋:智能体在安全领域的应用实践
6月5日,2025全球数字经济大会数字安全主论坛暨北京网络安全大会在国家会议中心隆重开幕。百度副总裁陈洋受邀出席,并作《智能体在安全领域的应用实践》主题演讲,分享了在智能体在安全领域的突破性实践。他指出,百度通过将安全能力…...
《基于Apache Flink的流处理》笔记
思维导图 1-3 章 4-7章 8-11 章 参考资料 源码: https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...
Unit 1 深度强化学习简介
Deep RL Course ——Unit 1 Introduction 从理论和实践层面深入学习深度强化学习。学会使用知名的深度强化学习库,例如 Stable Baselines3、RL Baselines3 Zoo、Sample Factory 和 CleanRL。在独特的环境中训练智能体,比如 SnowballFight、Huggy the Do…...
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...
安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)
船舶制造装配管理现状:装配工作依赖人工经验,装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书,但在实际执行中,工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...
springboot 日志类切面,接口成功记录日志,失败不记录
springboot 日志类切面,接口成功记录日志,失败不记录 自定义一个注解方法 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;/***…...
c# 局部函数 定义、功能与示例
C# 局部函数:定义、功能与示例 1. 定义与功能 局部函数(Local Function)是嵌套在另一个方法内部的私有方法,仅在包含它的方法内可见。 • 作用:封装仅用于当前方法的逻辑,避免污染类作用域,提升…...
