K8S(一)
| 角色 | IP |
| k8s-master | 192.168.1.31 |
| k8s-node1 | 192.168.1.32 |
| k8s-node2 | 192.168.1.33 |
systemctl stop firewalld
systemctl disable firewalld sed -i 's/enforcing/disabled/' /etc/selinux/config # 永久
setenforce 0 # 临时 swapoff -a # 临时
sed -ri 's/.*swap.*/#&/' /etc/fstab # 永久 hostnamectl set-hostname <hostname> cat >> /etc/hosts << EOF
192.168.1.31 k8smaster
192.168.1.32 k8snode1
192.168.1.33 k8snode2
EOF cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl --system # 生效 yum install ntpdate -y
ntpdate time.windows.com wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
yum -y install docker-ce-18.06.1.ce-3.el7
systemctl enable docker && systemctl start docker
docker --version
Docker version 18.06.1-ce, build e68fc7a cat > /etc/docker/daemon.json << EOF
{"registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"]
}
EOF systemctl restart docker 添加 yum 源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF yum install -y kubelet-1.18.0 kubeadm-1.18.0 kubectl-1.18.0
systemctl enable kubelet kubeadm init --apiserver-advertise-address=192.168.1.31 --image-repository registry.aliyuncs.com/google_containers --kubernetes-version v1.18.0 --service-cidr=10.96.0.0/12 --pod-network-cidr=10.244.0.0/16 [root@k8smaster ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
registry.aliyuncs.com/google_containers/kube-proxy v1.18.0 43940c34f24f 3 years ago 117MB
registry.aliyuncs.com/google_containers/kube-apiserver v1.18.0 74060cea7f70 3 years ago 173MB
registry.aliyuncs.com/google_containers/kube-controller-manager v1.18.0 d3e55153f52f 3 years ago 162MB
registry.aliyuncs.com/google_containers/kube-scheduler v1.18.0 a31f78c7c8ce 3 years ago 95.3MB
registry.aliyuncs.com/google_containers/pause 3.2 80d28bedfe5d 3 years ago 683kB
registry.aliyuncs.com/google_containers/coredns 1.6.7 67da37a9a360 3 years ago 43.8MB
registry.aliyuncs.com/google_containers/etcd 3.4.3-0 303ce5db0e90 4 years ago 288MB
(2)使用 kubectl 工具:
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config
kubectl get nodes kubeadm join 192.168.1.31:6443 --token p7bbz2.854x4kf9hvy3tbnc --discovery-token-ca-cert-hash sha256:7fb11503642078ab3eaa586286e5e6cd1219e4ad368b2d7f60818b7eec2ca91b 如果有问题:error execution phase preflight: couldn't validate the identity of the API Server: Get https://192.168.1.31:6443/api/v1/namespaces/kube-public/configmaps/cluster-info?timeout=10s: x509: certificate has expired or is not yet valid
问题1:token 过期
此时需要通过kubedam重新生成token
//解决方法
//master主机上重新生成token
[root@k8smaster ~]# kubeadm token generate #生成toke
xeqcbp.3nc76rjngebtqer0 #下面这条命令中会用到该结果
[root@k8smaster ~]# kubeadm token create xeqcbp.3nc76rjngebtqer0 --print-join-command --ttl=0 #根据token输出添加命令
kubeadm join 192.168.1.31:6443 --token xeqcbp.3nc76rjngebtqer0 --discovery-token-ca-cert-hash sha256:7fb11503642078ab3eaa586286e5e6cd1219e4ad368b2d7f60818b7eec2ca91b 然后用上面输出的kubeadm join命令放到想要添加的节点中执行
[root@k8snode1 ~]# kubeadm join 192.168.1.31:6443 --token xeqcbp.3nc76rjngebtqer0 --discovery-token-ca-cert-hash sha256:7fb11503642078ab3eaa586286e5e6cd1219e4ad368b2d7f60818b7eec2ca91b
W1120 22:51:37.787600 19907 join.go:346] [preflight] WARNING: JoinControlPane.controlPlane settings will be ignored when control-plane flag is not set.
[preflight] Running pre-flight checks[WARNING IsDockerSystemdCheck]: detected "cgroupfs" as the Docker cgroup driver. The recommended driver is "systemd". Please follow the guide at https://kubernetes.io/docs/setup/cri/
[preflight] Reading configuration from the cluster...
[preflight] FYI: You can look at this config file with 'kubectl -n kube-system get cm kubeadm-config -oyaml'
[kubelet-start] Downloading configuration for the kubelet from the "kubelet-config-1.18" ConfigMap in the kube-system namespace
[kubelet-start] Writing kubelet configuration to file "/var/lib/kubelet/config.yaml"
[kubelet-start] Writing kubelet environment file with flags to file "/var/lib/kubelet/kubeadm-flags.env"
[kubelet-start] Starting the kubelet
[kubelet-start] Waiting for the kubelet to perform the TLS Bootstrap...This node has joined the cluster:
* Certificate signing request was sent to apiserver and a response was received.
* The Kubelet was informed of the new secure connection details.Run 'kubectl get nodes' on the control-plane to see this node join the cluster. 问题2:k8s api server不可达
此时需要检查和关闭所有服务器的firewalld和selinux
wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml 默认镜像地址无法访问,sed命令修改为docker hub镜像仓库。
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml 报错:The connection to the server raw.githubusercontent.com was refused - did you specify the right host or port?
解决办法:
#在https://www.ipaddress.com/查询raw.githubusercontent.com的真实IP。
vi /etc/hosts
199.232.28.133 raw.githubusercontent.com[root@k8smaster ~]# kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
namespace/kube-flannel created
clusterrole.rbac.authorization.k8s.io/flannel created
clusterrolebinding.rbac.authorization.k8s.io/flannel created
serviceaccount/flannel created
configmap/kube-flannel-cfg created
daemonset.apps/kube-flannel-ds created[root@k8smaster ~]# kubectl get pods -n kube-system
NAME READY STATUS RESTARTS AGE
coredns-7ff77c879f-gt6z4 1/1 Running 0 3h56m
coredns-7ff77c879f-n2w4j 1/1 Running 0 3h56m
etcd-k8smaster 1/1 Running 1 3h56m
kube-apiserver-k8smaster 1/1 Running 1 3h56m
kube-controller-manager-k8smaster 1/1 Running 1 3h56m
kube-proxy-98wxv 1/1 Running 0 19m
kube-proxy-n8js9 1/1 Running 0 19m
kube-proxy-tp6ks 1/1 Running 1 3h56m
kube-scheduler-k8smaster 1/1 Running 1 3h56m[root@k8smaster ~]# kubectl get nodes
NAME STATUS ROLES AGE VERSION
k8smaster Ready master 3h58m v1.18.0
k8snode1 Ready <none> 20m v1.18.0
k8snode2 Ready <none> 20m v1.18.0 [root@k8smaster ~]# kubectl create deployment nginx --image=nginx
deployment.apps/nginx created[root@k8smaster ~]# kubectl expose deployment nginx --port=80 --type=NodePort
service/nginx exposed[root@k8smaster ~]# kubectl get pod,svc
NAME READY STATUS RESTARTS AGE
pod/nginx-f89759699-mtrjf 1/1 Running 0 2m43s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 4h3m
service/nginx NodePort 10.110.82.49 <none> 80:30867/TCP 33s 访问地址:http://192.168.1.32:30867/,http://192.168.1.33:30867/ (两个节点中任意节点的对应端口)
相关文章:
K8S(一)
一、kubernetes 概述 1、kubernetes 基本介绍 kubernetes,简称 K8s,是用 8 代替 8 个字符“ubernete”而成的缩写。是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes 的目标是让部署容器化的 应用简单并且高效…...
Linux快速显示文件行号并跳转
有时候,想要在线上直接查看日志文件,搜索到关键词后,如果一直按n找下去,很麻烦,我们可以先显示出行号,确定好我们要找内容对应的行号,直接跳转过去。 esc进入命令模式,输入:set nu命…...
异步爬取+多线程+redis构建一个运转丝滑且免费http-ip代理池 (二)
继上一章: CSDN 本次需要做的是进行有效ip的验证! 我们知道,从网页上爬取上千上万个ip之后,因为是免费的代理,所以,对这上千上万个ip进行验证有效性就需要考虑效率上的问题了; 而验证ip有效性的唯一办法,就是通过对网络发起请求;如果state200,就是有效,否则就是无效; 而上…...
HugeGraph安装与使用
1、HugeGraph-Server与HugeGraph-Hubble下载 HugeGraph官方地址:https://hugegraph.apache.org/ 环境为:linux 官网是有模块版本对应关系,尽量下载较新版本,hubble1.5.0之前是studio功能比较少。官网已经下架server,其他模块下载也比较慢。可以在网上找…...
计算机端口
前言 计算机端口(Port)是一种用于在计算机网络中标识特定服务或应用程序的机制。 端口是一个数字,范围从0到65535,用于将网络通信分配给不同的应用程序或服务。 在 Internet 协议套件(TCP/IP)中࿰…...
激发创新,助力研究:CogVLM,强大且开源的视觉语言模型亮相
项目设计集合(人工智能方向):助力新人快速实战掌握技能、自主完成项目设计升级,提升自身的硬实力(不仅限NLP、知识图谱、计算机视觉等领域):汇总有意义的项目设计集合,助力新人快速实…...
centos 6.10 安装 perl 5.14
下载安装包 运行下面命令: wget http://www.cpan.org/src/5.0/perl-5.14.2.tar.gz也可以直接下载好安装包,再拷到虚拟机 安装 执行下面命令 tar -xvzf perl-5.14.2.tar.gz #解压安装包 cd perl-5.14.2 ./Configure -des -Dprefix/usr/local/perl ma…...
Elasticsearch:FMA 风格的向量相似度计算
作者:Chris Hegarty 在 Lucene 9.7.0 中,我们添加了利用 SIMD 指令执行向量相似性计算的数据并行化的支持。 现在,我们通过使用融合乘加 (Fused Mulitply-Add - FMA) 进一步推动这一点。 什么是 FMA 乘法和加法是一种常见的运算,…...
思维模型 等待效应
本系列文章 主要是 分享 思维模型 ,涉及各个领域,重在提升认知。越是等待,越是焦虑。 1 等待效应的应用 1.1 等待效应在管理中的应用 西南航空公司是一家美国的航空公司,它在管理中运用了等待效应。西南航空公司鼓励员工在工作中…...
Linux下使用宏定义判断系统架构和系统类型
文章目录 查看编译器当前支持的宏定义查找指定的宏不同架构不同系统 附录-编译器内部常用的一些宏定义宏定义实际应用使用宏定义判断系统架构使用宏定义判断系统类型 一般情况下在linux下做C/C方面的开发不需要太关注系统架构,当然如果涉及到不同架构下的适配问题&a…...
Python---把函数的返回值作为另外一个函数的参数
def test1():return 50def test2(num):print(num)# 1. 保存函数test1的返回值 result test1()# 2.将函数返回值所在变量作为参数传递到test2函数 test2(result) # 50...
231123 刷题日报-动态规划
今天主要看了DP,前几天频繁遇到DP打击有点大。。 1. 0-1背包问题 要点: a. 三部曲: 1. 状态和选择 状态:物品序号、背包容量 选择:放、不放 2. dp数组定义、base case dp[i][w] 对于前i个物品,当前背包…...
微信小程序前端环境搭建
搭建微信小程序前端环境 申请小程序测试账号 访问路径 使用微信扫描二维码进行申请,申请成功之后,进入界面,获取小程序ID(AppID)和秘钥(AppSecret) 安装微信web开发者工具 访问路径 选择稳定开发的版本 需要在小程序的设置中将默认关闭…...
【Qt一坑】qt编译出现“常量中有换行符”
在qt编译过程中出现“常量中有换行符”,原因有以下几点(qt版本5.14.2): 1.中文编码格式问题,将UTF-8编码格式改成 UTF-8 BOM。 或者使用QtCreator 进行如下设置(找到Qt的左边列表里的项目,下的…...
C++每日选择题—Day1
第一题 以下C代码会输出什么? #include <iostream> using namespace std; class A { public:A() {}~A() {} private:static int a; }; int main() {cout << sizeof(A) << endl;return 0; } A:0 B:1 C:4 D:8 答…...
【实用】mysql配置 及将线上数据导入本地 问题解决及记录
[ERR] 1292 - Incorrect datetime value: ‘0000-00-0000:00:00‘ for column ‘BIRTH_DATE‘ at row 1 此问题是mysql当前配置不支持日期为空,或者为‘0000-00-0000:00:00‘得情况 1、直接在数据库执行 # 修改全局 set global.sql_mode ONLY_FULL_GROUP_BY,STR…...
如何下载OpenJDK及其源码
如果想下载 OpenJDK,存在以下几种办法: 最简单的办法是去 OpenJDK 官网,这里能下载 JDK9 及其以上的版本,还有 JDK 源码所在的 github 地址。 第二种方法是使用 IDEA 下载,位置在 File->Project Structure->SD…...
[Android]使用Retrofit进行网络请求
以下是使用 Retrofit 发送 POST 请求获取分页城市列表的 Kotlin 代码示例 1.在你的 build.gradle 文件中添加 Retrofit 和 Gson 的依赖 dependencies {......implementation("com.squareup.retrofit2:retrofit:2.9.0")implementation("com.squareup.retrofit2…...
OpenGL 绘制圆形平面(Qt)
文章目录 一、简介二、代码实现三、实现效果一、简介 这里使用一种简单的思路来生成一个圆形平面: 首先,我们需要生成一个单位圆,半径为1,法向量为(0, 0, 1),这一步我们可以使用一些函数生成圆形点集。之后,指定面片的索引生成一个圆形平面。当然这里为了后续管理起来方便…...
JAVA系列---Servlet详解
目录 背景为何会出现ServletWeb开发的本质 ServletsCGIFastCGIWSGIServlet总结 wsgi与servlet出现时间社区特点对web开发的影响 servlet详解特性主要工作执行逻辑 应用Tomcat背景embedded tomcat本质 背景 为何会出现Servlet Servlet是Server Applet 的缩写,译为“…...
从‘能用’到‘好看’:手把手教你用QSS和第三方库美化PyQt6/PySide6界面
从‘能用’到‘好看’:手把手教你用QSS和第三方库美化PyQt6/PySide6界面 当你的PyQt6/PySide6应用终于跑通了所有功能逻辑,却不得不面对一个残酷现实——界面看起来像是从上个世纪穿越过来的。别担心,这不是你的错。Python的GUI开发向来以功能…...
Shark007 Advanced Codecs
链接:https://pan.quark.cn/s/1ae881a46e4b在版本18中首次推出,结合了ADVANCED和STANDARD版任何“电影和电视应用程序”无法播放的内容,都可以在WMP中使用Shark编解码器播放。 您只需要勾选框,[x] WMP建议的设置。 Windows Media …...
小型语言模型在金融价格预测中的高效实践
1. 项目背景与核心价值在金融科技领域,价格预测一直是个充满挑战的课题。传统方法主要依赖统计模型和时间序列分析,但随着语言模型技术的发展,我们开始探索新的可能性。SLM Pricer这个项目尝试用小型语言模型(Small Language Model)来解决价格…...
灰色网络深度揭秘:暗网真实生态与安全风险全面解析
1. Hack Forums:不止是技术,更是“灰色地带”的狂欢? 这个2005年就成立的老牌论坛,与其说是“黑客技术交流”,不如说是网络安全灰色地带的缩影。从渗透测试到社工,啥都有,甚至还有交易区…别告…...
AIGC率突然飙升怎么救:嘎嘎降AI实测降幅60%+全程2026
AIGC率突然飙升怎么救:嘎嘎降AI实测降幅60%全程2026 答辩前一周,把上周还显示 28% 的稿子重新跑了一遍知网 AIGC,结果跳到了 71.3%。同款情况维普也出现,从 33% 涨到 68%。截止日就在眼前,不能慢慢摸索,需要…...
医疗C项目必须建立的5级代码审查漏斗:覆盖DO-178C/IEC 62304/FDA SWCG的三重合规验证机制
更多请点击: https://intelliparadigm.com 第一章:医疗嵌入式C语言FDA 2026合规编码的监管演进与范式跃迁 FDA于2024年发布的《Digital Health Center of Excellence Guidance v3.1》正式确立了2026年起对Class II及以上嵌入式医疗设备实施强制性“可追…...
避坑指南:在OpenHarmony上玩转Modbus RTU,RS-485接线和libmodbus配置那些事儿
OpenHarmony工业互联实战:RS-485硬件连接与libmodbus配置避坑手册 当温控器的数据突然跳变,当电表读数出现异常抖动,很多工程师的第一反应往往是检查代码逻辑——但真正的陷阱可能藏在那些被忽略的物理细节中。在工业现场,RS-485总…...
告别手动分页!用z-paging在uni-app里5分钟搞定列表加载(附完整配置流程)
告别手动分页!用z-paging在uni-app里5分钟搞定列表加载(附完整配置流程) 每次开发uni-app的列表页,最头疼的就是处理分页逻辑。下拉刷新要重置数据、上拉加载要拼接数组、空状态要手动判断...这些重复劳动不仅浪费时间,…...
职业倦怠期自救:软件测试从业者如何重新点燃对技术的热情
当测试工作变得“自动化”作为软件测试从业者,我们每天都在与缺陷、需求和自动化脚本打交道。从功能测试到性能压测,从接口自动化到安全渗透,日复一日的测试循环中,最初的探索乐趣可能逐渐被重复、高压和“背锅”的疲惫所取代。你…...
【2026最新版】小白程序员必看!AI Agent从入门到实战全解析(建议收藏)
对于刚入门大模型的小白,或是想拓展技术边界、抢占职场先机的程序员来说,AI Agent绝对是2026年最值得重点深耕的核心方向——它彻底打破了传统大模型“只输出、不落地”的局限,真正实现了“思考决策执行”一体化,堪称未来职场最具…...
