千磨万击还坚劲,任尔东西南北风。这篇文章主要讲述k8s部署-19-harbor高可用部署相关的知识,希望能为你提供帮助。
当我们使用k8s的时候,就不可以避免的会涉及到很多的镜像,那么是不是最好有一个地方能存放这些东西呢?还记得之前写docker系列的时候,有提到一个服务,叫做harbor,他就是存放镜像的,在k8s中,我还还是使用该服务,且扩展下搭建一个高可用的。
??harbor架构??
从官网找到下面这张图,可以大概的看一下,有一个简单的认知。
??软件下载??
从公众号“运维家”后台回复“harbor”即可获取软件下载地址。
??环境??
PS:harbor最好找两台独立的服务器来安装,我这里没有足够的服务器,所以在两个worker节点上进行安装了。节点名字
ip地址
node2
192.168.112.131
node3
192.168.112.132
??上传解压??
PS:本步骤需要在两个节点上同时执行;
[root@node2 ~]# tar xf harbor-offline-installer-v1.10.10.tgz
[root@node2 ~]# cd harbor/
[root@node2 harbor]# ls
common.shharbor.v1.10.10.tar.gzharbor.ymlinstall.shLICENSEprepare
[root@node2 harbor]#
??配置修改??
PS:本步骤需要在两个节点上同时执行;
[root@node2 harbor]# vim harbor.yml
# hostname需要修改成本机的地址
hostname: 192.168.112.131
# 密码修改,我在这里就不进行修改了
harbor_admin_password:Harbor12345
# 修改存储磁盘,默认是data,具体根据你服务器来修改,
# 应该放置到最大目录下,我在这里就不修改了
data_volume: /data
# harbordb的密码,我在这里也不进行修改了
password: root123
# 把有关https的全部注释掉
# https:
# https port for harbor, default is 443
# port: 443
# The path of cert and key files for nginx
#certificate: /your/certificate/path
#private_key: /your/private/key/path
[root@node2 harbor]#
??安装??
PS:本步骤需要在两个节点上同时执行;PS:安装之前需要先安装docker,此步骤就不写了,有疑惑的同学可以查看往期文章,或者直接公众号“运维家”后台回复“docker安装”,即可查看该内容。
往期推荐
??01-?docker?系列-linux下的?docker?安装??
[root@node2 harbor]# pwd
/root/harbor
[root@node2 harbor]# ./install.sh
提示如下内容就表示安装成功了。
??访问??
使用浏览器分别访问我们两台服务器的harbor界面,地址为:
http://192.168.112.131
http://192.168.112.132
都出现如下界面的时候,就表示我们的harbor安装成功了。
??nginx配置
??
使用nginx做代理,目的是为了访问harbor的方式为高可用,至于如何配置harbor为高可用,下面我们会提到,一步一步来。首先需要安装nginx,参考往期文章进行安装,安装在我们的节点1上,即原k8s集群中的node1(192.168.112.130)上:
【k8s部署-19-harbor高可用部署】
往期推荐
??如何安装?nginx?并代理下载服务器文件??
上面的文章中,我们只需要操作到nginx安装成功即可,然后将nginx的配置文件置空,并写入以下内容:
当一个节点down掉之后,只需要修改nginx配置文件,就可以快速的切换到另一个节点。
userroot;
worker_processes1;
error_log/usr/local/nginx/logs/error.log warn;
pid/usr/local/nginx/nginx.pid;
events
worker_connections1024;
stream
upstream harbor
server 192.168.112.131:80;
#server 192.168.112.132:80;
server
listen 80;
proxy_connect_timeout 10s;
proxy_timeout 300s;
proxy_pass harbor;
然后启动nginx:
[root@node1 nginx]# pwd
/usr/local/nginx
# 检查配置文件是否有问题
[root@node1 nginx]# ./sbin/nginx -t
nginx: the configuration file /usr/local/nginx//conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx//conf/nginx.conf test is successful
# 启动nginx
[root@node1 nginx]# ./sbin/nginx
??验证??
通过浏览器访问node1的IP,看下是否可以访问到harbor服务。
http://192.168.112.130
出现了如下界面:
这个时候我们是通过IP地址进行访问的,如果我们想通过域名访问呢?
??域名解析??当然是做域名解析最合适了,但是由于我们这里是实验环境,就一切从简,修改hosts文件,来达到这个目的,操作如下:
客户端修改(windows):
打开如下目录:
C:\\Windows\\System32\\drivers\\etc
找到hosts文件,右键使用笔记本打开,文件最后新增如下配置:
192.168.112.130 harbor.yunweijia.com
最后保存关闭即可。
linux服务器修改(三台服务器都需要修改):
[root@node1 nginx]# vim /etc/hosts
# 新增如下内容
192.168.112.130 harbor.yunweijia.com
[root@node1 nginx]#
最后浏览器访问验证:
http://harbor.yunweijia.com/
出现如下界面:
??haobor高可用??
访问node2上的harbor:
http://192.168.112.131/
使用admin/Harbor12345 登录进去,密码如果你修改了,记得使用你自己的密码,登录之后界面如下:
1、他默认有个library的仓库,我们将其删除:
2、然后新建一个k8s的仓库,如下:
点击确定之后,如下图:
3、创建一个用户:
剩余内容请转至VX公众号 “运维家” ,回复 “126” 查看。
推荐阅读
- #yyds干货盘点#JAVA三年经验面试题
- mongodb集群搭建
- #yyds干货盘点# Map - WeakHashMap源码解析
- 用C语言实现对一个有序数组的折半查找
- Flink的sink实战之二(kafka)
- 对话CoCoPIE首席科学家(AI可以当裁判,但不能喧宾夺主)
- 算法题每日一练---第12天(算式900)
- 3 步排查,3 步优化,探针性能损耗直降 44%
- RabbitMQ从概念到使用从Docker安装到RabbitMQ整合Springboot1.5w字最全教学