目录
[3. K8S 1.29版本 部署Nexus](#3. K8S 1.29版本 部署Nexus)
一、实验
1.环境
(1)主机
表1 主机
|--------|--------------|--------|----------------|------------|
| 主机 | 架构 | 版本 | IP | 备注 |
| master | K8S master节点 | 1.29.0 | 192.168.204.8 | |
| node1 | K8S node节点 | 1.29.0 | 192.168.204.9 | |
| node2 | K8S node节点 | 1.29.0 | 192.168.204.10 | 已部署Kuboard |
(2)master节点查看集群
bash
1)查看node
kubectl get node
2)查看node详细信息
kubectl get node -o wide
(3)查看pod
bash
[root@master ~]# kubectl get pod -A
data:image/s3,"s3://crabby-images/859dd/859dd87b8d4e60195b25660ca8a22b978bb61c6f" alt=""
(4) 访问Kuboard
bash
http://192.168.204.10:30080/kuboard/cluster
data:image/s3,"s3://crabby-images/a9b5f/a9b5f50415168f3f471feea62fe4f0c8487a78fe" alt=""
查看节点
data:image/s3,"s3://crabby-images/06e57/06e57b587a1744391bb302a40ed979cf6a7d4d91" alt=""
2.搭建NFS
(1)检查并安装rpcbind和nfs-utils软件包
bash
[root@master ~]# rpm -q rpcbind nfs-utils
data:image/s3,"s3://crabby-images/6cc86/6cc86a49b6a4ecdecd519e31c1ad2c290d620cbb" alt=""
(2)创建目录并授权
bash
[root@master ~]# mkdir -p /opt/nexus
data:image/s3,"s3://crabby-images/f1f20/f1f202c4a80fec6c43a3ba495ce70220bbf4494d" alt=""
bash
[root@master opt]# chmod 777 nexus/
data:image/s3,"s3://crabby-images/cfcce/cfcceedb1cfc1c9db324c1f68d7e796b955d82ea" alt=""
(3)打开nfs的配置文件
bash
[root@master opt]# vim /etc/exports
data:image/s3,"s3://crabby-images/601a1/601a1569e6948697eb22682404f53badcc2772bb" alt=""
(4)配置文件
给所有网段用户赋予读写权限、同步内容、不压缩共享对象root用户权限
bash
......
/opt/nexus *(rw,sync,no_root_squash)
data:image/s3,"s3://crabby-images/423a9/423a9901cc302040d9e4eab90ef6c99bbfdf7b9a" alt=""
(5)先后开启rpcbind、nfs服务并热加载配置文件内容,查看本机发布的nfs共享目录
bash
[root@master opt]# systemctl restart nfs
data:image/s3,"s3://crabby-images/552d3/552d3562a0a14003e3600d44311d5a777c26d2a4" alt=""
(6)监听端口
bash
[root@master opt]# ss -antp | grep rpcbind
data:image/s3,"s3://crabby-images/ef059/ef0592d84d8c63524677947e1fc44cc6b677eeca" alt=""
(7)查看共享
bash
[root@master opt]# showmount -e
data:image/s3,"s3://crabby-images/8685d/8685df5696a4b24989998a3807642ac0cf891932" alt=""
其他节点查看
bash
[root@node1 ~]# showmount -e master
data:image/s3,"s3://crabby-images/0c4f5/0c4f52fab6f11161cb2dc58af5efae379b74a47f" alt=""
3. K8S 1.29版本 部署Nexus
(1)创建名称空间
bash
[root@master opt]# kubectl create ns nexus
data:image/s3,"s3://crabby-images/43834/438343314037cf5d0928e892b69f9ac179cde1d4" alt=""
(2)创建nexus的pv
bash
[root@master ~]# vim pv-nexus.yaml
data:image/s3,"s3://crabby-images/63943/63943ee20cb29272f8e6de932b5fbef903f1d66a" alt=""
bash
apiVersion: v1
kind: PersistentVolume
metadata:
name: pv-nexus
spec:
capacity:
storage: 30Gi #配置容量大小
volumeMode: Filesystem
accessModes:
- ReadWriteOnce #配置访问策略为只允许一个节点读写
persistentVolumeReclaimPolicy: Retain #配置回收策略,Retain为手动回收
storageClassName: "pv-nexus" #配置为nfs
nfs:
path: /opt/nexus #配置nfs服务端的共享路径
server: 192.168.204.8 #配置nfs服务器地址
data:image/s3,"s3://crabby-images/bfaa2/bfaa26c5106c4877babbde731d2ff890b25b42e3" alt=""
(3)生成资源
bash
[root@master ~]# kubectl apply -f pv-nexus.yaml
data:image/s3,"s3://crabby-images/97d87/97d872720d3639e2b8fc50be20a4660ee65ae89b" alt=""
(4)查看pv
bash
[root@master ~]# kubectl get pv
data:image/s3,"s3://crabby-images/2b54a/2b54a118f04ef2459e3924ef6b1353623859b74d" alt=""
(5)拉取镜像
node1
bash
[root@node1 ~]# docker pull sonatype/nexus3:3.28.0
data:image/s3,"s3://crabby-images/31795/31795bea1ef8b79bbe3436c37d7598ddad20e02f" alt=""
(6) 导出镜像
bash
[root@node1 ~]# docker save -o nexus.tar sonatype/nexus3:3.28.0
data:image/s3,"s3://crabby-images/adfe6/adfe60a3e0baee200c89f2134d641fc2e12e1845" alt=""
(7)复制Docker镜像到node2节点
bash
[root@node1 ~]# scp nexus.tar root@node2:~
(8)node2节点导入Docker镜像
bash
[root@node2 ~]# docker load -i nexus.tar
data:image/s3,"s3://crabby-images/02f7c/02f7c7f38c03c37ffd3199669261cab1dc70610c" alt=""
(9)部署nexus
bash
[root@master ~]# vim nexus.yaml
data:image/s3,"s3://crabby-images/f1d79/f1d797da70236ab4de5e108cef5f99af18312c2f" alt=""
bash
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: nexus-pvc
namespace: nexus
spec:
accessModes:
- ReadWriteOnce
storageClassName: "pv-nexus"
resources:
requests:
storage: 30Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: nexus
name: nexus
namespace: nexus
spec:
replicas: 1
progressDeadlineSeconds: 600
minReadySeconds: 30
strategy:
rollingUpdate:
maxSurge: 1
maxUnavailable: 0
type: RollingUpdate
selector:
matchLabels:
app: nexus
template:
metadata:
labels:
app: nexus
spec:
containers:
- name: nexus
image: sonatype/nexus3:3.28.0
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8081
name: web
protocol: TCP
livenessProbe:
httpGet:
path: /
port: 8081
initialDelaySeconds: 70
periodSeconds: 30
failureThreshold: 6
readinessProbe:
httpGet:
path: /
port: 8081
initialDelaySeconds: 60
periodSeconds: 30
failureThreshold: 6
resources:
limits:
cpu: 1000m
memory: 2Gi
requests:
cpu: 500m
memory: 512Mi
volumeMounts:
- name: nexus-data
mountPath: /nexus-data
volumes:
- name: nexus-data
persistentVolumeClaim:
claimName: nexus-pvc
---
apiVersion: v1
kind: Service
metadata:
name: nexus
namespace: nexus
labels:
app: nexus
spec:
selector:
app: nexus
type: NodePort
ports:
- name: web
protocol: TCP
port: 8081
targetPort: 8081
nodePort: 30001
(11)生成资源
bash
[root@master nexus]# kubectl apply -f nexus.yaml
data:image/s3,"s3://crabby-images/94592/945927559bb5d0298422f62d920f14c78fa3ef3a" alt=""
data:image/s3,"s3://crabby-images/3318c/3318cc4351f62d32aa66eac635151c468404f962" alt=""
(12)查看pv,pvc
bash
[root@master ~]# kubectl get pv
data:image/s3,"s3://crabby-images/155c2/155c2ca98b421f5661da82a36ac1138236220c4f" alt=""
bash
[root@master ~]# kubectl get pvc -n nexus
data:image/s3,"s3://crabby-images/8a0c2/8a0c2729955017170af34da745629bfe8fa3f1e4" alt=""
(13) 查看pod,svc
bash
[root@master ~]# kubectl get pod,svc -n nexus
data:image/s3,"s3://crabby-images/f865e/f865e474408a5acffcfeb86341040d5ddb3392f6" alt=""
(14) Kuboard查看
工作负载
data:image/s3,"s3://crabby-images/390ce/390ced0580c5e1049fc519e9345e9bce22785831" alt=""
容器组
data:image/s3,"s3://crabby-images/c2d5e/c2d5eadaa1adcbb609790f40b70ebf384debb006" alt=""
服务
data:image/s3,"s3://crabby-images/1a04f/1a04fc6041edf9eb8889649c765071df8269178f" alt=""
存储
data:image/s3,"s3://crabby-images/a01f9/a01f98ea3f9c8de165fb26a5923b6b2883974efd" alt=""
(15)部署ingress
bash
vim ingress-nexus.yaml
data:image/s3,"s3://crabby-images/ef682/ef682d294c736dcb507b2126e52717a57f100958" alt=""
bash
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: ingress-nexus
namespace: nexus
spec:
ingressClassName: "nginx"
rules:
- host: nexus.site
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: nexus
port:
number: 8081
data:image/s3,"s3://crabby-images/af6b1/af6b1620dcf94dff32d3266c40b91d92f0fe6a60" alt=""
(16)生成资源
bash
[root@master ~]# kubectl apply -f ingress-nexus.yaml
data:image/s3,"s3://crabby-images/fc7b3/fc7b37699dcb8523f6b41d3285bcfa81240719db" alt=""
(17)查看ingress
bash
[root@master ~]# kubectl get ingress -n nexus
data:image/s3,"s3://crabby-images/f8dc0/f8dc0eaefe5a451584799a2afd41dba4d86c47d1" alt=""
(18)详细查看
bash
[root@master ~]# kubectl describe ingress ingress-nexus -n nexus
Name: ingress-nexus
Labels: <none>
Namespace: nexus
Address: 10.101.23.182
Ingress Class: nginx
Default backend: <default>
Rules:
Host Path Backends
---- ---- --------
nexus.site
/ nexus:8081 (10.244.166.164:8081)
Annotations: <none>
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal Sync 68s (x2 over 82s) nginx-ingress-controller Scheduled for sync
Normal Sync 68s (x2 over 82s) nginx-ingress-controller Scheduled for sync
data:image/s3,"s3://crabby-images/87fc4/87fc4a88a35ff5051adf52995acebe890d8bc1fb" alt=""
(19)Kuboard查看
应用路由
data:image/s3,"s3://crabby-images/f529a/f529ac2163ced3dfae7085af8bf933abbc64365c" alt=""
详细信息
data:image/s3,"s3://crabby-images/61e67/61e676410c0b17d15f9a24cc267b6c10ead8a22a" alt=""
(20)master节点修改hosts
bash
[root@master ~]# vim /etc/hosts
data:image/s3,"s3://crabby-images/faec8/faec898594cb150b825834baae783923c9c0b0a1" alt=""
data:image/s3,"s3://crabby-images/caa99/caa9901dd2892d91b24f5f988b12f8f01545e5a8" alt=""
(21)curl测试
(22)物理机修改hosts
data:image/s3,"s3://crabby-images/b6e4e/b6e4e47e61976c6ae9fcf4a8dd10b82df8de825b" alt=""
data:image/s3,"s3://crabby-images/ef13a/ef13a28a2499a922f9954352f063a46873fd3f9f" alt=""
(23)访问系统
bash
http://nexus.site:31820
data:image/s3,"s3://crabby-images/687c3/687c3f3d5f3f1fa38b7d8a10153d2b5462cc6d3b" alt=""
(24)K8S进入容器获取nexus初始的登录密码
bash
[root@master ~]# kubectl exec -it nexus-8498fc57cc-c82qr -n nexus /bin/bash
......
cat /nexus-data/admin.password
data:image/s3,"s3://crabby-images/ba362/ba362b9588a536b4f678bc35bc3d354e3bf0733b" alt=""
(25)输入用户名和密码
bash
账号:admin
密码:上面获取的初始密码
data:image/s3,"s3://crabby-images/35192/351921efeaeb2a73c00a8ee23a4f3f528e480619" alt=""
(26)进入系统
初始化操作,下一步
data:image/s3,"s3://crabby-images/759a5/759a54c2467f1d54caffd0d277f63f1de1f37ad3" alt=""
修改密码
data:image/s3,"s3://crabby-images/2e54e/2e54ec3276aae4413db987b996336b68ea0c2b59" alt=""
先设置允许匿名访问
data:image/s3,"s3://crabby-images/528f6/528f6ecf3788ce4ebaca4a0c2de6a56eabcdf920" alt=""
完成
data:image/s3,"s3://crabby-images/d9f23/d9f238ad549b81c23dd1714a31a39c9fd7b58a37" alt=""
(26)登录成功
data:image/s3,"s3://crabby-images/03dac/03dacde488d169448d78ccdd39442994a2415e8f" alt=""
(27)查看挂载情况(内容一致)
NFS
bash
[root@master ~]# cd /opt/nexus/
[root@master nexus]# ls
blobs db etc instances karaf.pid lock nexus.yaml port tmp
cache elasticsearch generated-bundles javaprefs keystores log orient restore-from-backup
data:image/s3,"s3://crabby-images/ba63b/ba63b108f55e08d420cceaba090224bfd2209a33" alt=""
K8S容器
bash
[root@master ~]# kubectl exec -it nexus-8498fc57cc-c82qr -n nexus /bin/bash
kubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a future version. Use kubectl exec [POD] -- [COMMAND] instead.
bash-4.4$ ls
bin dev help.1 lib licenses media nexus-data proc run srv tmp uid_template.sh var
boot etc home lib64 lost+found mnt opt root sbin sys uid_entrypoint.sh usr
bash-4.4$ cd nexus-data/
bash-4.4$ ls
blobs db etc instances karaf.pid lock nexus.yaml port tmp
cache elasticsearch generated-bundles javaprefs keystores log orient restore-from-backup
bash-4.4$ exit
exit
data:image/s3,"s3://crabby-images/6084d/6084d7332ecaa9ea9672b70af5c0d617afd27908" alt=""
(28)其他方式的nexus部署
可以参考本人博客:
持续集成交付CICD:CentOS 7 安装 Nexus 3.63-CSDN博客
二、问题
1.volumeMode有哪几种模式
(1)分类
bash
针对 PV 持久卷,Kubernetes 支持两种卷模式(volumeModes):Filesystem(文件系统) 和 Block(块)。
volumeMode 是一个可选的 API 参数。 如果该参数被省略,默认的卷模式是 Filesystem。
volumeMode 属性设置为 Filesystem 的卷会被 Pod 挂载(Mount) 到某个目录。 如果卷的存储来自某块设备而该设备目前为空,Kuberneretes 会在第一次挂载卷之前 在设备上创建文件系统。